use super::property::Property; use super::packet_type::PacketType; use crate::utils::buffer_reader::BuffReader; use crate::utils::buffer_reader::EncodedString; use crate::utils::buffer_reader::BinaryData; use crate::utils::buffer_reader::ParseError; use crate::packet::mqtt_packet::Packet; use heapless::Vec; pub const MAX_PROPERTIES: usize = 20; pub struct UnsubackPacket<'a, const MAX_REASONS: usize> { // 7 - 4 mqtt control packet type, 3-0 flagy pub fixed_header: u8, // 1 - 4 B lenght of variable header + len of payload pub remain_len: u32, pub packet_identifier: u16, pub property_len: u32, // properties pub properties: Vec, MAX_PROPERTIES>, pub reason_codes: Vec, } impl<'a, const MAX_REASONS: usize> UnsubackPacket<'a, MAX_REASONS> { pub fn decode_properties(& mut self, buff_reader: & mut BuffReader<'a>) { self.property_len = buff_reader.readVariableByteInt().unwrap(); let mut x: u32 = 0; let mut prop: Result; loop { let mut res: Property; prop = Property::decode(buff_reader); if let Ok(res) = prop { log::info!("Parsed property {:?}", res); x = x + res.len() as u32 + 1; self.properties.push(res); } else { // error handlo log::error!("Problem during property decoding"); } if x == self.property_len { break; } } } pub fn decode_fixed_header(& mut self, buff_reader: & mut BuffReader) -> PacketType { let first_byte: u8 = buff_reader.readU8().unwrap(); self.fixed_header = first_byte; self.remain_len = buff_reader.readVariableByteInt().unwrap(); return PacketType::from(self.fixed_header); } pub fn read_reason_codes(& mut self, buff_reader: & mut BuffReader<'a>) { let mut i = 0; loop { self.reason_codes.push(buff_reader.readU8().unwrap()); i = i + 1; if i == MAX_REASONS { break; } } } pub fn decode_suback_packet(& mut self, buff_reader: & mut BuffReader<'a>) { if self.decode_fixed_header(buff_reader) != (PacketType::Suback).into() { log::error!("Packet you are trying to decode is not SUBACK packet!"); return; } self.packet_identifier = buff_reader.readU16().unwrap(); self.decode_properties(buff_reader); self.read_reason_codes(buff_reader); } } impl<'a, const MAX_REASONS: usize> Packet<'a> for UnsubackPacket<'a, MAX_REASONS>{ fn decode(& mut self, buff_reader: & mut BuffReader<'a>) { self.decode_suback_packet(buff_reader); } fn encode(& mut self, buffer: & mut [u8]) { } }