1use bytes::BufMut;
4
5use crate::primitives::fixed::{get_bool, get_i16, get_i32, get_i64, put_bool, put_i16, put_i32, put_i64};
6use crate::primitives::string_bytes::{
7 compact_string_len, put_compact_string, put_string, string_len,
8};
9use crate::primitives::string_bytes_borrowed::{
10 get_compact_string_borrowed, get_string_borrowed,
11};
12use crate::tagged_fields::{encode_to_bytes, read_tagged_fields, tagged_fields_len, WriteTaggedFields};
13use crate::{Decode, DecodeBorrow, Encode, ProtocolError, UnknownTaggedFields};
14
15pub const API_KEY: i16 = 18;
16pub const MIN_VERSION: i16 = 0;
17pub const MAX_VERSION: i16 = 4;
18pub const FLEXIBLE_MIN: i16 = 3;
19
20#[inline]
21fn is_flexible(version: i16) -> bool { version >= FLEXIBLE_MIN }
22
23#[derive(Debug, Clone, PartialEq, Eq)]
24pub struct ApiVersionsResponse {
25 pub error_code: i16,
26 pub api_keys: Vec<ApiVersion>,
27 pub throttle_time_ms: i32,
28 pub supported_features: Vec<crate::owned::api_versions_response::SupportedFeatureKey>,
29 pub finalized_features_epoch: i64,
30 pub finalized_features: Vec<crate::owned::api_versions_response::FinalizedFeatureKey>,
31 pub zk_migration_ready: bool,
32 pub unknown_tagged_fields: UnknownTaggedFields,
33}
34
35impl Default for ApiVersionsResponse {
36 fn default() -> Self {
37 Self {
38 error_code: 0i16,
39 api_keys: Vec::new(),
40 throttle_time_ms: 0i32,
41 supported_features: Vec::new(),
42 finalized_features_epoch: -1i64,
43 finalized_features: Vec::new(),
44 zk_migration_ready: false,
45 unknown_tagged_fields: Default::default(),
46 }
47 }
48}
49
50impl ApiVersionsResponse {
51 pub fn to_owned(&self) -> crate::owned::api_versions_response::ApiVersionsResponse {
52 crate::owned::api_versions_response::ApiVersionsResponse {
53 error_code: (self.error_code),
54 api_keys: (self.api_keys).iter().map(|it| it.to_owned()).collect(),
55 throttle_time_ms: (self.throttle_time_ms),
56 supported_features: self.supported_features.clone(),
57 finalized_features_epoch: (self.finalized_features_epoch),
58 finalized_features: self.finalized_features.clone(),
59 zk_migration_ready: (self.zk_migration_ready),
60 unknown_tagged_fields: self.unknown_tagged_fields.clone(),
61 }
62 }
63}
64
65impl Encode for ApiVersionsResponse {
66 fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
67 if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
68 return Err(ProtocolError::UnsupportedVersion { api_key: API_KEY, version });
69 }
70 let flex = is_flexible(version);
71 if version >= 0 { put_i16(buf, self.error_code) }
72 if version >= 0 { { crate::primitives::array::put_array_len(buf, (self.api_keys).len(), flex); for it in &self.api_keys { it.encode(buf, version)?; } } }
73 if version >= 1 { put_i32(buf, self.throttle_time_ms) }
74 if flex {
75 let mut tagged = WriteTaggedFields::new();
76 if !(crate::codegen_helpers::is_default(&self.supported_features)) {
77 let payload = encode_to_bytes({ let prefix = crate::primitives::array::array_len_prefix_len((self.supported_features).len(), flex); let body: usize = (self.supported_features).iter().map(|it| it.encoded_len(version)).sum(); prefix + body }, |b| { { crate::primitives::array::put_array_len(b, (self.supported_features).len(), flex); for it in &self.supported_features { it.encode(b, version)?; } }; Ok(()) });
78 tagged.add(0, payload);
79 }
80 if !(self.finalized_features_epoch == -1i64) {
81 let payload = encode_to_bytes(8, |b| { put_i64(b, self.finalized_features_epoch); Ok(()) });
82 tagged.add(1, payload);
83 }
84 if !(crate::codegen_helpers::is_default(&self.finalized_features)) {
85 let payload = encode_to_bytes({ let prefix = crate::primitives::array::array_len_prefix_len((self.finalized_features).len(), flex); let body: usize = (self.finalized_features).iter().map(|it| it.encoded_len(version)).sum(); prefix + body }, |b| { { crate::primitives::array::put_array_len(b, (self.finalized_features).len(), flex); for it in &self.finalized_features { it.encode(b, version)?; } }; Ok(()) });
86 tagged.add(2, payload);
87 }
88 if !(self.zk_migration_ready == false) {
89 let payload = encode_to_bytes(1, |b| { put_bool(b, self.zk_migration_ready); Ok(()) });
90 tagged.add(3, payload);
91 }
92 tagged.write(buf, &self.unknown_tagged_fields);
93 }
94 Ok(())
95 }
96 fn encoded_len(&self, version: i16) -> usize {
97 let flex = is_flexible(version);
98 let mut n: usize = 0;
99 if version >= 0 { n += 2; }
100 if version >= 0 { n += { let prefix = crate::primitives::array::array_len_prefix_len((self.api_keys).len(), flex); let body: usize = (self.api_keys).iter().map(|it| it.encoded_len(version)).sum(); prefix + body }; }
101 if version >= 1 { n += 4; }
102 if flex {
103 let mut known_pairs: Vec<(u32, usize)> = Vec::new();
104 if !(crate::codegen_helpers::is_default(&self.supported_features)) {
105 known_pairs.push((0, { let prefix = crate::primitives::array::array_len_prefix_len((self.supported_features).len(), flex); let body: usize = (self.supported_features).iter().map(|it| it.encoded_len(version)).sum(); prefix + body }));
106 }
107 if !(self.finalized_features_epoch == -1i64) {
108 known_pairs.push((1, 8));
109 }
110 if !(crate::codegen_helpers::is_default(&self.finalized_features)) {
111 known_pairs.push((2, { let prefix = crate::primitives::array::array_len_prefix_len((self.finalized_features).len(), flex); let body: usize = (self.finalized_features).iter().map(|it| it.encoded_len(version)).sum(); prefix + body }));
112 }
113 if !(self.zk_migration_ready == false) {
114 known_pairs.push((3, 1));
115 }
116 n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
117 }
118 n
119 }
120}
121
122impl<'de> DecodeBorrow<'de> for ApiVersionsResponse {
123 fn decode_borrow(buf: &mut &'de [u8], version: i16) -> Result<Self, ProtocolError> {
124 if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
125 return Err(ProtocolError::UnsupportedVersion { api_key: API_KEY, version });
126 }
127 let flex = is_flexible(version);
128 let mut out = Self::default();
129 if version >= 0 { out.error_code = get_i16(buf)?; }
130 if version >= 0 { out.api_keys = { let n = crate::primitives::array::get_array_len(buf, flex)?; let mut v = Vec::with_capacity(n); for _ in 0..n { v.push(ApiVersion::decode_borrow(buf, version)?); } v }; }
131 if version >= 1 { out.throttle_time_ms = get_i32(buf)?; }
132 if flex {
133 let mut tag_supported_features = None;
135 let mut tag_finalized_features_epoch = None;
136 let mut tag_finalized_features = None;
137 let mut tag_zk_migration_ready = None;
138 out.unknown_tagged_fields = read_tagged_fields(buf, |tag, payload| {
139 match tag {
140 0 => { tag_supported_features = Some({ let b: &mut &[u8] = payload; { let n = crate::primitives::array::get_array_len(b, flex)?; let mut v = Vec::with_capacity(n); for _ in 0..n { v.push(crate::owned::api_versions_response::SupportedFeatureKey::decode(b, version)?); } v } }); Ok(true) }
141 1 => { tag_finalized_features_epoch = Some({ let b: &mut &[u8] = payload; get_i64(b)? }); Ok(true) }
142 2 => { tag_finalized_features = Some({ let b: &mut &[u8] = payload; { let n = crate::primitives::array::get_array_len(b, flex)?; let mut v = Vec::with_capacity(n); for _ in 0..n { v.push(crate::owned::api_versions_response::FinalizedFeatureKey::decode(b, version)?); } v } }); Ok(true) }
143 3 => { tag_zk_migration_ready = Some({ let b: &mut &[u8] = payload; get_bool(b)? }); Ok(true) }
144 _ => Ok(false),
145 }
146 })?;
147 if let Some(v) = tag_supported_features { out.supported_features = v; }
148 if let Some(v) = tag_finalized_features_epoch { out.finalized_features_epoch = v; }
149 if let Some(v) = tag_finalized_features { out.finalized_features = v; }
150 if let Some(v) = tag_zk_migration_ready { out.zk_migration_ready = v; }
151 }
152 Ok(out)
153 }
154}
155
156#[derive(Debug, Clone, PartialEq, Eq)]
157pub struct ApiVersion {
158 pub api_key: i16,
159 pub min_version: i16,
160 pub max_version: i16,
161 pub unknown_tagged_fields: UnknownTaggedFields,
162}
163
164impl Default for ApiVersion {
165 fn default() -> Self {
166 Self {
167 api_key: 0i16,
168 min_version: 0i16,
169 max_version: 0i16,
170 unknown_tagged_fields: Default::default(),
171 }
172 }
173}
174
175impl ApiVersion {
176 pub fn to_owned(&self) -> crate::owned::api_versions_response::ApiVersion {
177 crate::owned::api_versions_response::ApiVersion {
178 api_key: (self.api_key),
179 min_version: (self.min_version),
180 max_version: (self.max_version),
181 unknown_tagged_fields: self.unknown_tagged_fields.clone(),
182 }
183 }
184}
185
186impl Encode for ApiVersion {
187 fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
188 let flex = version >= 3;
189 if version >= 0 { put_i16(buf, self.api_key) }
190 if version >= 0 { put_i16(buf, self.min_version) }
191 if version >= 0 { put_i16(buf, self.max_version) }
192 if flex {
193 let tagged = WriteTaggedFields::new();
194 tagged.write(buf, &self.unknown_tagged_fields);
195 }
196 Ok(())
197 }
198 fn encoded_len(&self, version: i16) -> usize {
199 let flex = version >= 3;
200 let mut n: usize = 0;
201 if version >= 0 { n += 2; }
202 if version >= 0 { n += 2; }
203 if version >= 0 { n += 2; }
204 if flex {
205 let known_pairs: Vec<(u32, usize)> = Vec::new();
206 n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
207 }
208 n
209 }
210}
211
212impl<'de> DecodeBorrow<'de> for ApiVersion {
213 fn decode_borrow(buf: &mut &'de [u8], version: i16) -> Result<Self, ProtocolError> {
214 let flex = version >= 3;
215 let mut out = Self::default();
216 if version >= 0 { out.api_key = get_i16(buf)?; }
217 if version >= 0 { out.min_version = get_i16(buf)?; }
218 if version >= 0 { out.max_version = get_i16(buf)?; }
219 if flex {
220 out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| {
221 Ok(false)
222 })?;
223 }
224 Ok(out)
225 }
226}
227
228#[derive(Debug, Clone, PartialEq, Eq)]
229pub struct SupportedFeatureKey<'a> {
230 pub name: &'a str,
231 pub min_version: i16,
232 pub max_version: i16,
233 pub unknown_tagged_fields: UnknownTaggedFields,
234}
235
236impl<'a> Default for SupportedFeatureKey<'a> {
237 fn default() -> Self {
238 Self {
239 name: "",
240 min_version: 0i16,
241 max_version: 0i16,
242 unknown_tagged_fields: Default::default(),
243 }
244 }
245}
246
247impl<'a> SupportedFeatureKey<'a> {
248 pub fn to_owned(&self) -> crate::owned::api_versions_response::SupportedFeatureKey {
249 crate::owned::api_versions_response::SupportedFeatureKey {
250 name: (self.name).to_string(),
251 min_version: (self.min_version),
252 max_version: (self.max_version),
253 unknown_tagged_fields: self.unknown_tagged_fields.clone(),
254 }
255 }
256}
257
258impl<'a> Encode for SupportedFeatureKey<'a> {
259 fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
260 let flex = version >= 3;
261 if version >= 3 { if flex { put_compact_string(buf, self.name) } else { put_string(buf, self.name) } }
262 if version >= 3 { put_i16(buf, self.min_version) }
263 if version >= 3 { put_i16(buf, self.max_version) }
264 if flex {
265 let tagged = WriteTaggedFields::new();
266 tagged.write(buf, &self.unknown_tagged_fields);
267 }
268 Ok(())
269 }
270 fn encoded_len(&self, version: i16) -> usize {
271 let flex = version >= 3;
272 let mut n: usize = 0;
273 if version >= 3 { n += if flex { compact_string_len(self.name) } else { string_len(self.name) }; }
274 if version >= 3 { n += 2; }
275 if version >= 3 { n += 2; }
276 if flex {
277 let known_pairs: Vec<(u32, usize)> = Vec::new();
278 n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
279 }
280 n
281 }
282}
283
284impl<'de> DecodeBorrow<'de> for SupportedFeatureKey<'de> {
285 fn decode_borrow(buf: &mut &'de [u8], version: i16) -> Result<Self, ProtocolError> {
286 let flex = version >= 3;
287 let mut out = Self::default();
288 if version >= 3 { out.name = if flex { get_compact_string_borrowed(buf)? } else { get_string_borrowed(buf)? }; }
289 if version >= 3 { out.min_version = get_i16(buf)?; }
290 if version >= 3 { out.max_version = get_i16(buf)?; }
291 if flex {
292 out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| {
293 Ok(false)
294 })?;
295 }
296 Ok(out)
297 }
298}
299
300#[derive(Debug, Clone, PartialEq, Eq)]
301pub struct FinalizedFeatureKey<'a> {
302 pub name: &'a str,
303 pub max_version_level: i16,
304 pub min_version_level: i16,
305 pub unknown_tagged_fields: UnknownTaggedFields,
306}
307
308impl<'a> Default for FinalizedFeatureKey<'a> {
309 fn default() -> Self {
310 Self {
311 name: "",
312 max_version_level: 0i16,
313 min_version_level: 0i16,
314 unknown_tagged_fields: Default::default(),
315 }
316 }
317}
318
319impl<'a> FinalizedFeatureKey<'a> {
320 pub fn to_owned(&self) -> crate::owned::api_versions_response::FinalizedFeatureKey {
321 crate::owned::api_versions_response::FinalizedFeatureKey {
322 name: (self.name).to_string(),
323 max_version_level: (self.max_version_level),
324 min_version_level: (self.min_version_level),
325 unknown_tagged_fields: self.unknown_tagged_fields.clone(),
326 }
327 }
328}
329
330impl<'a> Encode for FinalizedFeatureKey<'a> {
331 fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
332 let flex = version >= 3;
333 if version >= 3 { if flex { put_compact_string(buf, self.name) } else { put_string(buf, self.name) } }
334 if version >= 3 { put_i16(buf, self.max_version_level) }
335 if version >= 3 { put_i16(buf, self.min_version_level) }
336 if flex {
337 let tagged = WriteTaggedFields::new();
338 tagged.write(buf, &self.unknown_tagged_fields);
339 }
340 Ok(())
341 }
342 fn encoded_len(&self, version: i16) -> usize {
343 let flex = version >= 3;
344 let mut n: usize = 0;
345 if version >= 3 { n += if flex { compact_string_len(self.name) } else { string_len(self.name) }; }
346 if version >= 3 { n += 2; }
347 if version >= 3 { n += 2; }
348 if flex {
349 let known_pairs: Vec<(u32, usize)> = Vec::new();
350 n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
351 }
352 n
353 }
354}
355
356impl<'de> DecodeBorrow<'de> for FinalizedFeatureKey<'de> {
357 fn decode_borrow(buf: &mut &'de [u8], version: i16) -> Result<Self, ProtocolError> {
358 let flex = version >= 3;
359 let mut out = Self::default();
360 if version >= 3 { out.name = if flex { get_compact_string_borrowed(buf)? } else { get_string_borrowed(buf)? }; }
361 if version >= 3 { out.max_version_level = get_i16(buf)?; }
362 if version >= 3 { out.min_version_level = get_i16(buf)?; }
363 if flex {
364 out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| {
365 Ok(false)
366 })?;
367 }
368 Ok(out)
369 }
370}