44 lines
878 B
Go
44 lines
878 B
Go
package sarama
|
|
|
|
import "time"
|
|
|
|
type InitProducerIDRequest struct {
|
|
TransactionalID *string
|
|
TransactionTimeout time.Duration
|
|
}
|
|
|
|
func (i *InitProducerIDRequest) encode(pe packetEncoder) error {
|
|
if err := pe.putNullableString(i.TransactionalID); err != nil {
|
|
return err
|
|
}
|
|
pe.putInt32(int32(i.TransactionTimeout / time.Millisecond))
|
|
|
|
return nil
|
|
}
|
|
|
|
func (i *InitProducerIDRequest) decode(pd packetDecoder, version int16) (err error) {
|
|
if i.TransactionalID, err = pd.getNullableString(); err != nil {
|
|
return err
|
|
}
|
|
|
|
timeout, err := pd.getInt32()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
i.TransactionTimeout = time.Duration(timeout) * time.Millisecond
|
|
|
|
return nil
|
|
}
|
|
|
|
func (i *InitProducerIDRequest) key() int16 {
|
|
return 22
|
|
}
|
|
|
|
func (i *InitProducerIDRequest) version() int16 {
|
|
return 0
|
|
}
|
|
|
|
func (i *InitProducerIDRequest) requiredVersion() KafkaVersion {
|
|
return V0_11_0_0
|
|
}
|