use crate::error::Error;
use crate::payload_util::require_exact_len;
use alloc::vec::Vec;
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
pub struct SCrypt {
pub server_cryptogram: [u8; 16],
}
impl SCrypt {
pub const fn new(c: [u8; 16]) -> Self {
Self {
server_cryptogram: c,
}
}
pub fn encode(&self) -> Result<Vec<u8>, Error> {
Ok(self.server_cryptogram.to_vec())
}
pub fn decode(data: &[u8]) -> Result<Self, Error> {
require_exact_len(data, 16, 0x77)?;
let mut c = [0u8; 16];
c.copy_from_slice(data);
Ok(Self {
server_cryptogram: c,
})
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn roundtrip() {
let body = SCrypt::new([0x42u8; 16]);
let bytes = body.encode().unwrap();
assert_eq!(bytes.len(), 16);
assert_eq!(SCrypt::decode(&bytes).unwrap(), body);
}
#[test]
fn decode_rejects_wrong_length() {
assert!(matches!(
SCrypt::decode(&[0; 15]),
Err(Error::PayloadLength { code: 0x77, .. })
));
}
}