metadata_request.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. package sarama
  2. type MetadataRequest struct {
  3. Version int16
  4. Topics []string
  5. AllowAutoTopicCreation bool
  6. }
  7. func (r *MetadataRequest) encode(pe packetEncoder) error {
  8. if r.Version < 0 || r.Version > 5 {
  9. return PacketEncodingError{"invalid or unsupported MetadataRequest version field"}
  10. }
  11. if r.Version == 0 || len(r.Topics) > 0 {
  12. err := pe.putArrayLength(len(r.Topics))
  13. if err != nil {
  14. return err
  15. }
  16. for i := range r.Topics {
  17. err = pe.putString(r.Topics[i])
  18. if err != nil {
  19. return err
  20. }
  21. }
  22. } else {
  23. pe.putInt32(-1)
  24. }
  25. if r.Version > 3 {
  26. pe.putBool(r.AllowAutoTopicCreation)
  27. }
  28. return nil
  29. }
  30. func (r *MetadataRequest) decode(pd packetDecoder, version int16) error {
  31. r.Version = version
  32. size, err := pd.getInt32()
  33. if err != nil {
  34. return err
  35. }
  36. if size > 0 {
  37. r.Topics = make([]string, size)
  38. for i := range r.Topics {
  39. topic, err := pd.getString()
  40. if err != nil {
  41. return err
  42. }
  43. r.Topics[i] = topic
  44. }
  45. }
  46. if r.Version > 3 {
  47. autoCreation, err := pd.getBool()
  48. if err != nil {
  49. return err
  50. }
  51. r.AllowAutoTopicCreation = autoCreation
  52. }
  53. return nil
  54. }
  55. func (r *MetadataRequest) key() int16 {
  56. return 3
  57. }
  58. func (r *MetadataRequest) version() int16 {
  59. return r.Version
  60. }
  61. func (r *MetadataRequest) headerVersion() int16 {
  62. return 1
  63. }
  64. func (r *MetadataRequest) requiredVersion() KafkaVersion {
  65. switch r.Version {
  66. case 1:
  67. return V0_10_0_0
  68. case 2:
  69. return V0_10_1_0
  70. case 3, 4:
  71. return V0_11_0_0
  72. case 5:
  73. return V1_0_0_0
  74. default:
  75. return MinVersion
  76. }
  77. }