-
Notifications
You must be signed in to change notification settings - Fork 51
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add aws-lc-rs as optional dependency
Export SignatureVerificationAlgorithms backed by it in webpki::aws_lc_rs
- Loading branch information
Showing
4 changed files
with
209 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,164 @@ | ||
use aws_lc_rs::signature; | ||
use pki_types::{AlgorithmIdentifier, InvalidSignature, SignatureVerificationAlgorithm}; | ||
|
||
use crate::signed_data::alg_id; | ||
|
||
// nb. aws-lc-rs has an API that is broadly compatible with *ring*, | ||
// so this is very similar to ring_algs.rs. | ||
|
||
/// A `SignatureVerificationAlgorithm` implemented using aws-lc-rs. | ||
struct AwsLcRsAlgorithm { | ||
public_key_alg_id: AlgorithmIdentifier, | ||
signature_alg_id: AlgorithmIdentifier, | ||
verification_alg: &'static dyn signature::VerificationAlgorithm, | ||
} | ||
|
||
impl SignatureVerificationAlgorithm for AwsLcRsAlgorithm { | ||
fn public_key_alg_id(&self) -> AlgorithmIdentifier { | ||
self.public_key_alg_id | ||
} | ||
|
||
fn signature_alg_id(&self) -> AlgorithmIdentifier { | ||
self.signature_alg_id | ||
} | ||
|
||
fn verify_signature( | ||
&self, | ||
public_key: &[u8], | ||
message: &[u8], | ||
signature: &[u8], | ||
) -> Result<(), InvalidSignature> { | ||
signature::UnparsedPublicKey::new(self.verification_alg, public_key) | ||
.verify(message, signature) | ||
.map_err(|_| InvalidSignature) | ||
} | ||
} | ||
|
||
/// ECDSA signatures using the P-256 curve and SHA-256. | ||
pub static ECDSA_P256_SHA256: &dyn SignatureVerificationAlgorithm = &AwsLcRsAlgorithm { | ||
public_key_alg_id: alg_id::ECDSA_P256, | ||
signature_alg_id: alg_id::ECDSA_SHA256, | ||
verification_alg: &signature::ECDSA_P256_SHA256_ASN1, | ||
}; | ||
|
||
/// ECDSA signatures using the P-256 curve and SHA-384. Deprecated. | ||
pub static ECDSA_P256_SHA384: &dyn SignatureVerificationAlgorithm = &AwsLcRsAlgorithm { | ||
public_key_alg_id: alg_id::ECDSA_P256, | ||
signature_alg_id: alg_id::ECDSA_SHA384, | ||
verification_alg: &signature::ECDSA_P256_SHA384_ASN1, | ||
}; | ||
|
||
/// ECDSA signatures using the P-384 curve and SHA-256. Deprecated. | ||
pub static ECDSA_P384_SHA256: &dyn SignatureVerificationAlgorithm = &AwsLcRsAlgorithm { | ||
public_key_alg_id: alg_id::ECDSA_P384, | ||
signature_alg_id: alg_id::ECDSA_SHA256, | ||
verification_alg: &signature::ECDSA_P384_SHA256_ASN1, | ||
}; | ||
|
||
/// ECDSA signatures using the P-384 curve and SHA-384. | ||
pub static ECDSA_P384_SHA384: &dyn SignatureVerificationAlgorithm = &AwsLcRsAlgorithm { | ||
public_key_alg_id: alg_id::ECDSA_P384, | ||
signature_alg_id: alg_id::ECDSA_SHA384, | ||
verification_alg: &signature::ECDSA_P384_SHA384_ASN1, | ||
}; | ||
|
||
/// RSA PKCS#1 1.5 signatures using SHA-256 for keys of 2048-8192 bits. | ||
pub static RSA_PKCS1_2048_8192_SHA256: &dyn SignatureVerificationAlgorithm = &AwsLcRsAlgorithm { | ||
public_key_alg_id: alg_id::RSA_ENCRYPTION, | ||
signature_alg_id: alg_id::RSA_PKCS1_SHA256, | ||
verification_alg: &signature::RSA_PKCS1_2048_8192_SHA256, | ||
}; | ||
|
||
/// RSA PKCS#1 1.5 signatures using SHA-384 for keys of 2048-8192 bits. | ||
pub static RSA_PKCS1_2048_8192_SHA384: &dyn SignatureVerificationAlgorithm = &AwsLcRsAlgorithm { | ||
public_key_alg_id: alg_id::RSA_ENCRYPTION, | ||
signature_alg_id: alg_id::RSA_PKCS1_SHA384, | ||
verification_alg: &signature::RSA_PKCS1_2048_8192_SHA384, | ||
}; | ||
|
||
/// RSA PKCS#1 1.5 signatures using SHA-512 for keys of 2048-8192 bits. | ||
pub static RSA_PKCS1_2048_8192_SHA512: &dyn SignatureVerificationAlgorithm = &AwsLcRsAlgorithm { | ||
public_key_alg_id: alg_id::RSA_ENCRYPTION, | ||
signature_alg_id: alg_id::RSA_PKCS1_SHA512, | ||
verification_alg: &signature::RSA_PKCS1_2048_8192_SHA512, | ||
}; | ||
|
||
/// RSA PKCS#1 1.5 signatures using SHA-384 for keys of 3072-8192 bits. | ||
pub static RSA_PKCS1_3072_8192_SHA384: &dyn SignatureVerificationAlgorithm = &AwsLcRsAlgorithm { | ||
public_key_alg_id: alg_id::RSA_ENCRYPTION, | ||
signature_alg_id: alg_id::RSA_PKCS1_SHA384, | ||
verification_alg: &signature::RSA_PKCS1_3072_8192_SHA384, | ||
}; | ||
|
||
/// RSA PSS signatures using SHA-256 for keys of 2048-8192 bits and of | ||
/// type rsaEncryption; see [RFC 4055 Section 1.2]. | ||
/// | ||
/// [RFC 4055 Section 1.2]: https://tools.ietf.org/html/rfc4055#section-1.2 | ||
pub static RSA_PSS_2048_8192_SHA256_LEGACY_KEY: &dyn SignatureVerificationAlgorithm = | ||
&AwsLcRsAlgorithm { | ||
public_key_alg_id: alg_id::RSA_ENCRYPTION, | ||
signature_alg_id: alg_id::RSA_PSS_SHA256, | ||
verification_alg: &signature::RSA_PSS_2048_8192_SHA256, | ||
}; | ||
|
||
/// RSA PSS signatures using SHA-384 for keys of 2048-8192 bits and of | ||
/// type rsaEncryption; see [RFC 4055 Section 1.2]. | ||
/// | ||
/// [RFC 4055 Section 1.2]: https://tools.ietf.org/html/rfc4055#section-1.2 | ||
pub static RSA_PSS_2048_8192_SHA384_LEGACY_KEY: &dyn SignatureVerificationAlgorithm = | ||
&AwsLcRsAlgorithm { | ||
public_key_alg_id: alg_id::RSA_ENCRYPTION, | ||
signature_alg_id: alg_id::RSA_PSS_SHA384, | ||
verification_alg: &signature::RSA_PSS_2048_8192_SHA384, | ||
}; | ||
|
||
/// RSA PSS signatures using SHA-512 for keys of 2048-8192 bits and of | ||
/// type rsaEncryption; see [RFC 4055 Section 1.2]. | ||
/// | ||
/// [RFC 4055 Section 1.2]: https://tools.ietf.org/html/rfc4055#section-1.2 | ||
pub static RSA_PSS_2048_8192_SHA512_LEGACY_KEY: &dyn SignatureVerificationAlgorithm = | ||
&AwsLcRsAlgorithm { | ||
public_key_alg_id: alg_id::RSA_ENCRYPTION, | ||
signature_alg_id: alg_id::RSA_PSS_SHA512, | ||
verification_alg: &signature::RSA_PSS_2048_8192_SHA512, | ||
}; | ||
|
||
/// ED25519 signatures according to RFC 8410 | ||
pub static ED25519: &dyn SignatureVerificationAlgorithm = &AwsLcRsAlgorithm { | ||
public_key_alg_id: alg_id::ED25519, | ||
signature_alg_id: alg_id::ED25519, | ||
verification_alg: &signature::ED25519, | ||
}; | ||
|
||
#[cfg(test)] | ||
#[path = "."] | ||
mod tests { | ||
use crate::Error; | ||
|
||
static SUPPORTED_ALGORITHMS_IN_TESTS: &[&dyn super::SignatureVerificationAlgorithm] = &[ | ||
// Reasonable algorithms. | ||
super::ECDSA_P256_SHA256, | ||
super::ECDSA_P384_SHA384, | ||
super::ED25519, | ||
super::RSA_PKCS1_2048_8192_SHA256, | ||
super::RSA_PKCS1_2048_8192_SHA384, | ||
super::RSA_PKCS1_2048_8192_SHA512, | ||
super::RSA_PKCS1_3072_8192_SHA384, | ||
super::RSA_PSS_2048_8192_SHA256_LEGACY_KEY, | ||
super::RSA_PSS_2048_8192_SHA384_LEGACY_KEY, | ||
super::RSA_PSS_2048_8192_SHA512_LEGACY_KEY, | ||
// Algorithms deprecated because they are nonsensical combinations. | ||
super::ECDSA_P256_SHA384, // Truncates digest. | ||
super::ECDSA_P384_SHA256, // Digest is unnecessarily short. | ||
]; | ||
|
||
const UNSUPPORTED_SIGNATURE_ALGORITHM_FOR_RSA_KEY: Error = | ||
Error::UnsupportedSignatureAlgorithmForPublicKey; | ||
|
||
const INVALID_SIGNATURE_FOR_RSA_KEY: Error = Error::InvalidSignatureForPublicKey; | ||
|
||
const OK_IF_RSA_AVAILABLE: Result<(), Error> = Ok(()); | ||
|
||
#[path = "alg_tests.rs"] | ||
mod alg_tests; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters