use super::{Algorithm, AlgorithmError, AlgorithmErrorKind::TagInvalid};
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[allow(non_camel_case_types)]
#[repr(u8)]
pub enum WrapAlg {
AES128_CCM = 0x1d,
AES192_CCM = 0x29,
AES256_CCM = 0x2a,
}
impl WrapAlg {
pub fn from_u8(tag: u8) -> Result<Self, AlgorithmError> {
Ok(match tag {
0x1d => WrapAlg::AES128_CCM,
0x29 => WrapAlg::AES192_CCM,
0x2a => WrapAlg::AES256_CCM,
_ => fail!(TagInvalid, "unknown wrap algorithm ID: 0x{:02x}", tag),
})
}
pub fn to_u8(self) -> u8 {
self as u8
}
pub fn key_len(self) -> usize {
match self {
WrapAlg::AES128_CCM => 16,
WrapAlg::AES192_CCM => 24,
WrapAlg::AES256_CCM => 32,
}
}
}
impl From<WrapAlg> for Algorithm {
fn from(alg: WrapAlg) -> Algorithm {
Algorithm::Wrap(alg)
}
}
impl_algorithm_serializers!(WrapAlg);