use super::{Algorithm, AlgorithmError, AlgorithmErrorKind::TagInvalid};
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[allow(non_camel_case_types)]
#[repr(u8)]
pub enum RsaAlg {
PKCS1_SHA1 = 0x01,
PKCS1_SHA256 = 0x02,
PKCS1_SHA384 = 0x03,
PKCS1_SHA512 = 0x04,
PSS_SHA1 = 0x05,
PSS_SHA256 = 0x06,
PSS_SHA384 = 0x07,
PSS_SHA512 = 0x08,
OAEP_SHA1 = 0x19,
OAEP_SHA256 = 0x1a,
OAEP_SHA384 = 0x1b,
OAEP_SHA512 = 0x1c,
}
impl RsaAlg {
pub fn from_u8(tag: u8) -> Result<Self, AlgorithmError> {
Ok(match tag {
0x01 => RsaAlg::PKCS1_SHA1,
0x02 => RsaAlg::PKCS1_SHA256,
0x03 => RsaAlg::PKCS1_SHA384,
0x04 => RsaAlg::PKCS1_SHA512,
0x05 => RsaAlg::PSS_SHA1,
0x06 => RsaAlg::PSS_SHA256,
0x07 => RsaAlg::PSS_SHA384,
0x08 => RsaAlg::PSS_SHA512,
0x19 => RsaAlg::OAEP_SHA1,
0x1a => RsaAlg::OAEP_SHA256,
0x1b => RsaAlg::OAEP_SHA384,
0x1c => RsaAlg::OAEP_SHA512,
_ => fail!(TagInvalid, "unknown RSA algorithm ID: 0x{:02x}", tag),
})
}
pub fn to_u8(self) -> u8 {
self as u8
}
}
impl From<RsaAlg> for Algorithm {
fn from(alg: RsaAlg) -> Algorithm {
Algorithm::Rsa(alg)
}
}
impl_algorithm_serializers!(RsaAlg);