aboutsummaryrefslogblamecommitdiffstats
path: root/lib/active_job/enqueuing.rb
blob: 7f2aef871e4cdde6fa61901597d3bf7d0cacc3ef (plain) (tree)
1
2
3
4
5
6
7
8
9
10
11



                               






                                                                        
                      


                                                                                                                            
       
 








                                                           





                                                                 



                                                                                                                                                     
       
     
   
require 'active_job/parameters'

module ActiveJob
  module Enqueuing
    # Push a job onto the queue.  The arguments must be legal JSON types
    # (string, int, float, nil, true, false, hash or array) or
    # ActiveModel::GlobalIdentication instances.  Arbitrary Ruby objects
    # are not supported.
    #
    # The return value is adapter-specific and may change in a future
    # ActiveJob release.
    def enqueue(*args)
      serialized_args = Parameters.serialize(args)
      ActiveSupport::Notifications.instrument "enqueue.active_job", adapter: queue_adapter, job: self, args: serialized_args
      queue_adapter.queue self, *serialized_args
    end

    # Enqueue a job to be performed at +interval+ from now.
    #
    #   enqueue_in(1.week, "mike")
    #
    # Returns truthy if a job was scheduled.
    def enqueue_in(interval, *args)
      enqueue_at(interval.from_now, *args)
    end

    # Enqueue a job to be performed at an explicit point in time.
    #
    #   enqueue_at(Date.tomorrow.midnight, "mike")
    #
    # Returns truthy if a job was scheduled.
    def enqueue_at(timestamp, *args)
      timestamp       = timestamp.to_f
      serialized_args = Parameters.serialize(args)
      ActiveSupport::Notifications.instrument "enqueue_at.active_job", adapter: queue_adapter, timestamp: timestamp, job: self, args: serialized_args
      queue_adapter.queue_at self, timestamp, *serialized_args
    end
  end
end