Class: Karafka::Routing::Topics

Inherits:
Object
  • Object
show all
Extended by:
Forwardable
Includes:
Enumerable
Defined in:
lib/karafka/routing/topics.rb

Overview

Abstraction layer on top of groups of topics

Instance Method Summary collapse

Constructor Details

#initialize(topics_array) ⇒ Topics

Returns a new instance of Topics.

Parameters:



13
14
15
# File 'lib/karafka/routing/topics.rb', line 13

def initialize(topics_array)
  @accumulator = topics_array.dup
end

Instance Method Details

#delete_ifObject

Allows us to remove elements from the topics

Block to decide what to delete



25
26
27
# File 'lib/karafka/routing/topics.rb', line 25

def delete_if(&)
  @accumulator.delete_if(&)
end

#eachObject

Yields each topic



18
19
20
# File 'lib/karafka/routing/topics.rb', line 18

def each(&)
  @accumulator.each(&)
end

#find(topic_name) ⇒ Karafka::Routing::Topic

Finds topic by its name

Parameters:

  • topic_name (String)

    topic name

Returns:

Raises:



35
36
37
38
# File 'lib/karafka/routing/topics.rb', line 35

def find(topic_name)
  @accumulator.find { |topic| topic.name == topic_name } ||
    raise(Karafka::Errors::TopicNotFoundError, topic_name)
end