Class: MultiWorker::Adapters::Resque

Inherits:
Object
  • Object
show all
Defined in:
lib/multi_worker/adapters/resque.rb

Class Method Summary collapse

Class Method Details

.configure(base, opts = {}) ⇒ Object



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
# File 'lib/multi_worker/adapters/resque.rb', line 4

def self.configure(base, opts={})
  base.class_eval do
    @queue = opts[:queue]

    if @retry = opts[:retry]
      require "resque-retry"
      extend ::Resque::Plugins::Retry

      @retry_limit = @retry[:limit]
      @retry_delay = @retry[:delay]
    end

    if @lock = opts[:lock]
      require "resque-lock-timeout"
      extend ::Resque::Plugins::LockTimeout

      if @lock.is_a?(Hash) && @lock[:timeout]
        @lock_timeout = @lock[:timeout].to_i
      end

      if opts[:unique]
        @loner = true
      end
    elsif opts[:unique]
      require "resque-loner"
      include ::Resque::Plugins::UniqueJob
    end

    if opts[:status]
      require "resque-status"
      include ::Resque::Plugins::Status
    end

    def self.perform(*args)
      self.new.perform(*args)
    end

    def self.perform_async(*args)
      ::Resque.enqueue(self, *args)
    end

    def perform_async(*args)
      self.class.perform_async(*args)
    end
  end
end

.rake_taskObject



51
52
53
54
55
56
# File 'lib/multi_worker/adapters/resque.rb', line 51

def self.rake_task
  require 'rake'
  require 'resque/tasks'

  ::Rake::Task['resque:work']
end