lib/generated/metadata.ex

defmodule(Kayrock.Metadata) do
  @api :metadata
  @moduledoc "Kayrock-generated module for the Kafka `#{@api}` API\n"
  _ = " THIS CODE IS GENERATED BY KAYROCK"

  (
    @vmin 0
    @vmax 5
  )

  defmodule(V0.Request) do
    @vsn 0
    @api :metadata
    @schema topics: {:array, :string}
    @moduledoc "Kayrock-generated request struct for Kafka `#{@api}` v#{@vsn} API\nmessages\n\nThe schema of this API is\n```\n#{
                 inspect(@schema, pretty: true)
               }\n```\n"
    _ = " THIS CODE IS GENERATED BY KAYROCK"
    defstruct(topics: [], correlation_id: nil, client_id: nil)
    import(Elixir.Kayrock.Serialize)
    @typedoc "Request struct for the Kafka `#{@api}` API v#{@vsn}\n"
    @type t :: %__MODULE__{
            topics: [nil | binary()],
            correlation_id: nil | integer(),
            client_id: nil | binary()
          }
    @doc "Returns the Kafka API key for this API"
    @spec api_key :: integer
    def(api_key) do
      Kayrock.KafkaSchemaMetadata.api_key(:metadata)
    end

    @doc "Returns the API version (#{@vsn}) implemented by this module"
    @spec api_vsn :: integer
    def(api_vsn) do
      0
    end

    @doc "Returns a function that can be used to deserialize the wire response from the\nbroker for this message type\n"
    @spec response_deserializer :: (binary -> {V0.Response.t(), binary})
    def(response_deserializer) do
      &V0.Response.deserialize/1
    end

    @doc "Returns the schema of this message\n\nSee [above](#).\n"
    @spec schema :: term
    def(schema) do
      [topics: {:array, :string}]
    end

    @doc "Serialize a message to binary data for transfer to a Kafka broker"
    @spec serialize(t()) :: iodata
    def(serialize(%V0.Request{} = struct)) do
      [
        <<api_key()::16, api_vsn()::16, struct.correlation_id::32,
          byte_size(struct.client_id)::16, struct.client_id::binary>>,
        [serialize_array(:string, Map.fetch!(struct, :topics))]
      ]
    end
  end

  defimpl(Elixir.Kayrock.Request, for: V0.Request) do
    def(serialize(%V0.Request{} = struct)) do
      try do
        V0.Request.serialize(struct)
      rescue
        e ->
          reraise(Kayrock.InvalidRequestError, {e, struct}, __STACKTRACE__)
      end
    end

    def(api_vsn(%V0.Request{})) do
      V0.Request.api_vsn()
    end

    def(response_deserializer(%V0.Request{})) do
      V0.Request.response_deserializer()
    end
  end

  defmodule(V1.Request) do
    @vsn 1
    @api :metadata
    @schema topics: {:array, :string}
    @moduledoc "Kayrock-generated request struct for Kafka `#{@api}` v#{@vsn} API\nmessages\n\nThe schema of this API is\n```\n#{
                 inspect(@schema, pretty: true)
               }\n```\n"
    _ = " THIS CODE IS GENERATED BY KAYROCK"
    defstruct(topics: [], correlation_id: nil, client_id: nil)
    import(Elixir.Kayrock.Serialize)
    @typedoc "Request struct for the Kafka `#{@api}` API v#{@vsn}\n"
    @type t :: %__MODULE__{
            topics: [nil | binary()],
            correlation_id: nil | integer(),
            client_id: nil | binary()
          }
    @doc "Returns the Kafka API key for this API"
    @spec api_key :: integer
    def(api_key) do
      Kayrock.KafkaSchemaMetadata.api_key(:metadata)
    end

    @doc "Returns the API version (#{@vsn}) implemented by this module"
    @spec api_vsn :: integer
    def(api_vsn) do
      1
    end

    @doc "Returns a function that can be used to deserialize the wire response from the\nbroker for this message type\n"
    @spec response_deserializer :: (binary -> {V1.Response.t(), binary})
    def(response_deserializer) do
      &V1.Response.deserialize/1
    end

    @doc "Returns the schema of this message\n\nSee [above](#).\n"
    @spec schema :: term
    def(schema) do
      [topics: {:array, :string}]
    end

    @doc "Serialize a message to binary data for transfer to a Kafka broker"
    @spec serialize(t()) :: iodata
    def(serialize(%V1.Request{} = struct)) do
      [
        <<api_key()::16, api_vsn()::16, struct.correlation_id::32,
          byte_size(struct.client_id)::16, struct.client_id::binary>>,
        [serialize_array(:string, Map.fetch!(struct, :topics))]
      ]
    end
  end

  defimpl(Elixir.Kayrock.Request, for: V1.Request) do
    def(serialize(%V1.Request{} = struct)) do
      try do
        V1.Request.serialize(struct)
      rescue
        e ->
          reraise(Kayrock.InvalidRequestError, {e, struct}, __STACKTRACE__)
      end
    end

    def(api_vsn(%V1.Request{})) do
      V1.Request.api_vsn()
    end

    def(response_deserializer(%V1.Request{})) do
      V1.Request.response_deserializer()
    end
  end

  defmodule(V2.Request) do
    @vsn 2
    @api :metadata
    @schema topics: {:array, :string}
    @moduledoc "Kayrock-generated request struct for Kafka `#{@api}` v#{@vsn} API\nmessages\n\nThe schema of this API is\n```\n#{
                 inspect(@schema, pretty: true)
               }\n```\n"
    _ = " THIS CODE IS GENERATED BY KAYROCK"
    defstruct(topics: [], correlation_id: nil, client_id: nil)
    import(Elixir.Kayrock.Serialize)
    @typedoc "Request struct for the Kafka `#{@api}` API v#{@vsn}\n"
    @type t :: %__MODULE__{
            topics: [nil | binary()],
            correlation_id: nil | integer(),
            client_id: nil | binary()
          }
    @doc "Returns the Kafka API key for this API"
    @spec api_key :: integer
    def(api_key) do
      Kayrock.KafkaSchemaMetadata.api_key(:metadata)
    end

    @doc "Returns the API version (#{@vsn}) implemented by this module"
    @spec api_vsn :: integer
    def(api_vsn) do
      2
    end

    @doc "Returns a function that can be used to deserialize the wire response from the\nbroker for this message type\n"
    @spec response_deserializer :: (binary -> {V2.Response.t(), binary})
    def(response_deserializer) do
      &V2.Response.deserialize/1
    end

    @doc "Returns the schema of this message\n\nSee [above](#).\n"
    @spec schema :: term
    def(schema) do
      [topics: {:array, :string}]
    end

    @doc "Serialize a message to binary data for transfer to a Kafka broker"
    @spec serialize(t()) :: iodata
    def(serialize(%V2.Request{} = struct)) do
      [
        <<api_key()::16, api_vsn()::16, struct.correlation_id::32,
          byte_size(struct.client_id)::16, struct.client_id::binary>>,
        [serialize_array(:string, Map.fetch!(struct, :topics))]
      ]
    end
  end

  defimpl(Elixir.Kayrock.Request, for: V2.Request) do
    def(serialize(%V2.Request{} = struct)) do
      try do
        V2.Request.serialize(struct)
      rescue
        e ->
          reraise(Kayrock.InvalidRequestError, {e, struct}, __STACKTRACE__)
      end
    end

    def(api_vsn(%V2.Request{})) do
      V2.Request.api_vsn()
    end

    def(response_deserializer(%V2.Request{})) do
      V2.Request.response_deserializer()
    end
  end

  defmodule(V3.Request) do
    @vsn 3
    @api :metadata
    @schema topics: {:array, :string}
    @moduledoc "Kayrock-generated request struct for Kafka `#{@api}` v#{@vsn} API\nmessages\n\nThe schema of this API is\n```\n#{
                 inspect(@schema, pretty: true)
               }\n```\n"
    _ = " THIS CODE IS GENERATED BY KAYROCK"
    defstruct(topics: [], correlation_id: nil, client_id: nil)
    import(Elixir.Kayrock.Serialize)
    @typedoc "Request struct for the Kafka `#{@api}` API v#{@vsn}\n"
    @type t :: %__MODULE__{
            topics: [nil | binary()],
            correlation_id: nil | integer(),
            client_id: nil | binary()
          }
    @doc "Returns the Kafka API key for this API"
    @spec api_key :: integer
    def(api_key) do
      Kayrock.KafkaSchemaMetadata.api_key(:metadata)
    end

    @doc "Returns the API version (#{@vsn}) implemented by this module"
    @spec api_vsn :: integer
    def(api_vsn) do
      3
    end

    @doc "Returns a function that can be used to deserialize the wire response from the\nbroker for this message type\n"
    @spec response_deserializer :: (binary -> {V3.Response.t(), binary})
    def(response_deserializer) do
      &V3.Response.deserialize/1
    end

    @doc "Returns the schema of this message\n\nSee [above](#).\n"
    @spec schema :: term
    def(schema) do
      [topics: {:array, :string}]
    end

    @doc "Serialize a message to binary data for transfer to a Kafka broker"
    @spec serialize(t()) :: iodata
    def(serialize(%V3.Request{} = struct)) do
      [
        <<api_key()::16, api_vsn()::16, struct.correlation_id::32,
          byte_size(struct.client_id)::16, struct.client_id::binary>>,
        [serialize_array(:string, Map.fetch!(struct, :topics))]
      ]
    end
  end

  defimpl(Elixir.Kayrock.Request, for: V3.Request) do
    def(serialize(%V3.Request{} = struct)) do
      try do
        V3.Request.serialize(struct)
      rescue
        e ->
          reraise(Kayrock.InvalidRequestError, {e, struct}, __STACKTRACE__)
      end
    end

    def(api_vsn(%V3.Request{})) do
      V3.Request.api_vsn()
    end

    def(response_deserializer(%V3.Request{})) do
      V3.Request.response_deserializer()
    end
  end

  defmodule(V4.Request) do
    @vsn 4
    @api :metadata
    @schema topics: {:array, :string}, allow_auto_topic_creation: :boolean
    @moduledoc "Kayrock-generated request struct for Kafka `#{@api}` v#{@vsn} API\nmessages\n\nThe schema of this API is\n```\n#{
                 inspect(@schema, pretty: true)
               }\n```\n"
    _ = " THIS CODE IS GENERATED BY KAYROCK"
    defstruct(topics: [], allow_auto_topic_creation: nil, correlation_id: nil, client_id: nil)
    import(Elixir.Kayrock.Serialize)
    @typedoc "Request struct for the Kafka `#{@api}` API v#{@vsn}\n"
    @type t :: %__MODULE__{
            topics: [nil | binary()],
            allow_auto_topic_creation: nil | integer(),
            correlation_id: nil | integer(),
            client_id: nil | binary()
          }
    @doc "Returns the Kafka API key for this API"
    @spec api_key :: integer
    def(api_key) do
      Kayrock.KafkaSchemaMetadata.api_key(:metadata)
    end

    @doc "Returns the API version (#{@vsn}) implemented by this module"
    @spec api_vsn :: integer
    def(api_vsn) do
      4
    end

    @doc "Returns a function that can be used to deserialize the wire response from the\nbroker for this message type\n"
    @spec response_deserializer :: (binary -> {V4.Response.t(), binary})
    def(response_deserializer) do
      &V4.Response.deserialize/1
    end

    @doc "Returns the schema of this message\n\nSee [above](#).\n"
    @spec schema :: term
    def(schema) do
      [topics: {:array, :string}, allow_auto_topic_creation: :boolean]
    end

    @doc "Serialize a message to binary data for transfer to a Kafka broker"
    @spec serialize(t()) :: iodata
    def(serialize(%V4.Request{} = struct)) do
      [
        <<api_key()::16, api_vsn()::16, struct.correlation_id::32,
          byte_size(struct.client_id)::16, struct.client_id::binary>>,
        [
          serialize_array(:string, Map.fetch!(struct, :topics)),
          serialize(:boolean, Map.fetch!(struct, :allow_auto_topic_creation))
        ]
      ]
    end
  end

  defimpl(Elixir.Kayrock.Request, for: V4.Request) do
    def(serialize(%V4.Request{} = struct)) do
      try do
        V4.Request.serialize(struct)
      rescue
        e ->
          reraise(Kayrock.InvalidRequestError, {e, struct}, __STACKTRACE__)
      end
    end

    def(api_vsn(%V4.Request{})) do
      V4.Request.api_vsn()
    end

    def(response_deserializer(%V4.Request{})) do
      V4.Request.response_deserializer()
    end
  end

  defmodule(V5.Request) do
    @vsn 5
    @api :metadata
    @schema topics: {:array, :string}, allow_auto_topic_creation: :boolean
    @moduledoc "Kayrock-generated request struct for Kafka `#{@api}` v#{@vsn} API\nmessages\n\nThe schema of this API is\n```\n#{
                 inspect(@schema, pretty: true)
               }\n```\n"
    _ = " THIS CODE IS GENERATED BY KAYROCK"
    defstruct(topics: [], allow_auto_topic_creation: nil, correlation_id: nil, client_id: nil)
    import(Elixir.Kayrock.Serialize)
    @typedoc "Request struct for the Kafka `#{@api}` API v#{@vsn}\n"
    @type t :: %__MODULE__{
            topics: [nil | binary()],
            allow_auto_topic_creation: nil | integer(),
            correlation_id: nil | integer(),
            client_id: nil | binary()
          }
    @doc "Returns the Kafka API key for this API"
    @spec api_key :: integer
    def(api_key) do
      Kayrock.KafkaSchemaMetadata.api_key(:metadata)
    end

    @doc "Returns the API version (#{@vsn}) implemented by this module"
    @spec api_vsn :: integer
    def(api_vsn) do
      5
    end

    @doc "Returns a function that can be used to deserialize the wire response from the\nbroker for this message type\n"
    @spec response_deserializer :: (binary -> {V5.Response.t(), binary})
    def(response_deserializer) do
      &V5.Response.deserialize/1
    end

    @doc "Returns the schema of this message\n\nSee [above](#).\n"
    @spec schema :: term
    def(schema) do
      [topics: {:array, :string}, allow_auto_topic_creation: :boolean]
    end

    @doc "Serialize a message to binary data for transfer to a Kafka broker"
    @spec serialize(t()) :: iodata
    def(serialize(%V5.Request{} = struct)) do
      [
        <<api_key()::16, api_vsn()::16, struct.correlation_id::32,
          byte_size(struct.client_id)::16, struct.client_id::binary>>,
        [
          serialize_array(:string, Map.fetch!(struct, :topics)),
          serialize(:boolean, Map.fetch!(struct, :allow_auto_topic_creation))
        ]
      ]
    end
  end

  defimpl(Elixir.Kayrock.Request, for: V5.Request) do
    def(serialize(%V5.Request{} = struct)) do
      try do
        V5.Request.serialize(struct)
      rescue
        e ->
          reraise(Kayrock.InvalidRequestError, {e, struct}, __STACKTRACE__)
      end
    end

    def(api_vsn(%V5.Request{})) do
      V5.Request.api_vsn()
    end

    def(response_deserializer(%V5.Request{})) do
      V5.Request.response_deserializer()
    end
  end

  (
    @doc "Returns a request struct for this API with the given version"
    @spec get_request_struct(integer) :: request_t
  )

  def(get_request_struct(0)) do
    %V0.Request{}
  end

  def(get_request_struct(1)) do
    %V1.Request{}
  end

  def(get_request_struct(2)) do
    %V2.Request{}
  end

  def(get_request_struct(3)) do
    %V3.Request{}
  end

  def(get_request_struct(4)) do
    %V4.Request{}
  end

  def(get_request_struct(5)) do
    %V5.Request{}
  end

  defmodule(V0.Response) do
    @vsn 0
    @api :metadata
    @schema brokers: {:array, [node_id: :int32, host: :string, port: :int32]},
            topic_metadata:
              {:array,
               [
                 error_code: :int16,
                 topic: :string,
                 partition_metadata:
                   {:array,
                    [
                      error_code: :int16,
                      partition: :int32,
                      leader: :int32,
                      replicas: {:array, :int32},
                      isr: {:array, :int32}
                    ]}
               ]}
    @moduledoc "Kayrock-generated response struct for Kafka `#{@api}` v#{@vsn} API\nmessages\n\nThe schema of this API is\n```\n#{
                 inspect(@schema, pretty: true)
               }\n```\n"
    _ = " THIS CODE IS GENERATED BY KAYROCK"
    defstruct(brokers: [], topic_metadata: [], correlation_id: nil)
    @typedoc "Response struct for the Kafka `#{@api}` API v#{@vsn}\n"
    @type t :: %__MODULE__{
            brokers: [%{node_id: nil | integer(), host: nil | binary(), port: nil | integer()}],
            topic_metadata: [
              %{
                error_code: nil | integer(),
                topic: nil | binary(),
                partition_metadata: [
                  %{
                    error_code: nil | integer(),
                    partition: nil | integer(),
                    leader: nil | integer(),
                    replicas: [nil | integer()],
                    isr: [nil | integer()]
                  }
                ]
              }
            ],
            correlation_id: integer()
          }
    import(Elixir.Kayrock.Deserialize)
    @doc "Returns the Kafka API key for this API"
    @spec api_key :: integer
    def(api_key) do
      Kayrock.KafkaSchemaMetadata.api_key(:metadata)
    end

    @doc "Returns the API version (#{@vsn}) implemented by this module"
    @spec api_vsn :: integer
    def(api_vsn) do
      0
    end

    @doc "Returns the schema of this message\n\nSee [above](#).\n"
    @spec schema :: term
    def(schema) do
      [
        brokers: {:array, [node_id: :int32, host: :string, port: :int32]},
        topic_metadata:
          {:array,
           [
             error_code: :int16,
             topic: :string,
             partition_metadata:
               {:array,
                [
                  error_code: :int16,
                  partition: :int32,
                  leader: :int32,
                  replicas: {:array, :int32},
                  isr: {:array, :int32}
                ]}
           ]}
      ]
    end

    @doc "Deserialize data for this version of this API\n"
    @spec deserialize(binary) :: {t(), binary}
    def(deserialize(data)) do
      <<correlation_id::32-signed, rest::binary>> = data
      deserialize_field(:root, :brokers, %__MODULE__{correlation_id: correlation_id}, rest)
    end

    defp(deserialize_field(:brokers, :node_id, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:brokers, :host, Map.put(acc, :node_id, val), rest)
    end

    defp(deserialize_field(:brokers, :host, acc, data)) do
      {val, rest} = deserialize(:string, data)
      deserialize_field(:brokers, :port, Map.put(acc, :host, val), rest)
    end

    defp(deserialize_field(:brokers, :port, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:brokers, nil, Map.put(acc, :port, val), rest)
    end

    defp(deserialize_field(:root, :brokers, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:brokers, :node_id, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(:root, :topic_metadata, Map.put(acc, :brokers, Enum.reverse(vals)), rest)
    end

    defp(deserialize_field(:topic_metadata, :error_code, acc, data)) do
      {val, rest} = deserialize(:int16, data)
      deserialize_field(:topic_metadata, :topic, Map.put(acc, :error_code, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :topic, acc, data)) do
      {val, rest} = deserialize(:string, data)
      deserialize_field(:topic_metadata, :partition_metadata, Map.put(acc, :topic, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :error_code, acc, data)) do
      {val, rest} = deserialize(:int16, data)
      deserialize_field(:partition_metadata, :partition, Map.put(acc, :error_code, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :partition, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:partition_metadata, :leader, Map.put(acc, :partition, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :leader, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:partition_metadata, :replicas, Map.put(acc, :leader, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :replicas, acc, data)) do
      {val, rest} = deserialize_array(:int32, data)

      deserialize_field(
        :partition_metadata,
        :isr,
        Map.put(acc, :replicas, Enum.reverse(val)),
        rest
      )
    end

    defp(deserialize_field(:partition_metadata, :isr, acc, data)) do
      {val, rest} = deserialize_array(:int32, data)
      deserialize_field(:partition_metadata, nil, Map.put(acc, :isr, Enum.reverse(val)), rest)
    end

    defp(deserialize_field(:topic_metadata, :partition_metadata, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:partition_metadata, :error_code, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(
        :topic_metadata,
        nil,
        Map.put(acc, :partition_metadata, Enum.reverse(vals)),
        rest
      )
    end

    defp(deserialize_field(:root, :topic_metadata, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:topic_metadata, :error_code, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(:root, nil, Map.put(acc, :topic_metadata, Enum.reverse(vals)), rest)
    end

    defp(deserialize_field(_, nil, acc, rest)) do
      {acc, rest}
    end
  end

  defmodule(V1.Response) do
    @vsn 1
    @api :metadata
    @schema brokers:
              {:array, [node_id: :int32, host: :string, port: :int32, rack: :nullable_string]},
            controller_id: :int32,
            topic_metadata:
              {:array,
               [
                 error_code: :int16,
                 topic: :string,
                 is_internal: :boolean,
                 partition_metadata:
                   {:array,
                    [
                      error_code: :int16,
                      partition: :int32,
                      leader: :int32,
                      replicas: {:array, :int32},
                      isr: {:array, :int32}
                    ]}
               ]}
    @moduledoc "Kayrock-generated response struct for Kafka `#{@api}` v#{@vsn} API\nmessages\n\nThe schema of this API is\n```\n#{
                 inspect(@schema, pretty: true)
               }\n```\n"
    _ = " THIS CODE IS GENERATED BY KAYROCK"
    defstruct(brokers: [], controller_id: nil, topic_metadata: [], correlation_id: nil)
    @typedoc "Response struct for the Kafka `#{@api}` API v#{@vsn}\n"
    @type t :: %__MODULE__{
            brokers: [
              %{
                node_id: nil | integer(),
                host: nil | binary(),
                port: nil | integer(),
                rack: nil | binary()
              }
            ],
            controller_id: nil | integer(),
            topic_metadata: [
              %{
                error_code: nil | integer(),
                topic: nil | binary(),
                is_internal: nil | integer(),
                partition_metadata: [
                  %{
                    error_code: nil | integer(),
                    partition: nil | integer(),
                    leader: nil | integer(),
                    replicas: [nil | integer()],
                    isr: [nil | integer()]
                  }
                ]
              }
            ],
            correlation_id: integer()
          }
    import(Elixir.Kayrock.Deserialize)
    @doc "Returns the Kafka API key for this API"
    @spec api_key :: integer
    def(api_key) do
      Kayrock.KafkaSchemaMetadata.api_key(:metadata)
    end

    @doc "Returns the API version (#{@vsn}) implemented by this module"
    @spec api_vsn :: integer
    def(api_vsn) do
      1
    end

    @doc "Returns the schema of this message\n\nSee [above](#).\n"
    @spec schema :: term
    def(schema) do
      [
        brokers: {:array, [node_id: :int32, host: :string, port: :int32, rack: :nullable_string]},
        controller_id: :int32,
        topic_metadata:
          {:array,
           [
             error_code: :int16,
             topic: :string,
             is_internal: :boolean,
             partition_metadata:
               {:array,
                [
                  error_code: :int16,
                  partition: :int32,
                  leader: :int32,
                  replicas: {:array, :int32},
                  isr: {:array, :int32}
                ]}
           ]}
      ]
    end

    @doc "Deserialize data for this version of this API\n"
    @spec deserialize(binary) :: {t(), binary}
    def(deserialize(data)) do
      <<correlation_id::32-signed, rest::binary>> = data
      deserialize_field(:root, :brokers, %__MODULE__{correlation_id: correlation_id}, rest)
    end

    defp(deserialize_field(:brokers, :node_id, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:brokers, :host, Map.put(acc, :node_id, val), rest)
    end

    defp(deserialize_field(:brokers, :host, acc, data)) do
      {val, rest} = deserialize(:string, data)
      deserialize_field(:brokers, :port, Map.put(acc, :host, val), rest)
    end

    defp(deserialize_field(:brokers, :port, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:brokers, :rack, Map.put(acc, :port, val), rest)
    end

    defp(deserialize_field(:brokers, :rack, acc, data)) do
      {val, rest} = deserialize(:nullable_string, data)
      deserialize_field(:brokers, nil, Map.put(acc, :rack, val), rest)
    end

    defp(deserialize_field(:root, :brokers, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:brokers, :node_id, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(:root, :controller_id, Map.put(acc, :brokers, Enum.reverse(vals)), rest)
    end

    defp(deserialize_field(:root, :controller_id, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:root, :topic_metadata, Map.put(acc, :controller_id, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :error_code, acc, data)) do
      {val, rest} = deserialize(:int16, data)
      deserialize_field(:topic_metadata, :topic, Map.put(acc, :error_code, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :topic, acc, data)) do
      {val, rest} = deserialize(:string, data)
      deserialize_field(:topic_metadata, :is_internal, Map.put(acc, :topic, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :is_internal, acc, data)) do
      {val, rest} = deserialize(:boolean, data)

      deserialize_field(
        :topic_metadata,
        :partition_metadata,
        Map.put(acc, :is_internal, val),
        rest
      )
    end

    defp(deserialize_field(:partition_metadata, :error_code, acc, data)) do
      {val, rest} = deserialize(:int16, data)
      deserialize_field(:partition_metadata, :partition, Map.put(acc, :error_code, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :partition, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:partition_metadata, :leader, Map.put(acc, :partition, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :leader, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:partition_metadata, :replicas, Map.put(acc, :leader, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :replicas, acc, data)) do
      {val, rest} = deserialize_array(:int32, data)

      deserialize_field(
        :partition_metadata,
        :isr,
        Map.put(acc, :replicas, Enum.reverse(val)),
        rest
      )
    end

    defp(deserialize_field(:partition_metadata, :isr, acc, data)) do
      {val, rest} = deserialize_array(:int32, data)
      deserialize_field(:partition_metadata, nil, Map.put(acc, :isr, Enum.reverse(val)), rest)
    end

    defp(deserialize_field(:topic_metadata, :partition_metadata, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:partition_metadata, :error_code, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(
        :topic_metadata,
        nil,
        Map.put(acc, :partition_metadata, Enum.reverse(vals)),
        rest
      )
    end

    defp(deserialize_field(:root, :topic_metadata, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:topic_metadata, :error_code, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(:root, nil, Map.put(acc, :topic_metadata, Enum.reverse(vals)), rest)
    end

    defp(deserialize_field(_, nil, acc, rest)) do
      {acc, rest}
    end
  end

  defmodule(V2.Response) do
    @vsn 2
    @api :metadata
    @schema brokers:
              {:array, [node_id: :int32, host: :string, port: :int32, rack: :nullable_string]},
            cluster_id: :nullable_string,
            controller_id: :int32,
            topic_metadata:
              {:array,
               [
                 error_code: :int16,
                 topic: :string,
                 is_internal: :boolean,
                 partition_metadata:
                   {:array,
                    [
                      error_code: :int16,
                      partition: :int32,
                      leader: :int32,
                      replicas: {:array, :int32},
                      isr: {:array, :int32}
                    ]}
               ]}
    @moduledoc "Kayrock-generated response struct for Kafka `#{@api}` v#{@vsn} API\nmessages\n\nThe schema of this API is\n```\n#{
                 inspect(@schema, pretty: true)
               }\n```\n"
    _ = " THIS CODE IS GENERATED BY KAYROCK"

    defstruct(
      brokers: [],
      cluster_id: nil,
      controller_id: nil,
      topic_metadata: [],
      correlation_id: nil
    )

    @typedoc "Response struct for the Kafka `#{@api}` API v#{@vsn}\n"
    @type t :: %__MODULE__{
            brokers: [
              %{
                node_id: nil | integer(),
                host: nil | binary(),
                port: nil | integer(),
                rack: nil | binary()
              }
            ],
            cluster_id: nil | binary(),
            controller_id: nil | integer(),
            topic_metadata: [
              %{
                error_code: nil | integer(),
                topic: nil | binary(),
                is_internal: nil | integer(),
                partition_metadata: [
                  %{
                    error_code: nil | integer(),
                    partition: nil | integer(),
                    leader: nil | integer(),
                    replicas: [nil | integer()],
                    isr: [nil | integer()]
                  }
                ]
              }
            ],
            correlation_id: integer()
          }
    import(Elixir.Kayrock.Deserialize)
    @doc "Returns the Kafka API key for this API"
    @spec api_key :: integer
    def(api_key) do
      Kayrock.KafkaSchemaMetadata.api_key(:metadata)
    end

    @doc "Returns the API version (#{@vsn}) implemented by this module"
    @spec api_vsn :: integer
    def(api_vsn) do
      2
    end

    @doc "Returns the schema of this message\n\nSee [above](#).\n"
    @spec schema :: term
    def(schema) do
      [
        brokers: {:array, [node_id: :int32, host: :string, port: :int32, rack: :nullable_string]},
        cluster_id: :nullable_string,
        controller_id: :int32,
        topic_metadata:
          {:array,
           [
             error_code: :int16,
             topic: :string,
             is_internal: :boolean,
             partition_metadata:
               {:array,
                [
                  error_code: :int16,
                  partition: :int32,
                  leader: :int32,
                  replicas: {:array, :int32},
                  isr: {:array, :int32}
                ]}
           ]}
      ]
    end

    @doc "Deserialize data for this version of this API\n"
    @spec deserialize(binary) :: {t(), binary}
    def(deserialize(data)) do
      <<correlation_id::32-signed, rest::binary>> = data
      deserialize_field(:root, :brokers, %__MODULE__{correlation_id: correlation_id}, rest)
    end

    defp(deserialize_field(:brokers, :node_id, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:brokers, :host, Map.put(acc, :node_id, val), rest)
    end

    defp(deserialize_field(:brokers, :host, acc, data)) do
      {val, rest} = deserialize(:string, data)
      deserialize_field(:brokers, :port, Map.put(acc, :host, val), rest)
    end

    defp(deserialize_field(:brokers, :port, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:brokers, :rack, Map.put(acc, :port, val), rest)
    end

    defp(deserialize_field(:brokers, :rack, acc, data)) do
      {val, rest} = deserialize(:nullable_string, data)
      deserialize_field(:brokers, nil, Map.put(acc, :rack, val), rest)
    end

    defp(deserialize_field(:root, :brokers, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:brokers, :node_id, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(:root, :cluster_id, Map.put(acc, :brokers, Enum.reverse(vals)), rest)
    end

    defp(deserialize_field(:root, :cluster_id, acc, data)) do
      {val, rest} = deserialize(:nullable_string, data)
      deserialize_field(:root, :controller_id, Map.put(acc, :cluster_id, val), rest)
    end

    defp(deserialize_field(:root, :controller_id, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:root, :topic_metadata, Map.put(acc, :controller_id, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :error_code, acc, data)) do
      {val, rest} = deserialize(:int16, data)
      deserialize_field(:topic_metadata, :topic, Map.put(acc, :error_code, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :topic, acc, data)) do
      {val, rest} = deserialize(:string, data)
      deserialize_field(:topic_metadata, :is_internal, Map.put(acc, :topic, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :is_internal, acc, data)) do
      {val, rest} = deserialize(:boolean, data)

      deserialize_field(
        :topic_metadata,
        :partition_metadata,
        Map.put(acc, :is_internal, val),
        rest
      )
    end

    defp(deserialize_field(:partition_metadata, :error_code, acc, data)) do
      {val, rest} = deserialize(:int16, data)
      deserialize_field(:partition_metadata, :partition, Map.put(acc, :error_code, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :partition, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:partition_metadata, :leader, Map.put(acc, :partition, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :leader, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:partition_metadata, :replicas, Map.put(acc, :leader, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :replicas, acc, data)) do
      {val, rest} = deserialize_array(:int32, data)

      deserialize_field(
        :partition_metadata,
        :isr,
        Map.put(acc, :replicas, Enum.reverse(val)),
        rest
      )
    end

    defp(deserialize_field(:partition_metadata, :isr, acc, data)) do
      {val, rest} = deserialize_array(:int32, data)
      deserialize_field(:partition_metadata, nil, Map.put(acc, :isr, Enum.reverse(val)), rest)
    end

    defp(deserialize_field(:topic_metadata, :partition_metadata, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:partition_metadata, :error_code, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(
        :topic_metadata,
        nil,
        Map.put(acc, :partition_metadata, Enum.reverse(vals)),
        rest
      )
    end

    defp(deserialize_field(:root, :topic_metadata, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:topic_metadata, :error_code, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(:root, nil, Map.put(acc, :topic_metadata, Enum.reverse(vals)), rest)
    end

    defp(deserialize_field(_, nil, acc, rest)) do
      {acc, rest}
    end
  end

  defmodule(V3.Response) do
    @vsn 3
    @api :metadata
    @schema throttle_time_ms: :int32,
            brokers:
              {:array, [node_id: :int32, host: :string, port: :int32, rack: :nullable_string]},
            cluster_id: :nullable_string,
            controller_id: :int32,
            topic_metadata:
              {:array,
               [
                 error_code: :int16,
                 topic: :string,
                 is_internal: :boolean,
                 partition_metadata:
                   {:array,
                    [
                      error_code: :int16,
                      partition: :int32,
                      leader: :int32,
                      replicas: {:array, :int32},
                      isr: {:array, :int32}
                    ]}
               ]}
    @moduledoc "Kayrock-generated response struct for Kafka `#{@api}` v#{@vsn} API\nmessages\n\nThe schema of this API is\n```\n#{
                 inspect(@schema, pretty: true)
               }\n```\n"
    _ = " THIS CODE IS GENERATED BY KAYROCK"

    defstruct(
      throttle_time_ms: nil,
      brokers: [],
      cluster_id: nil,
      controller_id: nil,
      topic_metadata: [],
      correlation_id: nil
    )

    @typedoc "Response struct for the Kafka `#{@api}` API v#{@vsn}\n"
    @type t :: %__MODULE__{
            throttle_time_ms: nil | integer(),
            brokers: [
              %{
                node_id: nil | integer(),
                host: nil | binary(),
                port: nil | integer(),
                rack: nil | binary()
              }
            ],
            cluster_id: nil | binary(),
            controller_id: nil | integer(),
            topic_metadata: [
              %{
                error_code: nil | integer(),
                topic: nil | binary(),
                is_internal: nil | integer(),
                partition_metadata: [
                  %{
                    error_code: nil | integer(),
                    partition: nil | integer(),
                    leader: nil | integer(),
                    replicas: [nil | integer()],
                    isr: [nil | integer()]
                  }
                ]
              }
            ],
            correlation_id: integer()
          }
    import(Elixir.Kayrock.Deserialize)
    @doc "Returns the Kafka API key for this API"
    @spec api_key :: integer
    def(api_key) do
      Kayrock.KafkaSchemaMetadata.api_key(:metadata)
    end

    @doc "Returns the API version (#{@vsn}) implemented by this module"
    @spec api_vsn :: integer
    def(api_vsn) do
      3
    end

    @doc "Returns the schema of this message\n\nSee [above](#).\n"
    @spec schema :: term
    def(schema) do
      [
        throttle_time_ms: :int32,
        brokers: {:array, [node_id: :int32, host: :string, port: :int32, rack: :nullable_string]},
        cluster_id: :nullable_string,
        controller_id: :int32,
        topic_metadata:
          {:array,
           [
             error_code: :int16,
             topic: :string,
             is_internal: :boolean,
             partition_metadata:
               {:array,
                [
                  error_code: :int16,
                  partition: :int32,
                  leader: :int32,
                  replicas: {:array, :int32},
                  isr: {:array, :int32}
                ]}
           ]}
      ]
    end

    @doc "Deserialize data for this version of this API\n"
    @spec deserialize(binary) :: {t(), binary}
    def(deserialize(data)) do
      <<correlation_id::32-signed, rest::binary>> = data

      deserialize_field(
        :root,
        :throttle_time_ms,
        %__MODULE__{correlation_id: correlation_id},
        rest
      )
    end

    defp(deserialize_field(:root, :throttle_time_ms, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:root, :brokers, Map.put(acc, :throttle_time_ms, val), rest)
    end

    defp(deserialize_field(:brokers, :node_id, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:brokers, :host, Map.put(acc, :node_id, val), rest)
    end

    defp(deserialize_field(:brokers, :host, acc, data)) do
      {val, rest} = deserialize(:string, data)
      deserialize_field(:brokers, :port, Map.put(acc, :host, val), rest)
    end

    defp(deserialize_field(:brokers, :port, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:brokers, :rack, Map.put(acc, :port, val), rest)
    end

    defp(deserialize_field(:brokers, :rack, acc, data)) do
      {val, rest} = deserialize(:nullable_string, data)
      deserialize_field(:brokers, nil, Map.put(acc, :rack, val), rest)
    end

    defp(deserialize_field(:root, :brokers, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:brokers, :node_id, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(:root, :cluster_id, Map.put(acc, :brokers, Enum.reverse(vals)), rest)
    end

    defp(deserialize_field(:root, :cluster_id, acc, data)) do
      {val, rest} = deserialize(:nullable_string, data)
      deserialize_field(:root, :controller_id, Map.put(acc, :cluster_id, val), rest)
    end

    defp(deserialize_field(:root, :controller_id, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:root, :topic_metadata, Map.put(acc, :controller_id, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :error_code, acc, data)) do
      {val, rest} = deserialize(:int16, data)
      deserialize_field(:topic_metadata, :topic, Map.put(acc, :error_code, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :topic, acc, data)) do
      {val, rest} = deserialize(:string, data)
      deserialize_field(:topic_metadata, :is_internal, Map.put(acc, :topic, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :is_internal, acc, data)) do
      {val, rest} = deserialize(:boolean, data)

      deserialize_field(
        :topic_metadata,
        :partition_metadata,
        Map.put(acc, :is_internal, val),
        rest
      )
    end

    defp(deserialize_field(:partition_metadata, :error_code, acc, data)) do
      {val, rest} = deserialize(:int16, data)
      deserialize_field(:partition_metadata, :partition, Map.put(acc, :error_code, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :partition, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:partition_metadata, :leader, Map.put(acc, :partition, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :leader, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:partition_metadata, :replicas, Map.put(acc, :leader, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :replicas, acc, data)) do
      {val, rest} = deserialize_array(:int32, data)

      deserialize_field(
        :partition_metadata,
        :isr,
        Map.put(acc, :replicas, Enum.reverse(val)),
        rest
      )
    end

    defp(deserialize_field(:partition_metadata, :isr, acc, data)) do
      {val, rest} = deserialize_array(:int32, data)
      deserialize_field(:partition_metadata, nil, Map.put(acc, :isr, Enum.reverse(val)), rest)
    end

    defp(deserialize_field(:topic_metadata, :partition_metadata, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:partition_metadata, :error_code, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(
        :topic_metadata,
        nil,
        Map.put(acc, :partition_metadata, Enum.reverse(vals)),
        rest
      )
    end

    defp(deserialize_field(:root, :topic_metadata, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:topic_metadata, :error_code, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(:root, nil, Map.put(acc, :topic_metadata, Enum.reverse(vals)), rest)
    end

    defp(deserialize_field(_, nil, acc, rest)) do
      {acc, rest}
    end
  end

  defmodule(V4.Response) do
    @vsn 4
    @api :metadata
    @schema throttle_time_ms: :int32,
            brokers:
              {:array, [node_id: :int32, host: :string, port: :int32, rack: :nullable_string]},
            cluster_id: :nullable_string,
            controller_id: :int32,
            topic_metadata:
              {:array,
               [
                 error_code: :int16,
                 topic: :string,
                 is_internal: :boolean,
                 partition_metadata:
                   {:array,
                    [
                      error_code: :int16,
                      partition: :int32,
                      leader: :int32,
                      replicas: {:array, :int32},
                      isr: {:array, :int32}
                    ]}
               ]}
    @moduledoc "Kayrock-generated response struct for Kafka `#{@api}` v#{@vsn} API\nmessages\n\nThe schema of this API is\n```\n#{
                 inspect(@schema, pretty: true)
               }\n```\n"
    _ = " THIS CODE IS GENERATED BY KAYROCK"

    defstruct(
      throttle_time_ms: nil,
      brokers: [],
      cluster_id: nil,
      controller_id: nil,
      topic_metadata: [],
      correlation_id: nil
    )

    @typedoc "Response struct for the Kafka `#{@api}` API v#{@vsn}\n"
    @type t :: %__MODULE__{
            throttle_time_ms: nil | integer(),
            brokers: [
              %{
                node_id: nil | integer(),
                host: nil | binary(),
                port: nil | integer(),
                rack: nil | binary()
              }
            ],
            cluster_id: nil | binary(),
            controller_id: nil | integer(),
            topic_metadata: [
              %{
                error_code: nil | integer(),
                topic: nil | binary(),
                is_internal: nil | integer(),
                partition_metadata: [
                  %{
                    error_code: nil | integer(),
                    partition: nil | integer(),
                    leader: nil | integer(),
                    replicas: [nil | integer()],
                    isr: [nil | integer()]
                  }
                ]
              }
            ],
            correlation_id: integer()
          }
    import(Elixir.Kayrock.Deserialize)
    @doc "Returns the Kafka API key for this API"
    @spec api_key :: integer
    def(api_key) do
      Kayrock.KafkaSchemaMetadata.api_key(:metadata)
    end

    @doc "Returns the API version (#{@vsn}) implemented by this module"
    @spec api_vsn :: integer
    def(api_vsn) do
      4
    end

    @doc "Returns the schema of this message\n\nSee [above](#).\n"
    @spec schema :: term
    def(schema) do
      [
        throttle_time_ms: :int32,
        brokers: {:array, [node_id: :int32, host: :string, port: :int32, rack: :nullable_string]},
        cluster_id: :nullable_string,
        controller_id: :int32,
        topic_metadata:
          {:array,
           [
             error_code: :int16,
             topic: :string,
             is_internal: :boolean,
             partition_metadata:
               {:array,
                [
                  error_code: :int16,
                  partition: :int32,
                  leader: :int32,
                  replicas: {:array, :int32},
                  isr: {:array, :int32}
                ]}
           ]}
      ]
    end

    @doc "Deserialize data for this version of this API\n"
    @spec deserialize(binary) :: {t(), binary}
    def(deserialize(data)) do
      <<correlation_id::32-signed, rest::binary>> = data

      deserialize_field(
        :root,
        :throttle_time_ms,
        %__MODULE__{correlation_id: correlation_id},
        rest
      )
    end

    defp(deserialize_field(:root, :throttle_time_ms, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:root, :brokers, Map.put(acc, :throttle_time_ms, val), rest)
    end

    defp(deserialize_field(:brokers, :node_id, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:brokers, :host, Map.put(acc, :node_id, val), rest)
    end

    defp(deserialize_field(:brokers, :host, acc, data)) do
      {val, rest} = deserialize(:string, data)
      deserialize_field(:brokers, :port, Map.put(acc, :host, val), rest)
    end

    defp(deserialize_field(:brokers, :port, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:brokers, :rack, Map.put(acc, :port, val), rest)
    end

    defp(deserialize_field(:brokers, :rack, acc, data)) do
      {val, rest} = deserialize(:nullable_string, data)
      deserialize_field(:brokers, nil, Map.put(acc, :rack, val), rest)
    end

    defp(deserialize_field(:root, :brokers, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:brokers, :node_id, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(:root, :cluster_id, Map.put(acc, :brokers, Enum.reverse(vals)), rest)
    end

    defp(deserialize_field(:root, :cluster_id, acc, data)) do
      {val, rest} = deserialize(:nullable_string, data)
      deserialize_field(:root, :controller_id, Map.put(acc, :cluster_id, val), rest)
    end

    defp(deserialize_field(:root, :controller_id, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:root, :topic_metadata, Map.put(acc, :controller_id, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :error_code, acc, data)) do
      {val, rest} = deserialize(:int16, data)
      deserialize_field(:topic_metadata, :topic, Map.put(acc, :error_code, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :topic, acc, data)) do
      {val, rest} = deserialize(:string, data)
      deserialize_field(:topic_metadata, :is_internal, Map.put(acc, :topic, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :is_internal, acc, data)) do
      {val, rest} = deserialize(:boolean, data)

      deserialize_field(
        :topic_metadata,
        :partition_metadata,
        Map.put(acc, :is_internal, val),
        rest
      )
    end

    defp(deserialize_field(:partition_metadata, :error_code, acc, data)) do
      {val, rest} = deserialize(:int16, data)
      deserialize_field(:partition_metadata, :partition, Map.put(acc, :error_code, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :partition, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:partition_metadata, :leader, Map.put(acc, :partition, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :leader, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:partition_metadata, :replicas, Map.put(acc, :leader, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :replicas, acc, data)) do
      {val, rest} = deserialize_array(:int32, data)

      deserialize_field(
        :partition_metadata,
        :isr,
        Map.put(acc, :replicas, Enum.reverse(val)),
        rest
      )
    end

    defp(deserialize_field(:partition_metadata, :isr, acc, data)) do
      {val, rest} = deserialize_array(:int32, data)
      deserialize_field(:partition_metadata, nil, Map.put(acc, :isr, Enum.reverse(val)), rest)
    end

    defp(deserialize_field(:topic_metadata, :partition_metadata, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:partition_metadata, :error_code, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(
        :topic_metadata,
        nil,
        Map.put(acc, :partition_metadata, Enum.reverse(vals)),
        rest
      )
    end

    defp(deserialize_field(:root, :topic_metadata, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:topic_metadata, :error_code, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(:root, nil, Map.put(acc, :topic_metadata, Enum.reverse(vals)), rest)
    end

    defp(deserialize_field(_, nil, acc, rest)) do
      {acc, rest}
    end
  end

  defmodule(V5.Response) do
    @vsn 5
    @api :metadata
    @schema throttle_time_ms: :int32,
            brokers:
              {:array, [node_id: :int32, host: :string, port: :int32, rack: :nullable_string]},
            cluster_id: :nullable_string,
            controller_id: :int32,
            topic_metadata:
              {:array,
               [
                 error_code: :int16,
                 topic: :string,
                 is_internal: :boolean,
                 partition_metadata:
                   {:array,
                    [
                      error_code: :int16,
                      partition: :int32,
                      leader: :int32,
                      replicas: {:array, :int32},
                      isr: {:array, :int32},
                      offline_replicas: {:array, :int32}
                    ]}
               ]}
    @moduledoc "Kayrock-generated response struct for Kafka `#{@api}` v#{@vsn} API\nmessages\n\nThe schema of this API is\n```\n#{
                 inspect(@schema, pretty: true)
               }\n```\n"
    _ = " THIS CODE IS GENERATED BY KAYROCK"

    defstruct(
      throttle_time_ms: nil,
      brokers: [],
      cluster_id: nil,
      controller_id: nil,
      topic_metadata: [],
      correlation_id: nil
    )

    @typedoc "Response struct for the Kafka `#{@api}` API v#{@vsn}\n"
    @type t :: %__MODULE__{
            throttle_time_ms: nil | integer(),
            brokers: [
              %{
                node_id: nil | integer(),
                host: nil | binary(),
                port: nil | integer(),
                rack: nil | binary()
              }
            ],
            cluster_id: nil | binary(),
            controller_id: nil | integer(),
            topic_metadata: [
              %{
                error_code: nil | integer(),
                topic: nil | binary(),
                is_internal: nil | integer(),
                partition_metadata: [
                  %{
                    error_code: nil | integer(),
                    partition: nil | integer(),
                    leader: nil | integer(),
                    replicas: [nil | integer()],
                    isr: [nil | integer()],
                    offline_replicas: [nil | integer()]
                  }
                ]
              }
            ],
            correlation_id: integer()
          }
    import(Elixir.Kayrock.Deserialize)
    @doc "Returns the Kafka API key for this API"
    @spec api_key :: integer
    def(api_key) do
      Kayrock.KafkaSchemaMetadata.api_key(:metadata)
    end

    @doc "Returns the API version (#{@vsn}) implemented by this module"
    @spec api_vsn :: integer
    def(api_vsn) do
      5
    end

    @doc "Returns the schema of this message\n\nSee [above](#).\n"
    @spec schema :: term
    def(schema) do
      [
        throttle_time_ms: :int32,
        brokers: {:array, [node_id: :int32, host: :string, port: :int32, rack: :nullable_string]},
        cluster_id: :nullable_string,
        controller_id: :int32,
        topic_metadata:
          {:array,
           [
             error_code: :int16,
             topic: :string,
             is_internal: :boolean,
             partition_metadata:
               {:array,
                [
                  error_code: :int16,
                  partition: :int32,
                  leader: :int32,
                  replicas: {:array, :int32},
                  isr: {:array, :int32},
                  offline_replicas: {:array, :int32}
                ]}
           ]}
      ]
    end

    @doc "Deserialize data for this version of this API\n"
    @spec deserialize(binary) :: {t(), binary}
    def(deserialize(data)) do
      <<correlation_id::32-signed, rest::binary>> = data

      deserialize_field(
        :root,
        :throttle_time_ms,
        %__MODULE__{correlation_id: correlation_id},
        rest
      )
    end

    defp(deserialize_field(:root, :throttle_time_ms, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:root, :brokers, Map.put(acc, :throttle_time_ms, val), rest)
    end

    defp(deserialize_field(:brokers, :node_id, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:brokers, :host, Map.put(acc, :node_id, val), rest)
    end

    defp(deserialize_field(:brokers, :host, acc, data)) do
      {val, rest} = deserialize(:string, data)
      deserialize_field(:brokers, :port, Map.put(acc, :host, val), rest)
    end

    defp(deserialize_field(:brokers, :port, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:brokers, :rack, Map.put(acc, :port, val), rest)
    end

    defp(deserialize_field(:brokers, :rack, acc, data)) do
      {val, rest} = deserialize(:nullable_string, data)
      deserialize_field(:brokers, nil, Map.put(acc, :rack, val), rest)
    end

    defp(deserialize_field(:root, :brokers, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:brokers, :node_id, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(:root, :cluster_id, Map.put(acc, :brokers, Enum.reverse(vals)), rest)
    end

    defp(deserialize_field(:root, :cluster_id, acc, data)) do
      {val, rest} = deserialize(:nullable_string, data)
      deserialize_field(:root, :controller_id, Map.put(acc, :cluster_id, val), rest)
    end

    defp(deserialize_field(:root, :controller_id, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:root, :topic_metadata, Map.put(acc, :controller_id, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :error_code, acc, data)) do
      {val, rest} = deserialize(:int16, data)
      deserialize_field(:topic_metadata, :topic, Map.put(acc, :error_code, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :topic, acc, data)) do
      {val, rest} = deserialize(:string, data)
      deserialize_field(:topic_metadata, :is_internal, Map.put(acc, :topic, val), rest)
    end

    defp(deserialize_field(:topic_metadata, :is_internal, acc, data)) do
      {val, rest} = deserialize(:boolean, data)

      deserialize_field(
        :topic_metadata,
        :partition_metadata,
        Map.put(acc, :is_internal, val),
        rest
      )
    end

    defp(deserialize_field(:partition_metadata, :error_code, acc, data)) do
      {val, rest} = deserialize(:int16, data)
      deserialize_field(:partition_metadata, :partition, Map.put(acc, :error_code, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :partition, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:partition_metadata, :leader, Map.put(acc, :partition, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :leader, acc, data)) do
      {val, rest} = deserialize(:int32, data)
      deserialize_field(:partition_metadata, :replicas, Map.put(acc, :leader, val), rest)
    end

    defp(deserialize_field(:partition_metadata, :replicas, acc, data)) do
      {val, rest} = deserialize_array(:int32, data)

      deserialize_field(
        :partition_metadata,
        :isr,
        Map.put(acc, :replicas, Enum.reverse(val)),
        rest
      )
    end

    defp(deserialize_field(:partition_metadata, :isr, acc, data)) do
      {val, rest} = deserialize_array(:int32, data)

      deserialize_field(
        :partition_metadata,
        :offline_replicas,
        Map.put(acc, :isr, Enum.reverse(val)),
        rest
      )
    end

    defp(deserialize_field(:partition_metadata, :offline_replicas, acc, data)) do
      {val, rest} = deserialize_array(:int32, data)

      deserialize_field(
        :partition_metadata,
        nil,
        Map.put(acc, :offline_replicas, Enum.reverse(val)),
        rest
      )
    end

    defp(deserialize_field(:topic_metadata, :partition_metadata, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:partition_metadata, :error_code, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(
        :topic_metadata,
        nil,
        Map.put(acc, :partition_metadata, Enum.reverse(vals)),
        rest
      )
    end

    defp(deserialize_field(:root, :topic_metadata, acc, data)) do
      <<num_elements::32-signed, rest::binary>> = data

      {vals, rest} =
        if(num_elements > 0) do
          Enum.reduce(1..num_elements, {[], rest}, fn _ix, {acc, d} ->
            {val, r} = deserialize_field(:topic_metadata, :error_code, %{}, d)
            {[val | acc], r}
          end)
        else
          {[], rest}
        end

      deserialize_field(:root, nil, Map.put(acc, :topic_metadata, Enum.reverse(vals)), rest)
    end

    defp(deserialize_field(_, nil, acc, rest)) do
      {acc, rest}
    end
  end

  (
    @doc "Deserializes raw wire data for this API with the given version"
    @spec deserialize(integer, binary) :: {response_t, binary}
  )

  def(deserialize(0, data)) do
    V0.Response.deserialize(data)
  end

  def(deserialize(1, data)) do
    V1.Response.deserialize(data)
  end

  def(deserialize(2, data)) do
    V2.Response.deserialize(data)
  end

  def(deserialize(3, data)) do
    V3.Response.deserialize(data)
  end

  def(deserialize(4, data)) do
    V4.Response.deserialize(data)
  end

  def(deserialize(5, data)) do
    V5.Response.deserialize(data)
  end

  (
    @typedoc "Union type for all request structs for this API"
    @type request_t ::
            Kayrock.Metadata.V5.Request.t()
            | Kayrock.Metadata.V4.Request.t()
            | Kayrock.Metadata.V3.Request.t()
            | Kayrock.Metadata.V2.Request.t()
            | Kayrock.Metadata.V1.Request.t()
            | Kayrock.Metadata.V0.Request.t()
  )

  (
    @typedoc "Union type for all response structs for this API"
    @type response_t ::
            Kayrock.Metadata.V5.Response.t()
            | Kayrock.Metadata.V4.Response.t()
            | Kayrock.Metadata.V3.Response.t()
            | Kayrock.Metadata.V2.Response.t()
            | Kayrock.Metadata.V1.Response.t()
            | Kayrock.Metadata.V0.Response.t()
  )

  (
    @doc "Returns the minimum version of this API supported by Kayrock (#{@vmin})"
    @spec min_vsn :: integer
    def(min_vsn) do
      0
    end
  )

  (
    @doc "Returns the maximum version of this API supported by Kayrock (#{@vmax})"
    @spec max_vsn :: integer
    def(max_vsn) do
      5
    end
  )
end