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
|