sync_group_request.go 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. package sarama
  2. type SyncGroupRequest struct {
  3. GroupId string
  4. GenerationId int32
  5. MemberId string
  6. GroupAssignments map[string][]byte
  7. }
  8. func (r *SyncGroupRequest) encode(pe packetEncoder) error {
  9. if err := pe.putString(r.GroupId); err != nil {
  10. return err
  11. }
  12. pe.putInt32(r.GenerationId)
  13. if err := pe.putString(r.MemberId); err != nil {
  14. return err
  15. }
  16. if err := pe.putArrayLength(len(r.GroupAssignments)); err != nil {
  17. return err
  18. }
  19. for memberId, memberAssignment := range r.GroupAssignments {
  20. if err := pe.putString(memberId); err != nil {
  21. return err
  22. }
  23. if err := pe.putBytes(memberAssignment); err != nil {
  24. return err
  25. }
  26. }
  27. return nil
  28. }
  29. func (r *SyncGroupRequest) decode(pd packetDecoder) (err error) {
  30. if r.GroupId, err = pd.getString(); err != nil {
  31. return
  32. }
  33. if r.GenerationId, err = pd.getInt32(); err != nil {
  34. return
  35. }
  36. if r.MemberId, err = pd.getString(); err != nil {
  37. return
  38. }
  39. n, err := pd.getArrayLength()
  40. if err != nil {
  41. return err
  42. }
  43. if n == 0 {
  44. return nil
  45. }
  46. r.GroupAssignments = make(map[string][]byte)
  47. for i := 0; i < n; i++ {
  48. memberId, err := pd.getString()
  49. if err != nil {
  50. return err
  51. }
  52. memberAssignment, err := pd.getBytes()
  53. if err != nil {
  54. return err
  55. }
  56. r.GroupAssignments[memberId] = memberAssignment
  57. }
  58. return nil
  59. }
  60. func (r *SyncGroupRequest) key() int16 {
  61. return 14
  62. }
  63. func (r *SyncGroupRequest) version() int16 {
  64. return 0
  65. }
  66. func (r *SyncGroupRequest) AddGroupAssignment(memberId string, memberAssignment []byte) {
  67. if r.GroupAssignments == nil {
  68. r.GroupAssignments = make(map[string][]byte)
  69. }
  70. r.GroupAssignments[memberId] = memberAssignment
  71. }