Sha256: 1ccd757189dae0698727637c7472d63d0325e1db3dfdab811af3291600d96ee9
Contents?: true
Size: 1.19 KB
Versions: 2
Compression:
Stored size: 1.19 KB
Contents
module QueueBus # fans out an event to multiple queues class Driver class << self def subscription_matches(attributes) out = [] Application.all.each do |app| subs = app.subscription_matches(attributes) out.concat(subs) end out end def perform(attributes={}) raise "No attributes passed" if attributes.empty? ::QueueBus.log_worker("Driver running: #{attributes.inspect}") subscription_matches(attributes).each do |sub| ::QueueBus.log_worker(" ...sending to #{sub.queue_name} queue with class #{sub.class_name} for app #{sub.app_key} because of subscription: #{sub.key}") bus_attr = { "bus_driven_at" => Time.now.to_i, "bus_rider_queue" => sub.queue_name, "bus_rider_app_key" => sub.app_key, "bus_rider_sub_key" => sub.key, "bus_rider_class_name" => sub.class_name} bus_attr = bus_attr.merge(attributes || {}) bus_attr["bus_class_proxy"] = sub.class_name ::QueueBus.enqueue_to(sub.queue_name, ::QueueBus::Worker, bus_attr) end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
queue-bus-0.5.2 | lib/queue_bus/driver.rb |
queue-bus-0.5.1 | lib/queue_bus/driver.rb |