Sha256: ec32e3458e6029b51f38c55602e6f8dbf7602a84b4b083eb84e036bdc19d59c8
Contents?: true
Size: 1.27 KB
Versions: 10
Compression:
Stored size: 1.27 KB
Contents
module AhoyEmail class DatabaseSubscriber def track_send(event) # use has_history to store on Ahoy::Messages end def track_click(event) Ahoy::Click.create!(campaign: event[:campaign], token: event[:token]) end def stats(campaign) sends = Ahoy::Message.where(campaign: campaign).count if defined?(ActiveRecord) && Ahoy::Click < ActiveRecord::Base result = Ahoy::Click.where(campaign: campaign).select("COUNT(*) AS clicks, COUNT(DISTINCT token) AS unique_clicks").to_a[0] clicks = result.clicks unique_clicks = result.unique_clicks else clicks = Ahoy::Click.where(campaign: campaign).count # TODO use aggregation framework unique_clicks = Ahoy::Click.where(campaign: campaign).distinct(:token).count end if sends > 0 || clicks > 0 { sends: sends, clicks: clicks, unique_clicks: unique_clicks, ctr: 100 * unique_clicks / sends.to_f } end end def campaigns if defined?(ActiveRecord) && Ahoy::Message < ActiveRecord::Base Ahoy::Message.where.not(campaign: nil).distinct.pluck(:campaign) else Ahoy::Message.where(campaign: {"$ne" => nil}).distinct(:campaign) end end end end
Version data entries
10 entries across 10 versions & 1 rubygems