Sha256: 2740849762a7c921c668003f96d3db87a59065c277437bc2e81533ce175f3acf
Contents?: true
Size: 1.38 KB
Versions: 2
Compression:
Stored size: 1.38 KB
Contents
# frozen_string_literal: true require 'bunny' module Totoro class BaseQueue class <<self def config @config ||= Totoro::Config.new end def connection @connection ||= Bunny.new(config.connect).tap(&:start) end def channel @channel ||= connection.create_channel end def exchange @exchange ||= channel.default_exchange end # enqueue = publish to direct exchange def enqueue(id, payload) queue = channel.queue(*config.queue(id)) payload = JSON.dump payload exchange.publish(payload, routing_key: queue.name) Rails.logger.info "send message to #{queue.name}" STDOUT.flush rescue Bunny::TCPConnectionFailedForAllHosts, AMQ::Protocol::EmptyResponseError => error Rails.logger.error error.message Rails.logger.info 'Add failed message to resend list' STDOUT.flush Totoro::TotoroFailedMessage.create( class_name: to_s, queue_id: id, payload: payload ) end def subscribe(id) queue = channel.queue(*config.queue(id)) queue.subscribe do |delivery_info, metadata, payload| yield(delivery_info, metadata, payload) end end def get_worker(worker_class) ::Worker.const_get(worker_class.to_s.camelize).new end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
totoro-0.5.3 | lib/totoro/base_queue.rb |
totoro-0.5.2 | lib/totoro/base_queue.rb |