use super::{NistP256, NistP384};
use crate::{algorithm, asymmetric};
#[cfg(feature = "secp256k1")]
use super::Secp256k1;
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[repr(u8)]
pub enum Algorithm {
Sha1 = 0x17,
Sha256 = 0x2b,
Sha384 = 0x2c,
Sha512 = 0x2d,
}
impl Algorithm {
pub fn from_u8(tag: u8) -> Result<Self, algorithm::Error> {
Ok(match tag {
0x17 => Algorithm::Sha1,
0x2b => Algorithm::Sha256,
0x2c => Algorithm::Sha384,
0x2d => Algorithm::Sha512,
_ => fail!(
algorithm::ErrorKind::TagInvalid,
"unknown ECDSA algorithm ID: 0x{:02x}",
tag
),
})
}
pub fn to_u8(self) -> u8 {
self as u8
}
}
impl_algorithm_serializers!(Algorithm);
pub trait CurveAlgorithm {
fn asymmetric_algorithm() -> asymmetric::Algorithm;
}
impl CurveAlgorithm for NistP256 {
fn asymmetric_algorithm() -> asymmetric::Algorithm {
asymmetric::Algorithm::EcP256
}
}
impl CurveAlgorithm for NistP384 {
fn asymmetric_algorithm() -> asymmetric::Algorithm {
asymmetric::Algorithm::EcP384
}
}
#[cfg(feature = "secp256k1")]
impl CurveAlgorithm for Secp256k1 {
fn asymmetric_algorithm() -> asymmetric::Algorithm {
asymmetric::Algorithm::EcK256
}
}