use byteorder::ReadBytesExt;
use crate::codec::*;
use crate::IoResult;
#[derive(Debug, Default, Clone)]
pub struct ProduceRequest {
pub transactional_id: Option<String>,
pub acks: i16,
pub timeout_ms: i32,
pub topic_data: Vec<TopicProduceData>,
pub unknown_tagged_fields: Vec<RawTaggedField>,
}
impl Decodable for ProduceRequest {
fn read<B: ReadBytesExt>(buf: &mut B, version: i16) -> IoResult<Self> {
let mut this = ProduceRequest::default();
if version >= 3 {
this.transactional_id = NullableString(version >= 9).decode(buf)?;
}
this.acks = Int16.decode(buf)?;
this.timeout_ms = Int32.decode(buf)?;
this.topic_data = NullableArray(Struct(version), version >= 9)
.decode(buf)?
.ok_or_else(|| err_decode_message_null("topic_data"))?;
if version >= 9 {
this.unknown_tagged_fields = RawTaggedFieldList.decode(buf)?;
}
Ok(this)
}
}
#[derive(Debug, Default, Clone)]
pub struct TopicProduceData {
pub name: String,
pub partition_data: Vec<PartitionProduceData>,
pub unknown_tagged_fields: Vec<RawTaggedField>,
}
impl Decodable for TopicProduceData {
fn read<B: ReadBytesExt>(buf: &mut B, version: i16) -> IoResult<Self> {
if version > 9 {
Err(err_decode_message_unsupported(version, "TopicProduceData"))?
}
let mut this = TopicProduceData {
name: NullableString(version >= 9)
.decode(buf)?
.ok_or_else(|| err_decode_message_null("name"))?,
partition_data: NullableArray(Struct(version), version >= 9)
.decode(buf)?
.ok_or_else(|| err_decode_message_null("partition_data"))?,
..Default::default()
};
if version >= 9 {
this.unknown_tagged_fields = RawTaggedFieldList.decode(buf)?;
}
Ok(this)
}
}
#[derive(Debug, Default, Clone)]
pub struct PartitionProduceData {
pub index: i32,
pub records: Option<Vec<u8>>,
pub unknown_tagged_fields: Vec<RawTaggedField>,
}
impl Decodable for PartitionProduceData {
fn read<B: ReadBytesExt>(buf: &mut B, version: i16) -> IoResult<Self> {
if version > 9 {
Err(err_decode_message_unsupported(
version,
"PartitionProduceData",
))?
}
let mut this = PartitionProduceData {
index: Int32.decode(buf)?,
records: NullableBytes(version >= 9).decode(buf)?,
..Default::default()
};
if version >= 9 {
this.unknown_tagged_fields = RawTaggedFieldList.decode(buf)?;
}
Ok(this)
}
}