use crate::{
error::Error,
request::{Request, SubFunction},
utils, DataIdentifier, Configuration, RequestData, Service,
};
#[derive(Debug, Clone, Eq, PartialEq)]
pub struct ReadDID {
pub did: DataIdentifier,
pub others: Vec<DataIdentifier>,
}
impl ReadDID {
pub fn new(did: DataIdentifier, others: Vec<DataIdentifier>) -> Self {
Self { did, others }
}
pub fn collect(self) -> Vec<DataIdentifier> {
let mut res = self.others;
res.insert(0, self.did);
res
}
}
impl From<ReadDID> for Vec<u8> {
fn from(input: ReadDID) -> Self {
let did: u16 = input.did.into();
let mut result: Vec<_> = did.to_be_bytes().to_vec();
input.others.into_iter().for_each(|v| {
let v: u16 = v.into();
result.extend(v.to_be_bytes());
});
result
}
}
impl RequestData for ReadDID {
fn new_request<T: AsRef<[u8]>>(
data: T,
sub_func: Option<u8>,
_: &Configuration,
) -> Result<Request, Error> {
let data = data.as_ref();
match sub_func {
Some(_) => Err(Error::SubFunctionError(Service::ReadDID)),
None => {
let data_len = data.len();
let mut offset = 0;
utils::data_length_check(data_len, offset + 2, false)?;
offset += 2;
while data_len > offset {
utils::data_length_check(data_len, offset + 2, false)?;
offset += 2;
}
Ok(Request {
service: Service::ReadDID,
sub_func: None,
data: data.to_vec(),
})
}
}
}
}
impl TryFrom<(&Request, &Configuration)> for ReadDID {
type Error = Error;
fn try_from((req, _): (&Request, &Configuration)) -> Result<Self, Self::Error> {
let service = req.service();
if service != Service::ReadDID || req.sub_func.is_some() {
return Err(Error::ServiceError(service));
}
let data = &req.data;
let data_len = data.len();
let mut offset = 0;
let did = DataIdentifier::from(u16::from_be_bytes([data[offset], data[offset + 1]]));
offset += 2;
let mut others = Vec::new();
while data_len > offset {
others.push(DataIdentifier::from(u16::from_be_bytes([
data[offset],
data[offset + 1],
])));
offset += 2;
}
Ok(Self::new(did, others))
}
}