alterconfigs.go 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. package alterconfigs
  2. import "github.com/segmentio/kafka-go/protocol"
  3. func init() {
  4. protocol.Register(&Request{}, &Response{})
  5. }
  6. // Detailed API definition: https://kafka.apache.org/protocol#The_Messages_AlterConfigs
  7. type Request struct {
  8. Resources []RequestResources `kafka:"min=v0,max=v1"`
  9. ValidateOnly bool `kafka:"min=v0,max=v1"`
  10. }
  11. func (r *Request) ApiKey() protocol.ApiKey { return protocol.AlterConfigs }
  12. func (r *Request) Broker(cluster protocol.Cluster) (protocol.Broker, error) {
  13. return cluster.Brokers[cluster.Controller], nil
  14. }
  15. type RequestResources struct {
  16. ResourceType int8 `kafka:"min=v0,max=v1"`
  17. ResourceName string `kafka:"min=v0,max=v1"`
  18. Configs []RequestConfig `kafka:"min=v0,max=v1"`
  19. }
  20. type RequestConfig struct {
  21. Name string `kafka:"min=v0,max=v1"`
  22. Value string `kafka:"min=v0,max=v1,nullable"`
  23. }
  24. type Response struct {
  25. ThrottleTimeMs int32 `kafka:"min=v0,max=v1"`
  26. Responses []ResponseResponses `kafka:"min=v0,max=v1"`
  27. }
  28. func (r *Response) ApiKey() protocol.ApiKey { return protocol.AlterConfigs }
  29. type ResponseResponses struct {
  30. ErrorCode int16 `kafka:"min=v0,max=v1"`
  31. ErrorMessage string `kafka:"min=v0,max=v1,nullable"`
  32. ResourceType int8 `kafka:"min=v0,max=v1"`
  33. ResourceName string `kafka:"min=v0,max=v1"`
  34. }
  35. var (
  36. _ protocol.BrokerMessage = (*Request)(nil)
  37. )