use crate::algorithm;
use anomaly::fail;
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[repr(u8)]
pub enum Algorithm {
Sha1 = 0x13,
Sha256 = 0x14,
Sha384 = 0x15,
Sha512 = 0x16,
}
impl Algorithm {
pub fn from_u8(tag: u8) -> Result<Self, algorithm::Error> {
Ok(match tag {
0x13 => Algorithm::Sha1,
0x14 => Algorithm::Sha256,
0x15 => Algorithm::Sha384,
0x16 => Algorithm::Sha512,
_ => fail!(
algorithm::ErrorKind::TagInvalid,
"unknown HMAC algorithm ID: 0x{:02x}",
tag
),
})
}
pub fn to_u8(self) -> u8 {
self as u8
}
pub fn key_len(self) -> usize {
match self {
Algorithm::Sha1 => 20,
Algorithm::Sha256 => 32,
Algorithm::Sha384 => 48,
Algorithm::Sha512 => 64,
}
}
pub fn max_key_len(self) -> usize {
match self {
Algorithm::Sha1 => 64,
Algorithm::Sha256 => 64,
Algorithm::Sha384 => 128,
Algorithm::Sha512 => 128,
}
}
}
impl_algorithm_serializers!(Algorithm);