kafka_protocol/messages/
list_client_metrics_resources_request.rs

1//! ListClientMetricsResourcesRequest
2//!
3//! See the schema for this message [here](https://github.com/apache/kafka/blob/trunk/clients/src/main/resources/common/message/ListClientMetricsResourcesRequest.json).
4// WARNING: the items of this module are generated and should not be edited directly
5#![allow(unused)]
6
7use std::borrow::Borrow;
8use std::collections::BTreeMap;
9
10use anyhow::{bail, Result};
11use bytes::Bytes;
12use uuid::Uuid;
13
14use crate::protocol::{
15    buf::{ByteBuf, ByteBufMut},
16    compute_unknown_tagged_fields_size, types, write_unknown_tagged_fields, Decodable, Decoder,
17    Encodable, Encoder, HeaderVersion, Message, StrBytes, VersionRange,
18};
19
20/// Valid versions: 0
21#[non_exhaustive]
22#[derive(Debug, Clone, PartialEq)]
23pub struct ListClientMetricsResourcesRequest {
24    /// Other tagged fields
25    pub unknown_tagged_fields: BTreeMap<i32, Bytes>,
26}
27
28impl ListClientMetricsResourcesRequest {
29    /// Sets unknown_tagged_fields to the passed value.
30    pub fn with_unknown_tagged_fields(mut self, value: BTreeMap<i32, Bytes>) -> Self {
31        self.unknown_tagged_fields = value;
32        self
33    }
34    /// Inserts an entry into unknown_tagged_fields.
35    pub fn with_unknown_tagged_field(mut self, key: i32, value: Bytes) -> Self {
36        self.unknown_tagged_fields.insert(key, value);
37        self
38    }
39}
40
41#[cfg(feature = "client")]
42impl Encodable for ListClientMetricsResourcesRequest {
43    fn encode<B: ByteBufMut>(&self, buf: &mut B, version: i16) -> Result<()> {
44        let num_tagged_fields = self.unknown_tagged_fields.len();
45        if num_tagged_fields > std::u32::MAX as usize {
46            bail!(
47                "Too many tagged fields to encode ({} fields)",
48                num_tagged_fields
49            );
50        }
51        types::UnsignedVarInt.encode(buf, num_tagged_fields as u32)?;
52
53        write_unknown_tagged_fields(buf, 0.., &self.unknown_tagged_fields)?;
54        Ok(())
55    }
56    fn compute_size(&self, version: i16) -> Result<usize> {
57        let mut total_size = 0;
58        let num_tagged_fields = self.unknown_tagged_fields.len();
59        if num_tagged_fields > std::u32::MAX as usize {
60            bail!(
61                "Too many tagged fields to encode ({} fields)",
62                num_tagged_fields
63            );
64        }
65        total_size += types::UnsignedVarInt.compute_size(num_tagged_fields as u32)?;
66
67        total_size += compute_unknown_tagged_fields_size(&self.unknown_tagged_fields)?;
68        Ok(total_size)
69    }
70}
71
72#[cfg(feature = "broker")]
73impl Decodable for ListClientMetricsResourcesRequest {
74    fn decode<B: ByteBuf>(buf: &mut B, version: i16) -> Result<Self> {
75        let mut unknown_tagged_fields = BTreeMap::new();
76        let num_tagged_fields = types::UnsignedVarInt.decode(buf)?;
77        for _ in 0..num_tagged_fields {
78            let tag: u32 = types::UnsignedVarInt.decode(buf)?;
79            let size: u32 = types::UnsignedVarInt.decode(buf)?;
80            let unknown_value = buf.try_get_bytes(size as usize)?;
81            unknown_tagged_fields.insert(tag as i32, unknown_value);
82        }
83        Ok(Self {
84            unknown_tagged_fields,
85        })
86    }
87}
88
89impl Default for ListClientMetricsResourcesRequest {
90    fn default() -> Self {
91        Self {
92            unknown_tagged_fields: BTreeMap::new(),
93        }
94    }
95}
96
97impl Message for ListClientMetricsResourcesRequest {
98    const VERSIONS: VersionRange = VersionRange { min: 0, max: 0 };
99    const DEPRECATED_VERSIONS: Option<VersionRange> = None;
100}
101
102impl HeaderVersion for ListClientMetricsResourcesRequest {
103    fn header_version(version: i16) -> i16 {
104        2
105    }
106}