3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
# File 'lib/mailkick/model.rb', line 3
def mailkick_user(opts = {})
email_key = opts[:email_key] || :email
class_eval do
scope :opted_out, lambda { |options = {}|
binds = [name, true]
if options[:list]
query = "(mailkick_opt_outs.list IS NULL OR mailkick_opt_outs.list = ?)"
binds << options[:list]
else
query = "mailkick_opt_outs.list IS NULL"
end
where("#{options[:not] ? 'NOT ' : ''}EXISTS(SELECT * FROM mailkick_opt_outs WHERE (#{table_name}.#{email_key} = mailkick_opt_outs.email OR (#{table_name}.#{primary_key} = mailkick_opt_outs.user_id AND mailkick_opt_outs.user_type = ?)) AND mailkick_opt_outs.active = ? AND #{query})", *binds)
}
scope :not_opted_out, lambda { |options = {}|
opted_out(options.merge(not: true))
}
define_method :opted_out? do |options = {}|
Mailkick.opted_out?({email: send(email_key), user: self}.merge(options))
end
define_method :opt_out do |options = {}|
Mailkick.opt_out({email: send(email_key), user: self}.merge(options))
end
define_method :opt_in do |options = {}|
Mailkick.opt_in({email: send(email_key), user: self}.merge(options))
end
end
end
|