Sha256: 5ce76835abad175061368eb06713e06407ac4f92e6adea45362b112c19b27923

Contents?: true

Size: 1.45 KB

Versions: 56

Compression:

Stored size: 1.45 KB

Contents

# frozen_string_literal: true

module Karafka
  module Messages
    # Builders encapsulate logic related to creating messages related objects.
    module Builders
      # Builder of a single message based on raw rdkafka message.
      module Message
        class << self
          # @param kafka_message [Rdkafka::Consumer::Message] raw fetched message
          # @param topic [Karafka::Routing::Topic] topic for which this message was fetched
          # @param received_at [Time] moment when we've received the message
          # @return [Karafka::Messages::Message] message object with payload and metadata
          def call(kafka_message, topic, received_at)
            # @see https://github.com/appsignal/rdkafka-ruby/issues/168
            kafka_message.headers.transform_keys!(&:to_s)

            metadata = Karafka::Messages::Metadata.new(
              timestamp: kafka_message.timestamp,
              headers: kafka_message.headers,
              key: kafka_message.key,
              offset: kafka_message.offset,
              deserializer: topic.deserializer,
              partition: kafka_message.partition,
              topic: topic.name,
              received_at: received_at
            ).freeze

            # Karafka messages cannot be frozen because of the lazy deserialization feature
            Karafka::Messages::Message.new(
              kafka_message.payload,
              metadata
            )
          end
        end
      end
    end
  end
end

Version data entries

56 entries across 56 versions & 1 rubygems

Version Path
karafka-2.1.4 lib/karafka/messages/builders/message.rb
karafka-2.1.3 lib/karafka/messages/builders/message.rb
karafka-2.1.2 lib/karafka/messages/builders/message.rb
karafka-2.1.1 lib/karafka/messages/builders/message.rb
karafka-2.1.0 lib/karafka/messages/builders/message.rb
karafka-2.0.41 lib/karafka/messages/builders/message.rb
karafka-2.0.40 lib/karafka/messages/builders/message.rb
karafka-2.0.39 lib/karafka/messages/builders/message.rb
karafka-2.0.38 lib/karafka/messages/builders/message.rb
karafka-2.0.37 lib/karafka/messages/builders/message.rb
karafka-2.0.36 lib/karafka/messages/builders/message.rb
karafka-2.0.35 lib/karafka/messages/builders/message.rb
karafka-2.0.34 lib/karafka/messages/builders/message.rb
karafka-2.0.33 lib/karafka/messages/builders/message.rb
karafka-2.0.32 lib/karafka/messages/builders/message.rb
karafka-2.0.31 lib/karafka/messages/builders/message.rb
karafka-2.0.30 lib/karafka/messages/builders/message.rb
karafka-2.0.29 lib/karafka/messages/builders/message.rb
karafka-2.0.28 lib/karafka/messages/builders/message.rb
karafka-2.0.27 lib/karafka/messages/builders/message.rb