use super::{Algorithm, AlgorithmError, AlgorithmErrorKind::TagInvalid};
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[allow(non_camel_case_types)]
#[repr(u8)]
pub enum EcdsaAlg {
SHA1 = 0x17,
SHA256 = 0x2b,
SHA384 = 0x2c,
SHA512 = 0x2d,
}
impl EcdsaAlg {
pub fn from_u8(tag: u8) -> Result<Self, AlgorithmError> {
Ok(match tag {
0x17 => EcdsaAlg::SHA1,
0x2b => EcdsaAlg::SHA256,
0x2c => EcdsaAlg::SHA384,
0x2d => EcdsaAlg::SHA512,
_ => fail!(TagInvalid, "unknown ECDSA algorithm ID: 0x{:02x}", tag),
})
}
pub fn to_u8(self) -> u8 {
self as u8
}
}
impl From<EcdsaAlg> for Algorithm {
fn from(alg: EcdsaAlg) -> Algorithm {
Algorithm::Ecdsa(alg)
}
}
impl_algorithm_serializers!(EcdsaAlg);