Module: ActiveJob::Callbacks::ClassMethods
Relationships & Source Files | |
Defined in: | activejob/lib/active_job/callbacks.rb |
Overview
These methods will be included into any Active Job object, adding callbacks for perform
and enqueue
methods.
Instance Method Summary
-
#after_enqueue(*filters, &blk)
Defines a callback that will get called right after the job is enqueued.
-
#after_perform(*filters, &blk)
Defines a callback that will get called right after the job’s perform method has finished.
-
#around_enqueue(*filters, &blk)
Defines a callback that will get called around the enqueuing of the job.
-
#around_perform(*filters, &blk)
Defines a callback that will get called around the job’s perform method.
-
#before_enqueue(*filters, &blk)
Defines a callback that will get called right before the job is enqueued.
-
#before_perform(*filters, &blk)
Defines a callback that will get called right before the job’s perform method is executed.
Instance Method Details
#after_enqueue(*filters, &blk)
Defines a callback that will get called right after the job is enqueued.
class VideoProcessJob < ActiveJob::Base
queue_as :default
after_enqueue do |job|
result = job.successfully_enqueued? ? "success" : "failure"
$statsd.increment "enqueue-video-job.#{result}"
end
def perform(video_id)
Video.find(video_id).process
end
end
# File 'activejob/lib/active_job/callbacks.rb', line 144
def after_enqueue(*filters, &blk) set_callback(:enqueue, :after, *filters, &blk) end
#after_perform(*filters, &blk)
# File 'activejob/lib/active_job/callbacks.rb', line 72
def after_perform(*filters, &blk) set_callback(:perform, :after, *filters, &blk) end
#around_enqueue(*filters, &blk)
# File 'activejob/lib/active_job/callbacks.rb', line 165
def around_enqueue(*filters, &blk) set_callback(:enqueue, :around, *filters, &blk) end
#around_perform(*filters, &blk)
Defines a callback that will get called around the job’s perform method.
class VideoProcessJob < ActiveJob::Base
queue_as :default
around_perform do |job, block|
UserMailer.notify_video_started_processing(job.arguments.first)
block.call
UserMailer.notify_video_processed(job.arguments.first)
end
def perform(video_id)
Video.find(video_id).process
end
end
You can access the return value of the job only if the execution wasn’t halted.
class VideoProcessJob < ActiveJob::Base
around_perform do |job, block|
value = block.call
puts value # => "Hello World!"
end
def perform
"Hello World!"
end
end
# File 'activejob/lib/active_job/callbacks.rb', line 105
def around_perform(*filters, &blk) set_callback(:perform, :around, *filters, &blk) end
#before_enqueue(*filters, &blk)
# File 'activejob/lib/active_job/callbacks.rb', line 124
def before_enqueue(*filters, &blk) set_callback(:enqueue, :before, *filters, &blk) end
#before_perform(*filters, &blk)
# File 'activejob/lib/active_job/callbacks.rb', line 53
def before_perform(*filters, &blk) set_callback(:perform, :before, *filters, &blk) end