| package sarama |
| |
| import "time" |
| |
| // DeleteAclsResponse is a delete acl response |
| type DeleteAclsResponse struct { |
| Version int16 |
| ThrottleTime time.Duration |
| FilterResponses []*FilterResponse |
| } |
| |
| func (d *DeleteAclsResponse) setVersion(v int16) { |
| d.Version = v |
| } |
| |
| func (d *DeleteAclsResponse) encode(pe packetEncoder) error { |
| pe.putDurationMs(d.ThrottleTime) |
| |
| if err := pe.putArrayLength(len(d.FilterResponses)); err != nil { |
| return err |
| } |
| |
| for _, filterResponse := range d.FilterResponses { |
| if err := filterResponse.encode(pe, d.Version); err != nil { |
| return err |
| } |
| } |
| |
| return nil |
| } |
| |
| func (d *DeleteAclsResponse) decode(pd packetDecoder, version int16) (err error) { |
| if d.ThrottleTime, err = pd.getDurationMs(); err != nil { |
| return err |
| } |
| |
| n, err := pd.getArrayLength() |
| if err != nil { |
| return err |
| } |
| d.FilterResponses = make([]*FilterResponse, n) |
| |
| for i := 0; i < n; i++ { |
| d.FilterResponses[i] = new(FilterResponse) |
| if err := d.FilterResponses[i].decode(pd, version); err != nil { |
| return err |
| } |
| } |
| |
| return nil |
| } |
| |
| func (d *DeleteAclsResponse) key() int16 { |
| return apiKeyDeleteAcls |
| } |
| |
| func (d *DeleteAclsResponse) version() int16 { |
| return d.Version |
| } |
| |
| func (d *DeleteAclsResponse) headerVersion() int16 { |
| return 0 |
| } |
| |
| func (d *DeleteAclsResponse) isValidVersion() bool { |
| return d.Version >= 0 && d.Version <= 1 |
| } |
| |
| func (d *DeleteAclsResponse) requiredVersion() KafkaVersion { |
| switch d.Version { |
| case 1: |
| return V2_0_0_0 |
| default: |
| return V0_11_0_0 |
| } |
| } |
| |
| func (r *DeleteAclsResponse) throttleTime() time.Duration { |
| return r.ThrottleTime |
| } |
| |
| // FilterResponse is a filter response type |
| type FilterResponse struct { |
| Err KError |
| ErrMsg *string |
| MatchingAcls []*MatchingAcl |
| } |
| |
| func (f *FilterResponse) encode(pe packetEncoder, version int16) error { |
| pe.putKError(f.Err) |
| if err := pe.putNullableString(f.ErrMsg); err != nil { |
| return err |
| } |
| |
| if err := pe.putArrayLength(len(f.MatchingAcls)); err != nil { |
| return err |
| } |
| for _, matchingAcl := range f.MatchingAcls { |
| if err := matchingAcl.encode(pe, version); err != nil { |
| return err |
| } |
| } |
| |
| return nil |
| } |
| |
| func (f *FilterResponse) decode(pd packetDecoder, version int16) (err error) { |
| f.Err, err = pd.getKError() |
| if err != nil { |
| return err |
| } |
| |
| if f.ErrMsg, err = pd.getNullableString(); err != nil { |
| return err |
| } |
| |
| n, err := pd.getArrayLength() |
| if err != nil { |
| return err |
| } |
| f.MatchingAcls = make([]*MatchingAcl, n) |
| for i := 0; i < n; i++ { |
| f.MatchingAcls[i] = new(MatchingAcl) |
| if err := f.MatchingAcls[i].decode(pd, version); err != nil { |
| return err |
| } |
| } |
| |
| return nil |
| } |
| |
| // MatchingAcl is a matching acl type |
| type MatchingAcl struct { |
| Err KError |
| ErrMsg *string |
| Resource |
| Acl |
| } |
| |
| func (m *MatchingAcl) encode(pe packetEncoder, version int16) error { |
| pe.putKError(m.Err) |
| if err := pe.putNullableString(m.ErrMsg); err != nil { |
| return err |
| } |
| |
| if err := m.Resource.encode(pe, version); err != nil { |
| return err |
| } |
| |
| if err := m.Acl.encode(pe); err != nil { |
| return err |
| } |
| |
| return nil |
| } |
| |
| func (m *MatchingAcl) decode(pd packetDecoder, version int16) (err error) { |
| m.Err, err = pd.getKError() |
| if err != nil { |
| return err |
| } |
| |
| if m.ErrMsg, err = pd.getNullableString(); err != nil { |
| return err |
| } |
| |
| if err := m.Resource.decode(pd, version); err != nil { |
| return err |
| } |
| |
| if err := m.Acl.decode(pd, version); err != nil { |
| return err |
| } |
| |
| return nil |
| } |