12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- package sarama
- import (
- "time"
- )
- type EndTxnResponse struct {
- Version int16
- ThrottleTime time.Duration
- Err KError
- }
- func (e *EndTxnResponse) encode(pe packetEncoder) error {
- pe.putInt32(int32(e.ThrottleTime / time.Millisecond))
- pe.putInt16(int16(e.Err))
- return nil
- }
- func (e *EndTxnResponse) decode(pd packetDecoder, version int16) (err error) {
- throttleTime, err := pd.getInt32()
- if err != nil {
- return err
- }
- e.ThrottleTime = time.Duration(throttleTime) * time.Millisecond
- kerr, err := pd.getInt16()
- if err != nil {
- return err
- }
- e.Err = KError(kerr)
- return nil
- }
- func (e *EndTxnResponse) key() int16 {
- return 26
- }
- func (e *EndTxnResponse) version() int16 {
- return e.Version
- }
- func (r *EndTxnResponse) headerVersion() int16 {
- return 0
- }
- func (e *EndTxnResponse) isValidVersion() bool {
- return e.Version >= 0 && e.Version <= 2
- }
- func (e *EndTxnResponse) requiredVersion() KafkaVersion {
- switch e.Version {
- case 2:
- return V2_7_0_0
- case 1:
- return V2_0_0_0
- default:
- return V0_11_0_0
- }
- }
- func (r *EndTxnResponse) throttleTime() time.Duration {
- return r.ThrottleTime
- }
|