| package sarama |
| |
| import ( |
| "time" |
| ) |
| |
| type DeleteTopicsResponse struct { |
| Version int16 |
| ThrottleTime time.Duration |
| TopicErrorCodes map[string]KError |
| } |
| |
| func (d *DeleteTopicsResponse) setVersion(v int16) { |
| d.Version = v |
| } |
| |
| func (d *DeleteTopicsResponse) encode(pe packetEncoder) error { |
| if d.Version >= 1 { |
| pe.putDurationMs(d.ThrottleTime) |
| } |
| |
| if err := pe.putArrayLength(len(d.TopicErrorCodes)); err != nil { |
| return err |
| } |
| for topic, errorCode := range d.TopicErrorCodes { |
| if err := pe.putString(topic); err != nil { |
| return err |
| } |
| pe.putKError(errorCode) |
| pe.putEmptyTaggedFieldArray() |
| } |
| |
| pe.putEmptyTaggedFieldArray() |
| return nil |
| } |
| |
| func (d *DeleteTopicsResponse) decode(pd packetDecoder, version int16) (err error) { |
| if version >= 1 { |
| if d.ThrottleTime, err = pd.getDurationMs(); err != nil { |
| return err |
| } |
| |
| d.Version = version |
| } |
| |
| n, err := pd.getArrayLength() |
| if err != nil { |
| return err |
| } |
| |
| d.TopicErrorCodes = make(map[string]KError, n) |
| |
| for i := 0; i < n; i++ { |
| topic, err := pd.getString() |
| if err != nil { |
| return err |
| } |
| d.TopicErrorCodes[topic], err = pd.getKError() |
| if err != nil { |
| return err |
| } |
| |
| if _, err := pd.getEmptyTaggedFieldArray(); err != nil { |
| return err |
| } |
| } |
| |
| _, err = pd.getEmptyTaggedFieldArray() |
| return err |
| } |
| |
| func (d *DeleteTopicsResponse) key() int16 { |
| return apiKeyDeleteTopics |
| } |
| |
| func (d *DeleteTopicsResponse) version() int16 { |
| return d.Version |
| } |
| |
| func (d *DeleteTopicsResponse) headerVersion() int16 { |
| if d.Version >= 4 { |
| return 1 |
| } |
| return 0 |
| } |
| |
| func (d *DeleteTopicsResponse) isFlexible() bool { |
| return d.isFlexibleVersion(d.Version) |
| } |
| |
| func (d *DeleteTopicsResponse) isFlexibleVersion(version int16) bool { |
| return version >= 4 |
| } |
| |
| func (d *DeleteTopicsResponse) isValidVersion() bool { |
| return d.Version >= 0 && d.Version <= 4 |
| } |
| |
| func (d *DeleteTopicsResponse) requiredVersion() KafkaVersion { |
| switch d.Version { |
| case 4: |
| return V2_4_0_0 |
| case 3: |
| return V2_1_0_0 |
| case 2: |
| return V2_0_0_0 |
| case 1: |
| return V0_11_0_0 |
| case 0: |
| return V0_10_1_0 |
| default: |
| return V2_2_0_0 |
| } |
| } |
| |
| func (r *DeleteTopicsResponse) throttleTime() time.Duration { |
| return r.ThrottleTime |
| } |