use byteorder::WriteBytesExt;
use crate::codec::*;
use crate::IoResult;
#[derive(Debug, Default, Clone)]
pub struct ProduceResponse {
pub responses: Vec<TopicProduceResponse>,
pub throttle_time_ms: i32,
pub unknown_tagged_fields: Vec<RawTaggedField>,
}
impl Encodable for ProduceResponse {
fn write<B: WriteBytesExt>(&self, buf: &mut B, version: i16) -> IoResult<()> {
NullableArray(Struct(version), version >= 9).encode(buf, self.responses.as_slice())?;
if version > 1 {
Int32.encode(buf, self.throttle_time_ms)?;
}
if version >= 9 {
RawTaggedFieldList.encode(buf, &self.unknown_tagged_fields)?;
}
Ok(())
}
fn calculate_size(&self, version: i16) -> usize {
let mut res = 0;
res +=
NullableArray(Struct(version), version >= 9).calculate_size(self.responses.as_slice());
if version > 1 {
res += Int32::SIZE; }
if version >= 9 {
res += RawTaggedFieldList.calculate_size(&self.unknown_tagged_fields);
}
res
}
}
#[derive(Debug, Default, Clone)]
pub struct TopicProduceResponse {
pub name: String,
pub partition_responses: Vec<PartitionProduceResponse>,
pub unknown_tagged_fields: Vec<RawTaggedField>,
}
impl Encodable for TopicProduceResponse {
fn write<B: WriteBytesExt>(&self, buf: &mut B, version: i16) -> IoResult<()> {
NullableString(version >= 9).encode(buf, self.name.as_str())?;
NullableArray(Struct(version), version >= 9)
.encode(buf, self.partition_responses.as_slice())?;
if version >= 9 {
RawTaggedFieldList.encode(buf, &self.unknown_tagged_fields)?;
}
Ok(())
}
fn calculate_size(&self, version: i16) -> usize {
let mut res = 0;
res += NullableString(version >= 9).calculate_size(self.name.as_str());
res += NullableArray(Struct(version), version >= 9)
.calculate_size(self.partition_responses.as_slice());
if version >= 9 {
res += RawTaggedFieldList.calculate_size(&self.unknown_tagged_fields);
}
res
}
}
#[derive(Debug, Default, Clone)]
pub struct PartitionProduceResponse {
pub index: i32,
pub error_code: i16,
pub base_offset: i64,
pub log_append_time_ms: i64,
pub log_start_offset: i64,
pub record_errors: Vec<BatchIndexAndErrorMessage>,
pub error_message: Option<String>,
pub unknown_tagged_fields: Vec<RawTaggedField>,
}
impl Encodable for PartitionProduceResponse {
fn write<B: WriteBytesExt>(&self, buf: &mut B, version: i16) -> IoResult<()> {
Int32.encode(buf, self.index)?;
Int16.encode(buf, self.error_code)?;
Int64.encode(buf, self.base_offset)?;
if version >= 2 {
Int64.encode(buf, self.log_append_time_ms)?;
}
if version >= 5 {
Int64.encode(buf, self.log_start_offset)?;
}
if version >= 8 {
NullableArray(Struct(version), version >= 9)
.encode(buf, self.record_errors.as_slice())?;
}
if version >= 8 {
NullableString(version >= 9).encode(buf, self.error_message.as_deref())?;
}
if version >= 9 {
RawTaggedFieldList.encode(buf, &self.unknown_tagged_fields)?;
}
Ok(())
}
fn calculate_size(&self, version: i16) -> usize {
let mut res = 0;
res += Int32::SIZE; res += Int16::SIZE; res += Int64::SIZE; if version >= 2 {
res += Int64::SIZE; }
if version >= 5 {
res += Int64::SIZE; }
if version >= 8 {
res += NullableArray(Struct(version), version >= 9)
.calculate_size(self.record_errors.as_slice());
}
if version >= 8 {
res += NullableString(version >= 9).calculate_size(self.error_message.as_deref());
}
if version >= 9 {
res += RawTaggedFieldList.calculate_size(&self.unknown_tagged_fields);
}
res
}
}
#[derive(Debug, Default, Clone)]
pub struct BatchIndexAndErrorMessage {
pub batch_index: i32,
pub batch_index_error_message: Option<String>,
pub unknown_tagged_fields: Vec<RawTaggedField>,
}
impl Encodable for BatchIndexAndErrorMessage {
fn write<B: WriteBytesExt>(&self, buf: &mut B, version: i16) -> IoResult<()> {
if version < 8 {
Err(err_encode_message_unsupported(
version,
"BatchIndexAndErrorMessage",
))?
}
Int32.encode(buf, self.batch_index)?;
NullableString(version >= 9).encode(buf, self.batch_index_error_message.as_deref())?;
if version >= 9 {
RawTaggedFieldList.encode(buf, &self.unknown_tagged_fields)?;
}
Ok(())
}
fn calculate_size(&self, version: i16) -> usize {
let mut res = 0;
res += Int32::SIZE; res +=
NullableString(version >= 9).calculate_size(self.batch_index_error_message.as_deref());
if version >= 9 {
res += RawTaggedFieldList.calculate_size(&self.unknown_tagged_fields);
}
res
}
}