Sha256: c13f289381f59f125323cb9f56cc03ced042603804e3246208c869941f141c30

Contents?: true

Size: 946 Bytes

Versions: 56

Compression:

Stored size: 946 Bytes

Contents

module Kafka
  module Protocol
    class MemberAssignment
      attr_reader :topics

      def initialize(version: 0, topics: {}, user_data: nil)
        @version = version
        @topics = topics
        @user_data = user_data
      end

      def assign(topic, partitions)
        @topics[topic] ||= []
        @topics[topic].concat(partitions)
      end

      def encode(encoder)
        encoder.write_int16(@version)

        encoder.write_array(@topics) do |topic, partitions|
          encoder.write_string(topic)

          encoder.write_array(partitions) do |partition|
            encoder.write_int32(partition)
          end
        end

        encoder.write_bytes(@user_data)
      end

      def self.decode(decoder)
        new(
          version: decoder.int16,
          topics: Hash[decoder.array { [decoder.string, decoder.array { decoder.int32 }] }],
          user_data: decoder.bytes,
        )
      end
    end
  end
end

Version data entries

56 entries across 56 versions & 1 rubygems

Version Path
ruby-kafka-0.6.0.beta4 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.6.0.beta3 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.6.0.beta2 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.6.0.beta1 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.5 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.4 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.4.beta1 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.3 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.2 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.2.beta3 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.2.beta2 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.2.beta1 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.1 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.1.beta2 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.1.beta1 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.4.4 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.0 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.0.beta6 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.0.beta5 lib/kafka/protocol/member_assignment.rb
ruby-kafka-0.5.0.beta4 lib/kafka/protocol/member_assignment.rb