blob: ca683cdd0bba4449a4db6435bfc5f507c4f1fd16 [file] [log] [blame]
Abhay Kumar40252eb2025-10-13 13:25:53 +00001package sarama
2
3import (
4 "time"
5)
6
7type DeleteGroupsResponse struct {
8 Version int16
9 ThrottleTime time.Duration
10 GroupErrorCodes map[string]KError
11}
12
13func (r *DeleteGroupsResponse) setVersion(v int16) {
14 r.Version = v
15}
16
17func (r *DeleteGroupsResponse) encode(pe packetEncoder) error {
18 pe.putDurationMs(r.ThrottleTime)
19
20 if err := pe.putArrayLength(len(r.GroupErrorCodes)); err != nil {
21 return err
22 }
23 for groupID, errorCode := range r.GroupErrorCodes {
24 if err := pe.putString(groupID); err != nil {
25 return err
26 }
27 pe.putKError(errorCode)
28 pe.putEmptyTaggedFieldArray()
29 }
30
31 pe.putEmptyTaggedFieldArray()
32 return nil
33}
34
35func (r *DeleteGroupsResponse) decode(pd packetDecoder, version int16) (err error) {
36 if r.ThrottleTime, err = pd.getDurationMs(); err != nil {
37 return err
38 }
39
40 n, err := pd.getArrayLength()
41 if err != nil {
42 return err
43 }
44 if n == 0 {
45 _, err = pd.getEmptyTaggedFieldArray()
46 return err
47 }
48
49 r.GroupErrorCodes = make(map[string]KError, n)
50 for i := 0; i < n; i++ {
51 groupID, err := pd.getString()
52 if err != nil {
53 return err
54 }
55 r.GroupErrorCodes[groupID], err = pd.getKError()
56 if err != nil {
57 return err
58 }
59
60 if _, err := pd.getEmptyTaggedFieldArray(); err != nil {
61 return err
62 }
63 }
64
65 _, err = pd.getEmptyTaggedFieldArray()
66 return err
67}
68
69func (r *DeleteGroupsResponse) key() int16 {
70 return apiKeyDeleteGroups
71}
72
73func (r *DeleteGroupsResponse) version() int16 {
74 return r.Version
75}
76
77func (r *DeleteGroupsResponse) headerVersion() int16 {
78 if r.Version >= 2 {
79 return 1
80 }
81 return 0
82}
83
84func (r *DeleteGroupsResponse) isFlexible() bool {
85 return r.isFlexibleVersion(r.Version)
86}
87
88func (r *DeleteGroupsResponse) isFlexibleVersion(version int16) bool {
89 return version >= 2
90}
91
92func (r *DeleteGroupsResponse) isValidVersion() bool {
93 return r.Version >= 0 && r.Version <= 2
94}
95
96func (r *DeleteGroupsResponse) requiredVersion() KafkaVersion {
97 switch r.Version {
98 case 2:
99 return V2_4_0_0
100 case 1:
101 return V2_0_0_0
102 case 0:
103 return V1_1_0_0
104 default:
105 return V2_0_0_0
106 }
107}
108
109func (r *DeleteGroupsResponse) throttleTime() time.Duration {
110 return r.ThrottleTime
111}