Sha256: bd9f0db96811bf1d2f9011189e240518ac1279e754c7ffeebeb94f9809aa4060

Contents?: true

Size: 1.39 KB

Versions: 21

Compression:

Stored size: 1.39 KB

Contents

# frozen_string_literal: true

# This Karafka component is a Pro component under a commercial license.
# This Karafka component is NOT licensed under LGPL.
#
# All of the commercial components are present in the lib/karafka/pro directory of this
# repository and their usage requires commercial license agreement.
#
# Karafka has also commercial-friendly license, commercial support and commercial components.
#
# By sending a pull request to the pro components, you are agreeing to transfer the copyright of
# your code to Maciej Mensfeld.

module Karafka
  module Pro
    module Routing
      module Features
        class DeadLetterQueue < Base
          # Expansions to the topic API in DLQ
          module Topic
            # @param strategy [#call, nil] Strategy we want to use or nil if a default strategy
            # (same as in OSS) should be applied
            # @param args [Hash] OSS DLQ arguments
            def dead_letter_queue(strategy: nil, **args)
              return @dead_letter_queue if @dead_letter_queue

              super(**args).tap do |config|
                # If explicit strategy is not provided, use the default approach from OSS
                config.strategy = strategy || lambda do |_errors_tracker, attempt|
                  attempt > config.max_retries ? :dispatch : :retry
                end
              end
            end
          end
        end
      end
    end
  end
end

Version data entries

21 entries across 21 versions & 1 rubygems

Version Path
karafka-2.4.16 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.15 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.14 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.13 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.12 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.11 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.10 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.9 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.8 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.7 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.6 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.5 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.4 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.3 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.0 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.0.rc1 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.3.4 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.0.beta2 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.4.0.beta1 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb
karafka-2.3.3 lib/karafka/pro/routing/features/dead_letter_queue/topic.rb