kf_protocol_message/kf_code_gen/
offset_fetch.rs1use serde::{Deserialize, Serialize};
5
6use kf_protocol_api::ErrorCode;
7use kf_protocol_api::Request;
8
9use kf_protocol_derive::Decode;
10use kf_protocol_derive::Encode;
11use kf_protocol_derive::KfDefault;
12
13#[derive(Encode, Decode, Serialize, Deserialize, KfDefault, Debug)]
18pub struct KfOffsetFetchRequest {
19 pub group_id: String,
21
22 pub topics: Option<Vec<OffsetFetchRequestTopic>>,
24}
25
26#[derive(Encode, Decode, Serialize, Deserialize, KfDefault, Debug)]
27pub struct OffsetFetchRequestTopic {
28 pub name: String,
29
30 pub partition_indexes: Vec<i32>,
32}
33
34#[derive(Encode, Decode, Serialize, Deserialize, KfDefault, Debug)]
39pub struct KfOffsetFetchResponse {
40 #[fluvio_kf(min_version = 3, ignorable)]
43 pub throttle_time_ms: i32,
44
45 pub topics: Vec<OffsetFetchResponseTopic>,
47
48 #[fluvio_kf(min_version = 2)]
50 pub error_code: ErrorCode,
51}
52
53#[derive(Encode, Decode, Serialize, Deserialize, KfDefault, Debug)]
54pub struct OffsetFetchResponseTopic {
55 pub name: String,
57
58 pub partitions: Vec<OffsetFetchResponsePartition>,
60}
61
62#[derive(Encode, Decode, Serialize, Deserialize, KfDefault, Debug)]
63pub struct OffsetFetchResponsePartition {
64 pub partition_index: i32,
66
67 pub committed_offset: i64,
69
70 #[fluvio_kf(min_version = 5)]
72 pub committed_leader_epoch: i32,
73
74 pub metadata: Option<String>,
76
77 pub error_code: ErrorCode,
79}
80
81impl Request for KfOffsetFetchRequest {
86 const API_KEY: u16 = 9;
87
88 const MIN_API_VERSION: i16 = 0;
89 const MAX_API_VERSION: i16 = 5;
90 const DEFAULT_API_VERSION: i16 = 5;
91
92 type Response = KfOffsetFetchResponse;
93}