2012-02-17 18:54:11 -05:00
|
|
|
require 'sidekiq/extensions/generic_proxy'
|
|
|
|
|
|
|
|
module Sidekiq
|
|
|
|
module Extensions
|
|
|
|
##
|
2012-05-25 23:21:42 -04:00
|
|
|
# Adds 'delay' and 'delay_for' to ActionMailer to offload arbitrary email
|
2012-02-17 18:54:11 -05:00
|
|
|
# delivery to Sidekiq. Example:
|
|
|
|
#
|
|
|
|
# UserMailer.delay.send_welcome_email(new_user)
|
2012-05-25 23:21:42 -04:00
|
|
|
# UserMailer.delay_for(5.days).send_welcome_email(new_user)
|
2012-11-14 23:54:43 -05:00
|
|
|
# UserMailer.delay_until(5.days.from_now).send_welcome_email(new_user)
|
2012-02-17 18:54:11 -05:00
|
|
|
class DelayedMailer
|
|
|
|
include Sidekiq::Worker
|
2012-05-25 23:21:42 -04:00
|
|
|
# I think it's reasonable to assume that emails should take less
|
|
|
|
# than 30 seconds to send.
|
|
|
|
sidekiq_options :timeout => 30
|
2012-02-17 18:54:11 -05:00
|
|
|
|
|
|
|
def perform(yml)
|
|
|
|
(target, method_name, args) = YAML.load(yml)
|
2012-10-19 13:50:44 -04:00
|
|
|
msg = target.send(method_name, *args)
|
|
|
|
# The email method can return nil, which causes ActionMailer to return
|
|
|
|
# an undeliverable empty message.
|
2012-11-14 17:25:48 -05:00
|
|
|
msg.deliver if msg && (msg.to || msg.cc || msg.bcc) && msg.from
|
2012-02-17 18:54:11 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
module ActionMailer
|
2012-10-17 13:17:19 -04:00
|
|
|
def delay(options={})
|
|
|
|
Proxy.new(DelayedMailer, self, options)
|
2012-02-17 18:54:11 -05:00
|
|
|
end
|
2012-10-17 13:17:19 -04:00
|
|
|
def delay_for(interval, options={})
|
|
|
|
Proxy.new(DelayedMailer, self, options.merge('at' => Time.now.to_f + interval.to_f))
|
2012-05-25 23:21:42 -04:00
|
|
|
end
|
2012-11-08 12:05:11 -05:00
|
|
|
def delay_until(timestamp, options={})
|
|
|
|
Proxy.new(DelayedMailer, self, options.merge('at' => timestamp.to_f))
|
|
|
|
end
|
2012-02-17 18:54:11 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|
2012-03-10 15:30:15 -05:00
|
|
|
end
|