github.com/segmentio/kafka-go@v0.4.48-0.20240318174348-3f6244eb34fd/protocol/addpartitionstotxn/addpartitionstotxn.go (about)

     1  package addpartitionstotxn
     2  
     3  import "github.com/segmentio/kafka-go/protocol"
     4  
     5  func init() {
     6  	protocol.Register(&Request{}, &Response{})
     7  }
     8  
     9  type Request struct {
    10  	// We need at least one tagged field to indicate that this is a "flexible" message
    11  	// type.
    12  	_ struct{} `kafka:"min=v3,max=v3,tag"`
    13  
    14  	TransactionalID string         `kafka:"min=v0,max=v2|min=v3,max=v3,compact"`
    15  	ProducerID      int64          `kafka:"min=v0,max=v3"`
    16  	ProducerEpoch   int16          `kafka:"min=v0,max=v3"`
    17  	Topics          []RequestTopic `kafka:"min=v0,max=v3"`
    18  }
    19  
    20  type RequestTopic struct {
    21  	// We need at least one tagged field to indicate that this is a "flexible" message
    22  	// type.
    23  	_ struct{} `kafka:"min=v3,max=v3,tag"`
    24  
    25  	Name       string  `kafka:"min=v0,max=v2|min=v3,max=v3,compact"`
    26  	Partitions []int32 `kafka:"min=v0,max=v3"`
    27  }
    28  
    29  func (r *Request) ApiKey() protocol.ApiKey { return protocol.AddPartitionsToTxn }
    30  
    31  func (r *Request) Transaction() string { return r.TransactionalID }
    32  
    33  var _ protocol.TransactionalMessage = (*Request)(nil)
    34  
    35  type Response struct {
    36  	// We need at least one tagged field to indicate that this is a "flexible" message
    37  	// type.
    38  	_ struct{} `kafka:"min=v3,max=v3,tag"`
    39  
    40  	ThrottleTimeMs int32            `kafka:"min=v0,max=v3"`
    41  	Results        []ResponseResult `kafka:"min=v0,max=v3"`
    42  }
    43  
    44  type ResponseResult struct {
    45  	// We need at least one tagged field to indicate that this is a "flexible" message
    46  	// type.
    47  	_ struct{} `kafka:"min=v3,max=v3,tag"`
    48  
    49  	Name    string              `kafka:"min=v0,max=v2|min=v3,max=v3,compact"`
    50  	Results []ResponsePartition `kafka:"min=v0,max=v3"`
    51  }
    52  
    53  type ResponsePartition struct {
    54  	// We need at least one tagged field to indicate that this is a "flexible" message
    55  	// type.
    56  	_ struct{} `kafka:"min=v3,max=v3,tag"`
    57  
    58  	PartitionIndex int32 `kafka:"min=v0,max=v3"`
    59  	ErrorCode      int16 `kafka:"min=v0,max=v3"`
    60  }
    61  
    62  func (r *Response) ApiKey() protocol.ApiKey { return protocol.AddPartitionsToTxn }