acl_delete_response.go 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. package sarama
  2. import "time"
  3. type DeleteAclsResponse struct {
  4. Version int16
  5. ThrottleTime time.Duration
  6. FilterResponses []*FilterResponse
  7. }
  8. func (a *DeleteAclsResponse) encode(pe packetEncoder) error {
  9. pe.putInt32(int32(a.ThrottleTime / time.Millisecond))
  10. if err := pe.putArrayLength(len(a.FilterResponses)); err != nil {
  11. return err
  12. }
  13. for _, filterResponse := range a.FilterResponses {
  14. if err := filterResponse.encode(pe, a.Version); err != nil {
  15. return err
  16. }
  17. }
  18. return nil
  19. }
  20. func (a *DeleteAclsResponse) decode(pd packetDecoder, version int16) (err error) {
  21. throttleTime, err := pd.getInt32()
  22. if err != nil {
  23. return err
  24. }
  25. a.ThrottleTime = time.Duration(throttleTime) * time.Millisecond
  26. n, err := pd.getArrayLength()
  27. if err != nil {
  28. return err
  29. }
  30. a.FilterResponses = make([]*FilterResponse, n)
  31. for i := 0; i < n; i++ {
  32. a.FilterResponses[i] = new(FilterResponse)
  33. if err := a.FilterResponses[i].decode(pd, version); err != nil {
  34. return err
  35. }
  36. }
  37. return nil
  38. }
  39. func (d *DeleteAclsResponse) key() int16 {
  40. return 31
  41. }
  42. func (d *DeleteAclsResponse) version() int16 {
  43. return int16(d.Version)
  44. }
  45. func (d *DeleteAclsResponse) requiredVersion() KafkaVersion {
  46. return V0_11_0_0
  47. }
  48. type FilterResponse struct {
  49. Err KError
  50. ErrMsg *string
  51. MatchingAcls []*MatchingAcl
  52. }
  53. func (f *FilterResponse) encode(pe packetEncoder, version int16) error {
  54. pe.putInt16(int16(f.Err))
  55. if err := pe.putNullableString(f.ErrMsg); err != nil {
  56. return err
  57. }
  58. if err := pe.putArrayLength(len(f.MatchingAcls)); err != nil {
  59. return err
  60. }
  61. for _, matchingAcl := range f.MatchingAcls {
  62. if err := matchingAcl.encode(pe, version); err != nil {
  63. return err
  64. }
  65. }
  66. return nil
  67. }
  68. func (f *FilterResponse) decode(pd packetDecoder, version int16) (err error) {
  69. kerr, err := pd.getInt16()
  70. if err != nil {
  71. return err
  72. }
  73. f.Err = KError(kerr)
  74. if f.ErrMsg, err = pd.getNullableString(); err != nil {
  75. return err
  76. }
  77. n, err := pd.getArrayLength()
  78. if err != nil {
  79. return err
  80. }
  81. f.MatchingAcls = make([]*MatchingAcl, n)
  82. for i := 0; i < n; i++ {
  83. f.MatchingAcls[i] = new(MatchingAcl)
  84. if err := f.MatchingAcls[i].decode(pd, version); err != nil {
  85. return err
  86. }
  87. }
  88. return nil
  89. }
  90. type MatchingAcl struct {
  91. Err KError
  92. ErrMsg *string
  93. Resource
  94. Acl
  95. }
  96. func (m *MatchingAcl) encode(pe packetEncoder, version int16) error {
  97. pe.putInt16(int16(m.Err))
  98. if err := pe.putNullableString(m.ErrMsg); err != nil {
  99. return err
  100. }
  101. if err := m.Resource.encode(pe, version); err != nil {
  102. return err
  103. }
  104. if err := m.Acl.encode(pe); err != nil {
  105. return err
  106. }
  107. return nil
  108. }
  109. func (m *MatchingAcl) decode(pd packetDecoder, version int16) (err error) {
  110. kerr, err := pd.getInt16()
  111. if err != nil {
  112. return err
  113. }
  114. m.Err = KError(kerr)
  115. if m.ErrMsg, err = pd.getNullableString(); err != nil {
  116. return err
  117. }
  118. if err := m.Resource.decode(pd, version); err != nil {
  119. return err
  120. }
  121. if err := m.Acl.decode(pd, version); err != nil {
  122. return err
  123. }
  124. return nil
  125. }