lib/kafka/protocol/sync_group_request.rb



# frozen_string_literal: true

module Kafka
  module Protocol
    class SyncGroupRequest
      def initialize(group_id:, generation_id:, member_id:, group_assignment: {})
        @group_id = group_id
        @generation_id = generation_id
        @member_id = member_id
        @group_assignment = group_assignment
      end

      def api_key
        SYNC_GROUP_API
      end

      def response_class
        SyncGroupResponse
      end

      def encode(encoder)
        encoder.write_string(@group_id)
        encoder.write_int32(@generation_id)
        encoder.write_string(@member_id)

        encoder.write_array(@group_assignment) do |member_id, member_assignment|
          encoder.write_string(member_id)
          encoder.write_bytes(Encoder.encode_with(member_assignment))
        end
      end
    end
  end
end