use async_trait::async_trait;
use bcder::Oid;
use crate::raw_signature::{
oids::*, AsyncRawSignatureValidator, RawSignatureValidationError, RawSignatureValidator,
SigningAlg,
};
mod ecdsa_validator;
pub(crate) use ecdsa_validator::EcdsaValidator;
mod ed25519_validator;
pub(crate) use ed25519_validator::Ed25519Validator;
mod rsa_legacy_validator;
pub(crate) use rsa_legacy_validator::RsaLegacyValidator;
mod rsa_validator;
pub(crate) use rsa_validator::RsaValidator;
struct AsyncRawSignatureValidatorAdapter {
validator: Box<dyn RawSignatureValidator>,
}
impl AsyncRawSignatureValidatorAdapter {
fn new(validator: Box<dyn RawSignatureValidator>) -> Self {
Self { validator }
}
}
#[async_trait(?Send)]
impl AsyncRawSignatureValidator for AsyncRawSignatureValidatorAdapter {
async fn validate_async(
&self,
sig: &[u8],
data: &[u8],
public_key: &[u8],
) -> Result<(), RawSignatureValidationError> {
self.validator.validate(sig, data, public_key)
}
}
pub(crate) fn async_validator_for_signing_alg(
alg: SigningAlg,
) -> Option<Box<dyn AsyncRawSignatureValidator>> {
let validator = validator_for_signing_alg(alg)?;
Some(Box::new(AsyncRawSignatureValidatorAdapter::new(validator)))
}
pub(crate) fn async_validator_for_sig_and_hash_algs(
sig_alg: &Oid,
hash_alg: &Oid,
) -> Option<Box<dyn AsyncRawSignatureValidator>> {
let validator = validator_for_sig_and_hash_algs(sig_alg, hash_alg)?;
Some(Box::new(AsyncRawSignatureValidatorAdapter::new(validator)))
}
pub fn validator_for_signing_alg(alg: SigningAlg) -> Option<Box<dyn RawSignatureValidator>> {
match alg {
SigningAlg::Ed25519 => Some(Box::new(Ed25519Validator {})),
SigningAlg::Ps256 => Some(Box::new(RsaValidator::Ps256)),
SigningAlg::Ps384 => Some(Box::new(RsaValidator::Ps384)),
SigningAlg::Ps512 => Some(Box::new(RsaValidator::Ps512)),
SigningAlg::Es256 => Some(Box::new(EcdsaValidator::Es256)),
SigningAlg::Es384 => Some(Box::new(EcdsaValidator::Es384)),
SigningAlg::Es512 => Some(Box::new(EcdsaValidator::Es512)),
_ => None,
}
}
pub(crate) fn validator_for_sig_and_hash_algs(
sig_alg: &Oid,
hash_alg: &Oid,
) -> Option<Box<dyn RawSignatureValidator>> {
if sig_alg.as_ref() == RSA_OID.as_bytes() {
if hash_alg.as_ref() == SHA256_OID.as_bytes() {
return Some(Box::new(RsaLegacyValidator::Rsa256));
} else if hash_alg.as_ref() == SHA384_OID.as_bytes() {
return Some(Box::new(RsaLegacyValidator::Rsa384));
} else if hash_alg.as_ref() == SHA512_OID.as_bytes() {
return Some(Box::new(RsaLegacyValidator::Rsa512));
}
}
if sig_alg.as_ref() == RSA_PSS_OID.as_bytes() {
if hash_alg.as_ref() == SHA256_OID.as_bytes() {
return Some(Box::new(RsaValidator::Ps256));
} else if hash_alg.as_ref() == SHA384_OID.as_bytes() {
return Some(Box::new(RsaValidator::Ps384));
} else if hash_alg.as_ref() == SHA512_OID.as_bytes() {
return Some(Box::new(RsaValidator::Ps512));
}
}
if sig_alg.as_ref() == EC_PUBLICKEY_OID.as_bytes() {
if hash_alg.as_ref() == SHA256_OID.as_bytes() {
return Some(Box::new(EcdsaValidator::Es256));
} else if hash_alg.as_ref() == SHA384_OID.as_bytes() {
return Some(Box::new(EcdsaValidator::Es384));
} else if hash_alg.as_ref() == SHA512_OID.as_bytes() {
return Some(Box::new(EcdsaValidator::Es512));
}
}
if sig_alg.as_ref() == ED25519_OID.as_bytes() {
return Some(Box::new(Ed25519Validator {}));
}
None
}