crabka_protocol/opt/rustwide/workdir/generated/
DescribeClusterRequest.borrowed.rs1use crate::primitives::fixed::{get_bool, get_i8, put_bool, put_i8};
3use crate::tagged_fields::{WriteTaggedFields, read_tagged_fields, tagged_fields_len};
4use crate::{DecodeBorrow, Encode, ProtocolError, UnknownTaggedFields};
5use bytes::BufMut;
6pub const API_KEY: i16 = 60;
7pub const MIN_VERSION: i16 = 0;
8pub const MAX_VERSION: i16 = 2;
9pub const FLEXIBLE_MIN: i16 = 0;
10#[inline]
11fn is_flexible(version: i16) -> bool {
12 version >= FLEXIBLE_MIN
13}
14#[derive(Debug, Clone, PartialEq, Eq)]
15pub struct DescribeClusterRequest {
16 pub include_cluster_authorized_operations: bool,
17 pub endpoint_type: i8,
18 pub include_fenced_brokers: bool,
19 pub unknown_tagged_fields: UnknownTaggedFields,
20}
21impl Default for DescribeClusterRequest {
22 fn default() -> Self {
23 Self {
24 include_cluster_authorized_operations: false,
25 endpoint_type: 1i8,
26 include_fenced_brokers: false,
27 unknown_tagged_fields: Default::default(),
28 }
29 }
30}
31impl DescribeClusterRequest {
32 pub fn to_owned(&self) -> crate::owned::describe_cluster_request::DescribeClusterRequest {
33 crate::owned::describe_cluster_request::DescribeClusterRequest {
34 include_cluster_authorized_operations: (self.include_cluster_authorized_operations),
35 endpoint_type: (self.endpoint_type),
36 include_fenced_brokers: (self.include_fenced_brokers),
37 unknown_tagged_fields: self.unknown_tagged_fields.clone(),
38 }
39 }
40}
41impl Encode for DescribeClusterRequest {
42 fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
43 if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
44 return Err(ProtocolError::UnsupportedVersion {
45 api_key: API_KEY,
46 version,
47 });
48 }
49 let flex = is_flexible(version);
50 if version >= 0 {
51 put_bool(buf, self.include_cluster_authorized_operations);
52 }
53 if version >= 1 {
54 put_i8(buf, self.endpoint_type);
55 }
56 if version >= 2 {
57 put_bool(buf, self.include_fenced_brokers);
58 }
59 if flex {
60 let tagged = WriteTaggedFields::new();
61 tagged.write(buf, &self.unknown_tagged_fields);
62 }
63 Ok(())
64 }
65 fn encoded_len(&self, version: i16) -> usize {
66 let flex = is_flexible(version);
67 let mut n: usize = 0;
68 if version >= 0 {
69 n += 1;
70 }
71 if version >= 1 {
72 n += 1;
73 }
74 if version >= 2 {
75 n += 1;
76 }
77 if flex {
78 let known_pairs: Vec<(u32, usize)> = Vec::new();
79 n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
80 }
81 n
82 }
83}
84impl<'de> DecodeBorrow<'de> for DescribeClusterRequest {
85 fn decode_borrow(buf: &mut &'de [u8], version: i16) -> Result<Self, ProtocolError> {
86 if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
87 return Err(ProtocolError::UnsupportedVersion {
88 api_key: API_KEY,
89 version,
90 });
91 }
92 let flex = is_flexible(version);
93 let mut out = Self::default();
94 if version >= 0 {
95 out.include_cluster_authorized_operations = get_bool(buf)?;
96 }
97 if version >= 1 {
98 out.endpoint_type = get_i8(buf)?;
99 }
100 if version >= 2 {
101 out.include_fenced_brokers = get_bool(buf)?;
102 }
103 if flex {
104 out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| Ok(false))?;
105 }
106 Ok(out)
107 }
108}
109#[cfg(test)]
110impl DescribeClusterRequest {
111 #[must_use]
112 pub fn populated(version: i16) -> Self {
113 let mut m = Self::default();
114 if version >= 0 {
115 m.include_cluster_authorized_operations = true;
116 }
117 if version >= 1 {
118 m.endpoint_type = 1i8;
119 }
120 if version >= 2 {
121 m.include_fenced_brokers = true;
122 }
123 m
124 }
125}