Sha256: 4269d340d6d1dd198937d5e471d9a2b001d347a0f30a329f53da073bd40e43c0

Contents?: true

Size: 1.85 KB

Versions: 56

Compression:

Stored size: 1.85 KB

Contents

# frozen_string_literal: true

module Karafka
  module Messages
    # Messages batch represents a set of messages received from Kafka of a single topic partition.
    class Messages
      include Enumerable

      attr_reader :metadata

      # @param messages_array [Array<Karafka::Messages::Message>] array with karafka messages
      # @param metadata [Karafka::Messages::BatchMetadata]
      # @return [Karafka::Messages::Messages] lazy evaluated messages batch object
      def initialize(messages_array, metadata)
        @messages_array = messages_array
        @metadata = metadata
      end

      # @param block [Proc] block we want to execute per each message
      # @note Invocation of this method will not cause loading and deserializing of messages.
      def each(&block)
        @messages_array.each(&block)
      end

      # Runs deserialization of all the messages and returns them
      # @return [Array<Karafka::Messages::Message>]
      def deserialize!
        each(&:payload)
      end

      # @return [Array<Object>] array with deserialized payloads. This method can be useful when
      #   we don't care about metadata and just want to extract all the data payloads from the
      #   batch
      def payloads
        map(&:payload)
      end

      # @return [Array<String>] array with raw, not deserialized payloads
      def raw_payloads
        map(&:raw_payload)
      end

      # @return [Karafka::Messages::Message] first message
      def first
        @messages_array.first
      end

      # @return [Karafka::Messages::Message] last message
      def last
        @messages_array.last
      end

      # @return [Integer] number of messages in the batch
      def size
        @messages_array.size
      end

      # @return [Array<Karafka::Messages::Message>] pure array with messages
      def to_a
        @messages_array
      end
    end
  end
end

Version data entries

56 entries across 56 versions & 1 rubygems

Version Path
karafka-2.0.39 lib/karafka/messages/messages.rb
karafka-2.0.38 lib/karafka/messages/messages.rb
karafka-2.0.37 lib/karafka/messages/messages.rb
karafka-2.0.36 lib/karafka/messages/messages.rb
karafka-2.0.35 lib/karafka/messages/messages.rb
karafka-2.0.34 lib/karafka/messages/messages.rb
karafka-2.0.33 lib/karafka/messages/messages.rb
karafka-2.0.32 lib/karafka/messages/messages.rb
karafka-2.0.31 lib/karafka/messages/messages.rb
karafka-2.0.30 lib/karafka/messages/messages.rb
karafka-2.0.29 lib/karafka/messages/messages.rb
karafka-2.0.28 lib/karafka/messages/messages.rb
karafka-2.0.27 lib/karafka/messages/messages.rb
karafka-2.0.26 lib/karafka/messages/messages.rb
karafka-2.0.24 lib/karafka/messages/messages.rb
karafka-2.0.23 lib/karafka/messages/messages.rb
karafka-2.0.22 lib/karafka/messages/messages.rb
karafka-2.0.21 lib/karafka/messages/messages.rb
karafka-2.0.20 lib/karafka/messages/messages.rb
karafka-2.0.19 lib/karafka/messages/messages.rb