Sha256: 3bbbece2201a6cc6ae33b6c7da470b81d51348bf26d8e0894e9fb9bae0d984f1
Contents?: true
Size: 1.88 KB
Versions: 3
Compression:
Stored size: 1.88 KB
Contents
# frozen_string_literal: true class Freddy module Consumers class TapIntoConsumer def self.consume(*attrs, &block) new(*attrs).consume(&block) end def initialize(thread_pool:, patterns:, channel:, options:) @consume_thread_pool = thread_pool @patterns = patterns @channel = channel @options = options raise 'Do not use durable queues without specifying a group' if durable? && !group end def consume(&block) queue = create_queue consumer = queue.subscribe(manual_ack: true) do |delivery| process_message(queue, delivery, &block) end ResponderHandler.new(consumer, @consume_thread_pool) end private def create_queue topic_exchange = @channel.topic(Freddy::FREDDY_TOPIC_EXCHANGE_NAME) queue = if group @channel.queue("groups.#{group}", durable: durable?) else @channel.queue('', exclusive: true) end @patterns.each do |pattern| queue.bind(topic_exchange, routing_key: pattern) end queue end def process_message(_queue, delivery) @consume_thread_pool.post do delivery.in_span do yield delivery.payload, delivery.routing_key @channel.acknowledge(delivery.tag) end rescue StandardError case on_exception when :reject @channel.reject(delivery.tag) when :requeue @channel.reject(delivery.tag, true) else @channel.acknowledge(delivery.tag) end raise end end def group @options.fetch(:group, nil) end def durable? @options.fetch(:durable, false) end def on_exception @options.fetch(:on_exception, :ack) end end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
freddy-2.5.1 | lib/freddy/consumers/tap_into_consumer.rb |
freddy-2.5.0 | lib/freddy/consumers/tap_into_consumer.rb |
freddy-2.5.0.pre.rc.1 | lib/freddy/consumers/tap_into_consumer.rb |