mirror of
https://github.com/mperham/sidekiq.git
synced 2022-11-09 13:52:34 -05:00
e12bf878fa
Replaced with `__send__` from std lib * `send` can now be overridden to be more semantically meaningful * `message.send(user_id)` as opposed to `message.send_message(user_id)` * `__send__` makes it clear that the reflective version is intended
40 lines
1.4 KiB
Ruby
40 lines
1.4 KiB
Ruby
require 'sidekiq/extensions/generic_proxy'
|
|
|
|
module Sidekiq
|
|
module Extensions
|
|
##
|
|
# Adds 'delay', 'delay_for' and `delay_until` methods to ActionMailer to offload arbitrary email
|
|
# delivery to Sidekiq. Example:
|
|
#
|
|
# UserMailer.delay.send_welcome_email(new_user)
|
|
# UserMailer.delay_for(5.days).send_welcome_email(new_user)
|
|
# UserMailer.delay_until(5.days.from_now).send_welcome_email(new_user)
|
|
class DelayedMailer
|
|
include Sidekiq::Worker
|
|
|
|
def perform(yml)
|
|
(target, method_name, args) = YAML.load(yml)
|
|
msg = target.__send__(method_name, *args)
|
|
# The email method can return nil, which causes ActionMailer to return
|
|
# an undeliverable empty message.
|
|
msg.deliver if msg && (msg.to || msg.cc || msg.bcc) && msg.from
|
|
end
|
|
end
|
|
|
|
module ActionMailer
|
|
def sidekiq_delay(options={})
|
|
Proxy.new(DelayedMailer, self, options)
|
|
end
|
|
def sidekiq_delay_for(interval, options={})
|
|
Proxy.new(DelayedMailer, self, options.merge('at' => Time.now.to_f + interval.to_f))
|
|
end
|
|
def sidekiq_delay_until(timestamp, options={})
|
|
Proxy.new(DelayedMailer, self, options.merge('at' => timestamp.to_f))
|
|
end
|
|
alias_method :delay, :sidekiq_delay
|
|
alias_method :delay_for, :sidekiq_delay_for
|
|
alias_method :delay_until, :sidekiq_delay_until
|
|
end
|
|
|
|
end
|
|
end
|