use byteorder::WriteBytesExt;
use crate::codec::*;
use crate::IoResult;
#[derive(Debug, Default, Clone)]
pub struct OffsetFetchResponse {
pub throttle_time_ms: i32,
pub topics: Vec<OffsetFetchResponseTopic>,
pub error_code: i16,
pub groups: Vec<OffsetFetchResponseGroup>,
pub unknown_tagged_fields: Vec<RawTaggedField>,
}
impl Encodable for OffsetFetchResponse {
fn write<B: WriteBytesExt>(&self, buf: &mut B, version: i16) -> IoResult<()> {
if version >= 3 {
Int32.encode(buf, self.throttle_time_ms)?;
}
if version <= 7 {
NullableArray(Struct(version), version >= 6).encode(buf, self.topics.as_slice())?;
}
if (2..=7).contains(&version) {
Int16.encode(buf, self.error_code)?;
}
if version >= 8 {
NullableArray(Struct(version), true).encode(buf, self.groups.as_slice())?;
}
if version >= 6 {
RawTaggedFieldList.encode(buf, &self.unknown_tagged_fields)?;
}
Ok(())
}
fn calculate_size(&self, version: i16) -> usize {
let mut res = 0;
if version >= 3 {
res += Int32::SIZE; }
if version <= 7 {
res +=
NullableArray(Struct(version), version >= 6).calculate_size(self.topics.as_slice());
}
if (2..=7).contains(&version) {
res += Int16::SIZE; }
if version >= 8 {
res += NullableArray(Struct(version), true).calculate_size(self.groups.as_slice());
}
if version >= 6 {
res += RawTaggedFieldList.calculate_size(&self.unknown_tagged_fields);
}
res
}
}
#[derive(Debug, Default, Clone)]
pub struct OffsetFetchResponseTopic {
pub name: String,
pub partitions: Vec<OffsetFetchResponsePartition>,
pub unknown_tagged_fields: Vec<RawTaggedField>,
}
impl Encodable for OffsetFetchResponseTopic {
fn write<B: WriteBytesExt>(&self, buf: &mut B, version: i16) -> IoResult<()> {
if version > 7 {
Err(err_encode_message_unsupported(
version,
"OffsetFetchResponseTopic",
))?
}
NullableString(version >= 6).encode(buf, self.name.as_str())?;
NullableArray(Struct(version), version >= 6).encode(buf, self.partitions.as_slice())?;
if version >= 6 {
RawTaggedFieldList.encode(buf, &self.unknown_tagged_fields)?;
}
Ok(())
}
fn calculate_size(&self, version: i16) -> usize {
let mut res = 0;
res += NullableString(version >= 6).calculate_size(self.name.as_str());
res +=
NullableArray(Struct(version), version >= 6).calculate_size(self.partitions.as_slice());
if version >= 6 {
res += RawTaggedFieldList.calculate_size(&self.unknown_tagged_fields);
}
res
}
}
#[derive(Debug, Default, Clone)]
pub struct OffsetFetchResponsePartition {
pub partition_index: i32,
pub committed_offset: i32,
pub committed_leader_epoch: i32,
pub metadata: Option<String>,
pub error_code: i16,
pub unknown_tagged_fields: Vec<RawTaggedField>,
}
impl Encodable for OffsetFetchResponsePartition {
fn write<B: WriteBytesExt>(&self, buf: &mut B, version: i16) -> IoResult<()> {
Int32.encode(buf, self.partition_index)?;
Int32.encode(buf, self.committed_offset)?;
if version >= 5 {
Int32.encode(buf, self.committed_leader_epoch)?;
}
NullableString(version >= 6).encode(buf, self.metadata.as_deref())?;
Int16.encode(buf, self.error_code)?;
if version >= 6 {
RawTaggedFieldList.encode(buf, &self.unknown_tagged_fields)?;
}
Ok(())
}
fn calculate_size(&self, version: i16) -> usize {
let mut res = 0;
res += Int32::SIZE; res += Int32::SIZE; if version >= 5 {
res += Int32::SIZE; }
res += NullableString(version >= 6).calculate_size(self.metadata.as_deref());
res += Int16::SIZE; if version >= 6 {
res += RawTaggedFieldList.calculate_size(&self.unknown_tagged_fields);
}
res
}
}
#[derive(Debug, Default, Clone)]
pub struct OffsetFetchResponseGroup {
pub group_id: String,
pub topics: Vec<OffsetFetchResponseTopics>,
pub error_code: i16,
pub unknown_tagged_fields: Vec<RawTaggedField>,
}
impl Encodable for OffsetFetchResponseGroup {
fn write<B: WriteBytesExt>(&self, buf: &mut B, version: i16) -> IoResult<()> {
if version < 8 {
Err(err_encode_message_unsupported(
version,
"OffsetFetchResponseGroup",
))?
}
NullableString(true).encode(buf, self.group_id.as_str())?;
NullableArray(Struct(version), true).encode(buf, self.topics.as_slice())?;
Int16.encode(buf, self.error_code)?;
RawTaggedFieldList.encode(buf, &self.unknown_tagged_fields)?;
Ok(())
}
fn calculate_size(&self, version: i16) -> usize {
let mut res = 0;
res += NullableString(true).calculate_size(self.group_id.as_str());
res += NullableArray(Struct(version), true).calculate_size(self.topics.as_slice());
res += Int16::SIZE; res += RawTaggedFieldList.calculate_size(&self.unknown_tagged_fields);
res
}
}
#[derive(Debug, Default, Clone)]
pub struct OffsetFetchResponseTopics {
pub name: String,
pub partitions: Vec<OffsetFetchResponsePartitions>,
pub unknown_tagged_fields: Vec<RawTaggedField>,
}
impl Encodable for OffsetFetchResponseTopics {
fn write<B: WriteBytesExt>(&self, buf: &mut B, version: i16) -> IoResult<()> {
NullableString(true).encode(buf, self.name.as_str())?;
NullableArray(Struct(version), true).encode(buf, self.partitions.as_slice())?;
RawTaggedFieldList.encode(buf, &self.unknown_tagged_fields)?;
Ok(())
}
fn calculate_size(&self, version: i16) -> usize {
let mut res = 0;
res += NullableString(true).calculate_size(self.name.as_str());
res += NullableArray(Struct(version), true).calculate_size(self.partitions.as_slice());
res += RawTaggedFieldList.calculate_size(&self.unknown_tagged_fields);
res
}
}
#[derive(Debug, Default, Clone)]
pub struct OffsetFetchResponsePartitions {
pub partition_index: i32,
pub committed_offset: i64,
pub committed_leader_epoch: i32,
pub metadata: Option<String>,
pub error_code: i16,
pub unknown_tagged_fields: Vec<RawTaggedField>,
}
impl Encodable for OffsetFetchResponsePartitions {
fn write<B: WriteBytesExt>(&self, buf: &mut B, _version: i16) -> IoResult<()> {
Int32.encode(buf, self.partition_index)?;
Int64.encode(buf, self.committed_offset)?;
Int32.encode(buf, self.committed_leader_epoch)?;
NullableString(true).encode(buf, self.metadata.as_deref())?;
Int16.encode(buf, self.error_code)?;
RawTaggedFieldList.encode(buf, &self.unknown_tagged_fields)?;
Ok(())
}
fn calculate_size(&self, _version: i16) -> usize {
let mut res = 0;
res += Int32::SIZE; res += Int64::SIZE; res += Int32::SIZE; res += NullableString(true).calculate_size(self.metadata.as_deref());
res += Int16::SIZE; res += RawTaggedFieldList.calculate_size(&self.unknown_tagged_fields);
res
}
}