kf_protocol_message/kf_code_gen/
sync_group.rs1use serde::{Deserialize, Serialize};
5
6use kf_protocol_api::ErrorCode;
7use kf_protocol_api::GroupAssignment;
8use kf_protocol_api::Request;
9
10use kf_protocol_derive::Decode;
11use kf_protocol_derive::Encode;
12use kf_protocol_derive::KfDefault;
13
14#[derive(Encode, Decode, Serialize, Deserialize, KfDefault, Debug)]
19pub struct KfSyncGroupRequest {
20 pub group_id: String,
22
23 pub generation_id: i32,
25
26 pub member_id: String,
28
29 pub assignments: Vec<SyncGroupRequestAssignment>,
31}
32
33#[derive(Encode, Decode, Serialize, Deserialize, KfDefault, Debug)]
34pub struct SyncGroupRequestAssignment {
35 pub member_id: String,
37
38 pub assignment: GroupAssignment,
40}
41
42#[derive(Encode, Decode, Serialize, Deserialize, KfDefault, Debug)]
47pub struct KfSyncGroupResponse {
48 #[fluvio_kf(min_version = 1, ignorable)]
51 pub throttle_time_ms: i32,
52
53 pub error_code: ErrorCode,
55
56 pub assignment: GroupAssignment,
58}
59
60impl Request for KfSyncGroupRequest {
65 const API_KEY: u16 = 14;
66
67 const MIN_API_VERSION: i16 = 0;
68 const MAX_API_VERSION: i16 = 2;
69 const DEFAULT_API_VERSION: i16 = 2;
70
71 type Response = KfSyncGroupResponse;
72}