describe_groups_response.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. package sarama
  2. type DescribeGroupsResponse struct {
  3. Groups []*GroupDescription
  4. }
  5. func (r *DescribeGroupsResponse) encode(pe packetEncoder) error {
  6. if err := pe.putArrayLength(len(r.Groups)); err != nil {
  7. return err
  8. }
  9. for _, groupDescription := range r.Groups {
  10. if err := groupDescription.encode(pe); err != nil {
  11. return err
  12. }
  13. }
  14. return nil
  15. }
  16. func (r *DescribeGroupsResponse) decode(pd packetDecoder, version int16) (err error) {
  17. n, err := pd.getArrayLength()
  18. if err != nil {
  19. return err
  20. }
  21. r.Groups = make([]*GroupDescription, n)
  22. for i := 0; i < n; i++ {
  23. r.Groups[i] = new(GroupDescription)
  24. if err := r.Groups[i].decode(pd); err != nil {
  25. return err
  26. }
  27. }
  28. return nil
  29. }
  30. func (r *DescribeGroupsResponse) key() int16 {
  31. return 15
  32. }
  33. func (r *DescribeGroupsResponse) version() int16 {
  34. return 0
  35. }
  36. type GroupDescription struct {
  37. Err KError
  38. GroupId string
  39. State string
  40. ProtocolType string
  41. Protocol string
  42. Members map[string]*GroupMemberDescription
  43. }
  44. func (gd *GroupDescription) encode(pe packetEncoder) error {
  45. pe.putInt16(int16(gd.Err))
  46. if err := pe.putString(gd.GroupId); err != nil {
  47. return err
  48. }
  49. if err := pe.putString(gd.State); err != nil {
  50. return err
  51. }
  52. if err := pe.putString(gd.ProtocolType); err != nil {
  53. return err
  54. }
  55. if err := pe.putString(gd.Protocol); err != nil {
  56. return err
  57. }
  58. if err := pe.putArrayLength(len(gd.Members)); err != nil {
  59. return err
  60. }
  61. for memberId, groupMemberDescription := range gd.Members {
  62. if err := pe.putString(memberId); err != nil {
  63. return err
  64. }
  65. if err := groupMemberDescription.encode(pe); err != nil {
  66. return err
  67. }
  68. }
  69. return nil
  70. }
  71. func (gd *GroupDescription) decode(pd packetDecoder) (err error) {
  72. if kerr, err := pd.getInt16(); err != nil {
  73. return err
  74. } else {
  75. gd.Err = KError(kerr)
  76. }
  77. if gd.GroupId, err = pd.getString(); err != nil {
  78. return
  79. }
  80. if gd.State, err = pd.getString(); err != nil {
  81. return
  82. }
  83. if gd.ProtocolType, err = pd.getString(); err != nil {
  84. return
  85. }
  86. if gd.Protocol, err = pd.getString(); err != nil {
  87. return
  88. }
  89. n, err := pd.getArrayLength()
  90. if err != nil {
  91. return err
  92. }
  93. if n == 0 {
  94. return nil
  95. }
  96. gd.Members = make(map[string]*GroupMemberDescription)
  97. for i := 0; i < n; i++ {
  98. memberId, err := pd.getString()
  99. if err != nil {
  100. return err
  101. }
  102. gd.Members[memberId] = new(GroupMemberDescription)
  103. if err := gd.Members[memberId].decode(pd); err != nil {
  104. return err
  105. }
  106. }
  107. return nil
  108. }
  109. type GroupMemberDescription struct {
  110. ClientId string
  111. ClientHost string
  112. MemberMetadata []byte
  113. MemberAssignment []byte
  114. }
  115. func (gmd *GroupMemberDescription) encode(pe packetEncoder) error {
  116. if err := pe.putString(gmd.ClientId); err != nil {
  117. return err
  118. }
  119. if err := pe.putString(gmd.ClientHost); err != nil {
  120. return err
  121. }
  122. if err := pe.putBytes(gmd.MemberMetadata); err != nil {
  123. return err
  124. }
  125. if err := pe.putBytes(gmd.MemberAssignment); err != nil {
  126. return err
  127. }
  128. return nil
  129. }
  130. func (gmd *GroupMemberDescription) decode(pd packetDecoder) (err error) {
  131. if gmd.ClientId, err = pd.getString(); err != nil {
  132. return
  133. }
  134. if gmd.ClientHost, err = pd.getString(); err != nil {
  135. return
  136. }
  137. if gmd.MemberMetadata, err = pd.getBytes(); err != nil {
  138. return
  139. }
  140. if gmd.MemberAssignment, err = pd.getBytes(); err != nil {
  141. return
  142. }
  143. return nil
  144. }