Sha256: 15c0f03d03cf6b9373b4201fbc35dd38c71a7fb7909069e7a2fb99d030323d55
Contents?: true
Size: 1.34 KB
Versions: 2
Compression:
Stored size: 1.34 KB
Contents
module QueueDispatcher class QueueDispatcherProxy < ActiveSupport::ProxyObject def initialize(target, options = {}) ## Workaround for Rails 4.2: All serialized objects which respond to :id will get typecasted by its id. This ## behaviour doesn't allow to store ActiveRecord objects. We handle this, by encapsulating all objects in ## before storing. @target = TargetContainer.new(target) @options = options end def method_missing(method, *args) # Find or create the task_queue terminate_immediately = @options.delete(:terminate_immediately) terminate_immediately = terminate_immediately.nil? ? false : terminate_immediately terminate_immediately = @options[:queue].nil? ? true : terminate_immediately task_queue_name = @options.delete(:queue) || "#{@target.payload.to_s}_#{::Time.now.to_f}" task_queue = ::TaskQueue.find_or_create_by_name task_queue_name, terminate_immediately: terminate_immediately # Create Task default_values = {priority: 100} mandatory_values = {target: @target, method_name: method, args: args, state: 'new', task_queue_id: task_queue.id} ::Task.create default_values.merge(@options).merge(mandatory_values) end end module MessageSending def enqueue(options = {}) QueueDispatcherProxy.new(self, options) end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
queue_dispatcher-2.5.3 | lib/queue_dispatcher/message_sending.rb |
queue_dispatcher-2.3.0 | lib/queue_dispatcher/message_sending.rb |