offset_fetch_request.go 847 B

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. package protocol
  2. import enc "sarama/encoding"
  3. type OffsetFetchRequest struct {
  4. ConsumerGroup string
  5. partitions map[string][]int32
  6. }
  7. func (r *OffsetFetchRequest) Encode(pe enc.PacketEncoder) error {
  8. err := pe.PutString(r.ConsumerGroup)
  9. if err != nil {
  10. return err
  11. }
  12. err = pe.PutArrayLength(len(r.partitions))
  13. if err != nil {
  14. return err
  15. }
  16. for topic, partitions := range r.partitions {
  17. err = pe.PutString(topic)
  18. if err != nil {
  19. return err
  20. }
  21. pe.PutInt32Array(partitions)
  22. }
  23. return nil
  24. }
  25. func (r *OffsetFetchRequest) key() int16 {
  26. return 7
  27. }
  28. func (r *OffsetFetchRequest) version() int16 {
  29. return 0
  30. }
  31. func (r *OffsetFetchRequest) AddPartition(topic string, partition_id int32) {
  32. if r.partitions == nil {
  33. r.partitions = make(map[string][]int32)
  34. }
  35. r.partitions[topic] = append(r.partitions[topic], partition_id)
  36. }