crabka_protocol/opt/rustwide/workdir/generated/
UpdateRaftVoterRequest.owned.rs1use crate::primitives::fixed::{get_i16, get_i32, get_u16, put_i16, put_i32, put_u16};
4use crate::primitives::string_bytes::{
5 compact_nullable_string_len, compact_string_len, get_compact_nullable_string_owned,
6 get_compact_string_owned, get_nullable_string_owned, get_string_owned, nullable_string_len,
7 put_compact_nullable_string, put_compact_string, put_nullable_string, put_string, string_len,
8};
9use crate::tagged_fields::{WriteTaggedFields, read_tagged_fields, tagged_fields_len};
10use crate::{Decode, Encode, ProtocolError, UnknownTaggedFields};
11use bytes::{Buf, BufMut};
12pub const API_KEY: i16 = 82;
13pub const MIN_VERSION: i16 = 0;
14pub const MAX_VERSION: i16 = 0;
15pub const FLEXIBLE_MIN: i16 = 0;
16#[inline]
17fn is_flexible(version: i16) -> bool {
18 version >= FLEXIBLE_MIN
19}
20#[derive(Debug, Clone, PartialEq, Eq, Default)]
21pub struct UpdateRaftVoterRequest {
22 pub cluster_id: Option<String>,
23 pub current_leader_epoch: i32,
24 pub voter_id: i32,
25 pub voter_directory_id: crate::primitives::uuid::Uuid,
26 pub listeners: Vec<Listener>,
27 pub k_raft_version_feature: KRaftVersionFeature,
28 pub unknown_tagged_fields: UnknownTaggedFields,
29}
30impl Encode for UpdateRaftVoterRequest {
31 fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
32 if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
33 return Err(ProtocolError::UnsupportedVersion {
34 api_key: API_KEY,
35 version,
36 });
37 }
38 let flex = is_flexible(version);
39 if version >= 0 {
40 if flex {
41 put_compact_nullable_string(buf, self.cluster_id.as_deref());
42 } else {
43 put_nullable_string(buf, self.cluster_id.as_deref());
44 }
45 }
46 if version >= 0 {
47 put_i32(buf, self.current_leader_epoch);
48 }
49 if version >= 0 {
50 put_i32(buf, self.voter_id);
51 }
52 if version >= 0 {
53 crate::primitives::uuid::put_uuid(buf, self.voter_directory_id);
54 }
55 if version >= 0 {
56 {
57 crate::primitives::array::put_array_len(buf, (self.listeners).len(), flex);
58 for it in &self.listeners {
59 it.encode(buf, version)?;
60 }
61 }
62 }
63 if version >= 0 {
64 self.k_raft_version_feature.encode(buf, version)?;
65 }
66 if flex {
67 let tagged = WriteTaggedFields::new();
68 tagged.write(buf, &self.unknown_tagged_fields);
69 }
70 Ok(())
71 }
72 fn encoded_len(&self, version: i16) -> usize {
73 let flex = is_flexible(version);
74 let mut n: usize = 0;
75 if version >= 0 {
76 n += if flex {
77 compact_nullable_string_len(self.cluster_id.as_deref())
78 } else {
79 nullable_string_len(self.cluster_id.as_deref())
80 };
81 }
82 if version >= 0 {
83 n += 4;
84 }
85 if version >= 0 {
86 n += 4;
87 }
88 if version >= 0 {
89 n += 16;
90 }
91 if version >= 0 {
92 n += {
93 let prefix =
94 crate::primitives::array::array_len_prefix_len((self.listeners).len(), flex);
95 let body: usize = (self.listeners)
96 .iter()
97 .map(|it| it.encoded_len(version))
98 .sum();
99 prefix + body
100 };
101 }
102 if version >= 0 {
103 n += self.k_raft_version_feature.encoded_len(version);
104 }
105 if flex {
106 let known_pairs: Vec<(u32, usize)> = Vec::new();
107 n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
108 }
109 n
110 }
111}
112impl Decode<'_> for UpdateRaftVoterRequest {
113 fn decode<B: Buf>(buf: &mut B, version: i16) -> Result<Self, ProtocolError> {
114 if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
115 return Err(ProtocolError::UnsupportedVersion {
116 api_key: API_KEY,
117 version,
118 });
119 }
120 let flex = is_flexible(version);
121 let mut out = Self::default();
122 if version >= 0 {
123 out.cluster_id = if flex {
124 get_compact_nullable_string_owned(buf)?
125 } else {
126 get_nullable_string_owned(buf)?
127 };
128 }
129 if version >= 0 {
130 out.current_leader_epoch = get_i32(buf)?;
131 }
132 if version >= 0 {
133 out.voter_id = get_i32(buf)?;
134 }
135 if version >= 0 {
136 out.voter_directory_id = crate::primitives::uuid::get_uuid(buf)?;
137 }
138 if version >= 0 {
139 out.listeners = {
140 let n = crate::primitives::array::get_array_len(buf, flex)?;
141 let mut v = Vec::with_capacity(n);
142 for _ in 0..n {
143 v.push(Listener::decode(buf, version)?);
144 }
145 v
146 };
147 }
148 if version >= 0 {
149 out.k_raft_version_feature = KRaftVersionFeature::decode(buf, version)?;
150 }
151 if flex {
152 out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| Ok(false))?;
153 }
154 Ok(out)
155 }
156}
157#[cfg(test)]
158impl UpdateRaftVoterRequest {
159 #[must_use]
160 pub fn populated(version: i16) -> Self {
161 let mut m = Self::default();
162 if version >= 0 {
163 m.cluster_id = Some("x".to_string());
164 }
165 if version >= 0 {
166 m.current_leader_epoch = 1i32;
167 }
168 if version >= 0 {
169 m.voter_id = 1i32;
170 }
171 if version >= 0 {
172 m.voter_directory_id = crate::primitives::uuid::Uuid([1u8; 16]);
173 }
174 if version >= 0 {
175 m.listeners = vec![Listener::populated(version)];
176 }
177 if version >= 0 {
178 m.k_raft_version_feature = KRaftVersionFeature::populated(version);
179 }
180 m
181 }
182}
183#[derive(Debug, Clone, PartialEq, Eq, Default)]
184pub struct Listener {
185 pub name: String,
186 pub host: String,
187 pub port: u16,
188 pub unknown_tagged_fields: UnknownTaggedFields,
189}
190impl Encode for Listener {
191 fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
192 let flex = version >= 0;
193 if version >= 0 {
194 if flex {
195 put_compact_string(buf, &self.name);
196 } else {
197 put_string(buf, &self.name);
198 }
199 }
200 if version >= 0 {
201 if flex {
202 put_compact_string(buf, &self.host);
203 } else {
204 put_string(buf, &self.host);
205 }
206 }
207 if version >= 0 {
208 put_u16(buf, self.port);
209 }
210 if flex {
211 let tagged = WriteTaggedFields::new();
212 tagged.write(buf, &self.unknown_tagged_fields);
213 }
214 Ok(())
215 }
216 fn encoded_len(&self, version: i16) -> usize {
217 let flex = version >= 0;
218 let mut n: usize = 0;
219 if version >= 0 {
220 n += if flex {
221 compact_string_len(&self.name)
222 } else {
223 string_len(&self.name)
224 };
225 }
226 if version >= 0 {
227 n += if flex {
228 compact_string_len(&self.host)
229 } else {
230 string_len(&self.host)
231 };
232 }
233 if version >= 0 {
234 n += 2;
235 }
236 if flex {
237 let known_pairs: Vec<(u32, usize)> = Vec::new();
238 n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
239 }
240 n
241 }
242}
243impl Decode<'_> for Listener {
244 fn decode<B: Buf>(buf: &mut B, version: i16) -> Result<Self, ProtocolError> {
245 let flex = version >= 0;
246 let mut out = Self::default();
247 if version >= 0 {
248 out.name = if flex {
249 get_compact_string_owned(buf)?
250 } else {
251 get_string_owned(buf)?
252 };
253 }
254 if version >= 0 {
255 out.host = if flex {
256 get_compact_string_owned(buf)?
257 } else {
258 get_string_owned(buf)?
259 };
260 }
261 if version >= 0 {
262 out.port = get_u16(buf)?;
263 }
264 if flex {
265 out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| Ok(false))?;
266 }
267 Ok(out)
268 }
269}
270#[cfg(test)]
271impl Listener {
272 #[must_use]
273 pub fn populated(version: i16) -> Self {
274 let mut m = Self::default();
275 if version >= 0 {
276 m.name = "x".to_string();
277 }
278 if version >= 0 {
279 m.host = "x".to_string();
280 }
281 if version >= 0 {
282 m.port = 1u16;
283 }
284 m
285 }
286}
287#[derive(Debug, Clone, PartialEq, Eq, Default)]
288pub struct KRaftVersionFeature {
289 pub min_supported_version: i16,
290 pub max_supported_version: i16,
291 pub unknown_tagged_fields: UnknownTaggedFields,
292}
293impl Encode for KRaftVersionFeature {
294 fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
295 let flex = version >= 0;
296 if version >= 0 {
297 put_i16(buf, self.min_supported_version);
298 }
299 if version >= 0 {
300 put_i16(buf, self.max_supported_version);
301 }
302 if flex {
303 let tagged = WriteTaggedFields::new();
304 tagged.write(buf, &self.unknown_tagged_fields);
305 }
306 Ok(())
307 }
308 fn encoded_len(&self, version: i16) -> usize {
309 let flex = version >= 0;
310 let mut n: usize = 0;
311 if version >= 0 {
312 n += 2;
313 }
314 if version >= 0 {
315 n += 2;
316 }
317 if flex {
318 let known_pairs: Vec<(u32, usize)> = Vec::new();
319 n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
320 }
321 n
322 }
323}
324impl Decode<'_> for KRaftVersionFeature {
325 fn decode<B: Buf>(buf: &mut B, version: i16) -> Result<Self, ProtocolError> {
326 let flex = version >= 0;
327 let mut out = Self::default();
328 if version >= 0 {
329 out.min_supported_version = get_i16(buf)?;
330 }
331 if version >= 0 {
332 out.max_supported_version = get_i16(buf)?;
333 }
334 if flex {
335 out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| Ok(false))?;
336 }
337 Ok(out)
338 }
339}
340#[cfg(test)]
341impl KRaftVersionFeature {
342 #[must_use]
343 pub fn populated(version: i16) -> Self {
344 let mut m = Self::default();
345 if version >= 0 {
346 m.min_supported_version = 1i16;
347 }
348 if version >= 0 {
349 m.max_supported_version = 1i16;
350 }
351 m
352 }
353}
354#[must_use]
357#[allow(unused_comparisons)]
358pub fn default_json(version: i16) -> ::serde_json::Value {
359 let mut obj = ::serde_json::Map::new();
360 obj.insert("clusterId".to_string(), ::serde_json::Value::Null);
361 obj.insert("currentLeaderEpoch".to_string(), ::serde_json::json!(0));
362 obj.insert("voterId".to_string(), ::serde_json::json!(0));
363 obj.insert(
364 "voterDirectoryId".to_string(),
365 ::serde_json::Value::String("AAAAAAAAAAAAAAAAAAAAAA".to_string()),
366 );
367 obj.insert("listeners".to_string(), ::serde_json::Value::Array(vec![]));
368 obj.insert("kRaftVersionFeature".to_string(), {
369 let mut m = ::serde_json::Map::new();
370 m.insert("minSupportedVersion".to_string(), ::serde_json::json!(0));
371 m.insert("maxSupportedVersion".to_string(), ::serde_json::json!(0));
372 ::serde_json::Value::Object(m)
373 });
374 ::serde_json::Value::Object(obj)
375}
376impl crate::ProtocolRequest for UpdateRaftVoterRequest {
377 const API_KEY: i16 = API_KEY;
378 const MIN_VERSION: i16 = MIN_VERSION;
379 const MAX_VERSION: i16 = MAX_VERSION;
380 const FLEXIBLE_MIN: i16 = FLEXIBLE_MIN;
381 type Response = super::update_raft_voter_response::UpdateRaftVoterResponse;
382}