Module: ActiveJob::Core
Overview
Provides general behavior that will be included into every Active Job object that inherits from ActiveJob::Base.
Defined Under Namespace
Modules: ClassMethods
Instance Attribute Summary collapse
-
#arguments ⇒ Object
Job arguments.
-
#enqueued_at ⇒ Object
Track when a job was enqueued.
-
#exception_executions ⇒ Object
Hash that contains the number of times this job handled errors for each specific retry_on declaration.
-
#executions ⇒ Object
Number of times this job has been executed (which increments on every retry, like after an exception).
-
#job_id ⇒ Object
Job Identifier.
-
#locale ⇒ Object
I18n.locale to be used during the job.
-
#priority ⇒ Object
writeonly
Priority that the job will have (lower is more priority).
-
#provider_job_id ⇒ Object
ID optionally provided by adapter.
-
#queue_name ⇒ Object
writeonly
Queue in which the job will reside.
-
#scheduled_at ⇒ Object
Timestamp when the job should be performed.
-
#serialized_arguments ⇒ Object
writeonly
Sets the attribute serialized_arguments.
-
#timezone ⇒ Object
Timezone to be used during the job.
Instance Method Summary collapse
-
#deserialize(job_data) ⇒ Object
Attaches the stored job data to the current instance.
-
#initialize(*arguments) ⇒ Object
Creates a new job instance.
-
#serialize ⇒ Object
Returns a hash with the job data that can safely be passed to the queuing adapter.
Methods included from ActiveSupport::Concern
append_features, class_methods, extended, included
Instance Attribute Details
#arguments ⇒ Object
Job arguments
10 11 12 |
# File 'activejob/lib/active_job/core.rb', line 10 def arguments @arguments end |
#enqueued_at ⇒ Object
Track when a job was enqueued
44 45 46 |
# File 'activejob/lib/active_job/core.rb', line 44 def enqueued_at @enqueued_at end |
#exception_executions ⇒ Object
Hash that contains the number of times this job handled errors for each specific retry_on declaration. Keys are the string representation of the exceptions listed in the retry_on declaration, while its associated value holds the number of executions where the corresponding retry_on declaration handled one of its listed exceptions.
35 36 37 |
# File 'activejob/lib/active_job/core.rb', line 35 def exception_executions @exception_executions end |
#executions ⇒ Object
Number of times this job has been executed (which increments on every retry, like after an exception).
29 30 31 |
# File 'activejob/lib/active_job/core.rb', line 29 def executions @executions end |
#job_id ⇒ Object
Job Identifier
17 18 19 |
# File 'activejob/lib/active_job/core.rb', line 17 def job_id @job_id end |
#locale ⇒ Object
I18n.locale to be used during the job.
38 39 40 |
# File 'activejob/lib/active_job/core.rb', line 38 def locale @locale end |
#priority=(value) ⇒ Object (writeonly)
Priority that the job will have (lower is more priority).
23 24 25 |
# File 'activejob/lib/active_job/core.rb', line 23 def priority=(value) @priority = value end |
#provider_job_id ⇒ Object
ID optionally provided by adapter
26 27 28 |
# File 'activejob/lib/active_job/core.rb', line 26 def provider_job_id @provider_job_id end |
#queue_name=(value) ⇒ Object (writeonly)
Queue in which the job will reside.
20 21 22 |
# File 'activejob/lib/active_job/core.rb', line 20 def queue_name=(value) @queue_name = value end |
#scheduled_at ⇒ Object
Timestamp when the job should be performed
14 15 16 |
# File 'activejob/lib/active_job/core.rb', line 14 def scheduled_at @scheduled_at end |
#serialized_arguments=(value) ⇒ Object (writeonly)
Sets the attribute serialized_arguments
11 12 13 |
# File 'activejob/lib/active_job/core.rb', line 11 def serialized_arguments=(value) @serialized_arguments = value end |
#timezone ⇒ Object
Timezone to be used during the job.
41 42 43 |
# File 'activejob/lib/active_job/core.rb', line 41 def timezone @timezone end |
Instance Method Details
#deserialize(job_data) ⇒ Object
Attaches the stored job data to the current instance. Receives a hash returned from serialize
Examples
class DeliverWebhookJob < ActiveJob::Base
attr_writer :attempt_number
def attempt_number
@attempt_number ||= 0
end
def serialize
super.merge('attempt_number' => attempt_number + 1)
end
def deserialize(job_data)
super
self.attempt_number = job_data['attempt_number']
end
rescue_from(Timeout::Error) do |exception|
raise exception if attempt_number > 5
retry_job(wait: 10)
end
end
134 135 136 137 138 139 140 141 142 143 144 145 |
# File 'activejob/lib/active_job/core.rb', line 134 def deserialize(job_data) self.job_id = job_data["job_id"] self.provider_job_id = job_data["provider_job_id"] self.queue_name = job_data["queue_name"] self.priority = job_data["priority"] self.serialized_arguments = job_data["arguments"] self.executions = job_data["executions"] self.exception_executions = job_data["exception_executions"] self.locale = job_data["locale"] || I18n.locale.to_s self.timezone = job_data["timezone"] || Time.zone&.name self.enqueued_at = job_data["enqueued_at"] end |
#initialize(*arguments) ⇒ Object
Creates a new job instance. Takes the arguments that will be passed to the perform method.
81 82 83 84 85 86 87 88 |
# File 'activejob/lib/active_job/core.rb', line 81 def initialize(*arguments) @arguments = arguments @job_id = SecureRandom.uuid @queue_name = self.class.queue_name @priority = self.class.priority @executions = 0 @exception_executions = {} end |
#serialize ⇒ Object
Returns a hash with the job data that can safely be passed to the queuing adapter.
92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 |
# File 'activejob/lib/active_job/core.rb', line 92 def serialize { "job_class" => self.class.name, "job_id" => job_id, "provider_job_id" => provider_job_id, "queue_name" => queue_name, "priority" => priority, "arguments" => serialize_arguments_if_needed(arguments), "executions" => executions, "exception_executions" => exception_executions, "locale" => I18n.locale.to_s, "timezone" => Time.zone&.name, "enqueued_at" => Time.now.utc.iso8601 } end |