Skip to content

Commit

Permalink
Add support for Ed25519KeyPair::generate
Browse files Browse the repository at this point in the history
  • Loading branch information
skmcgrail committed Nov 5, 2024
1 parent 05f8a25 commit a273cbc
Showing 1 changed file with 36 additions and 1 deletion.
37 changes: 36 additions & 1 deletion aws-lc-rs/src/ed25519.rs
Original file line number Diff line number Diff line change
Expand Up @@ -244,6 +244,31 @@ pub(crate) fn generate_key() -> Result<LcPtr<EVP_PKEY>, ()> {
}

impl Ed25519KeyPair {
/// Generates a new key pair and returns the key pair.
///
/// # Errors
/// `error::Unspecified` if key generation fails.
pub fn generate() -> Result<Self, Unspecified> {
let evp_pkey = generate_key()?;

let mut public_key = [0u8; ED25519_PUBLIC_KEY_LEN];
let mut out_len: usize = ED25519_PUBLIC_KEY_LEN;
if 1 != unsafe {
EVP_PKEY_get_raw_public_key(*evp_pkey.as_const(), public_key.as_mut_ptr(), &mut out_len)
} {
return Err(Unspecified);
}
debug_assert_eq!(public_key.len(), out_len);

Ok(Self {
public_key: PublicKey {
public_key_bytes: public_key,
evp_pkey: evp_pkey.clone(),
},
evp_pkey,
})
}

/// Generates a new key pair and returns the key pair serialized as a
/// PKCS#8 document.
///
Expand Down Expand Up @@ -527,9 +552,19 @@ mod tests {
use crate::ed25519::Ed25519KeyPair;
use crate::encoding::{AsBigEndian, AsDer, Pkcs8V1Der, Pkcs8V2Der, PublicKeyX509Der};
use crate::rand::SystemRandom;
use crate::signature::KeyPair;
use crate::signature::{KeyPair, UnparsedPublicKey, ED25519};
use crate::{hex, test};

#[test]
fn test_generate() {
const MESSAGE: &[u8] = b"test message";
let key_pair = Ed25519KeyPair::generate().unwrap();
let public_key = key_pair.public_key();
let signature = key_pair.sign(MESSAGE);
let unparsed_public_key = UnparsedPublicKey::new(&ED25519, public_key.as_ref());
let _ = unparsed_public_key.verify(MESSAGE, signature.as_ref()).unwrap();
}

#[test]
fn test_generate_pkcs8() {
let rng = SystemRandom::new();
Expand Down

0 comments on commit a273cbc

Please sign in to comment.