Sha256: 6b03c4233c018b9c9afed84cb7971471b460a0ce249fd9626c85dbbcdd4a9822
Contents?: true
Size: 1.94 KB
Versions: 2
Compression:
Stored size: 1.94 KB
Contents
require 'digest/md5' # # If you want your job to be unique, include this module in it. If you wish, # you can overwrite this implementation of redis_key to fit your needs # module Resque module Plugins module UniqueJob def self.included(base) base.extend ClassMethods base.class_eval do base.send(:extend, Resque::Helpers) end end # self.included module ClassMethods # # Payload is what Resque stored for this job along with the job's class name. # On a Resque with no plugins installed, this is a hash containing :class and :args # def redis_key(payload) payload = decode(encode(payload)) # This is the cycle the data goes when being enqueued/dequeued job = payload[:class] || payload["class"] args = (payload[:args] || payload["args"]) args.map! do |arg| arg.is_a?(Hash) ? arg.sort : arg end digest = Digest::MD5.hexdigest encode(:class => job, :args => args) digest end # # The default ttl of a locking key is -1, i.e. forever. If for some reason you only # want the lock to be in place after a certain amount of time, just set a ttl for # for your job. For example: # # class FooJob # include Resque::Plugins::UniqueJob # @loner_ttl = 40 # end # end # def loner_ttl @loner_ttl || -1 end end # ClassMethods end end end module Resque module Plugins module Loner class UniqueJob include Resque::Plugins::UniqueJob def self.inherited(host) super(host) return if @__unique_job_warned warn "Inherit Resque::Plugins::Loner::UniqueJob is deprecated. Include Resque::Plugins::UniqueJob module instead." @__unique_job_warned = true end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
resque-loner-1.2.1 | lib/resque-loner/unique_job.rb |
resque-loner-1.2.0 | lib/resque-loner/unique_job.rb |