package sarama import "time" type InitProducerIDResponse struct { ThrottleTime time.Duration Err KError Version int16 ProducerID int64 ProducerEpoch int16 } func (i *InitProducerIDResponse) encode(pe packetEncoder) error { pe.putInt32(int32(i.ThrottleTime / time.Millisecond)) pe.putInt16(int16(i.Err)) pe.putInt64(i.ProducerID) pe.putInt16(i.ProducerEpoch) if i.Version >= 2 { pe.putEmptyTaggedFieldArray() } return nil } func (i *InitProducerIDResponse) decode(pd packetDecoder, version int16) (err error) { i.Version = version throttleTime, err := pd.getInt32() if err != nil { return err } i.ThrottleTime = time.Duration(throttleTime) * time.Millisecond kerr, err := pd.getInt16() if err != nil { return err } i.Err = KError(kerr) if i.ProducerID, err = pd.getInt64(); err != nil { return err } if i.ProducerEpoch, err = pd.getInt16(); err != nil { return err } if i.Version >= 2 { if _, err := pd.getEmptyTaggedFieldArray(); err != nil { return err } } return nil } func (i *InitProducerIDResponse) key() int16 { return 22 } func (i *InitProducerIDResponse) version() int16 { return i.Version } func (i *InitProducerIDResponse) headerVersion() int16 { if i.Version >= 2 { return 1 } return 0 } func (i *InitProducerIDResponse) isValidVersion() bool { return i.Version >= 0 && i.Version <= 4 } func (i *InitProducerIDResponse) requiredVersion() KafkaVersion { switch i.Version { case 4: return V2_7_0_0 case 3: return V2_5_0_0 case 2: return V2_4_0_0 case 1: return V2_0_0_0 default: return V0_11_0_0 } } func (r *InitProducerIDResponse) throttleTime() time.Duration { return r.ThrottleTime }