aboutsummaryrefslogtreecommitdiffstats
path: root/activejob/lib/active_job/enqueuing.rb
blob: e3ac11ba97e84e4fe2d5bfe75742b5ae71d3bb8b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
require 'active_job/arguments'

module ActiveJob
  module Enqueuing
    extend ActiveSupport::Concern

    module ClassMethods
      # 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.
      #
      # Returns an instance of the job class queued with args available in
      # Job#arguments.
      def enqueue(*args)
        new(args).tap do |job|
          job.run_callbacks :enqueue do
            queue_adapter.enqueue self, job.job_id, *Arguments.serialize(args)
          end
        end
      end

      # Enqueue a job to be performed at +interval+ from now.
      #
      #   enqueue_in(1.week, "mike")
      #
      # Returns an instance of the job class queued with args available in
      # Job#arguments and the timestamp in Job#enqueue_at.
      def enqueue_in(interval, *args)
        enqueue_at interval.seconds.from_now, *args
      end

      # Enqueue a job to be performed at an explicit point in time.
      #
      #   enqueue_at(Date.tomorrow.midnight, "mike")
      #
      # Returns an instance of the job class queued with args available in
      # Job#arguments and the timestamp in Job#enqueue_at.
      def enqueue_at(timestamp, *args)
        new(args).tap do |job|
          job.enqueued_at = timestamp

          job.run_callbacks :enqueue do
            queue_adapter.enqueue_at self, timestamp.to_f, job.job_id, *Arguments.serialize(args)
          end
        end
      end
    end

    included do
      attr_accessor :arguments
      attr_accessor :enqueued_at
    end

    def initialize(arguments = nil)
      @arguments = arguments
    end

    def retry_now
      self.class.enqueue *arguments
    end

    def retry_in(interval)
      self.class.enqueue_in interval, *arguments
    end

    def retry_at(timestamp)
      self.class.enqueue_at timestamp, *arguments
    end
  end
end