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-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)
|
|
|
|
target.send(method_name, *args).deliver
|
|
|
|
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-02-17 18:54:11 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|
2012-03-10 15:30:15 -05:00
|
|
|
end
|