Module: Karafka::Pro::Routing::Features::DirectAssignments::SubscriptionGroup

Defined in:
lib/karafka/pro/routing/features/direct_assignments/subscription_group.rb

Overview

Extension allowing us to select correct subscriptions and assignments based on the expanded routing setup

Instance Method Summary collapse

Instance Method Details

#assignments(consumer) ⇒ Rdkafka::Consumer::TopicPartitionList

Returns final tpl for assignments.

Parameters:

Returns:

  • (Rdkafka::Consumer::TopicPartitionList)

    final tpl for assignments



29
30
31
32
33
34
35
36
37
38
# File 'lib/karafka/pro/routing/features/direct_assignments/subscription_group.rb', line 29

def assignments(consumer)
  topics
    .select(&:active?)
    .select { |topic| topic.direct_assignments.active? }
    .map { |topic| build_assignments(topic) }
    .to_h
    .tap { |topics| return false if topics.empty? }
    .then { |topics| Iterator::Expander.new.call(topics) }
    .then { |topics| Iterator::TplBuilder.new(consumer, topics).call }
end

#subscriptionsfalse, Array<String>

Returns false if we do not have any subscriptions or array with all the subscriptions for given subscription group.

Returns:

  • (false, Array<String>)

    false if we do not have any subscriptions or array with all the subscriptions for given subscription group



18
19
20
21
22
23
24
# File 'lib/karafka/pro/routing/features/direct_assignments/subscription_group.rb', line 18

def subscriptions
  topics
    .select(&:active?)
    .reject { |topic| topic.direct_assignments.active? }
    .map(&:subscription_name)
    .then { |subscriptions| subscriptions.empty? ? false : subscriptions }
end