aboutsummaryrefslogblamecommitdiffstats
path: root/lib/active_job/enqueuing.rb
blob: dafa2399c8223bd5159277e94e95b93431d6849b (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.enqueue 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, job: self, args: serialized_args, timestamp: timestamp
      queue_adapter.enqueue_at self, timestamp, *serialized_args
    end
  end
end