Skip to content

Commit

Permalink
Add CoreEdDsaPrivateSigningKey::generate
Browse files Browse the repository at this point in the history
  • Loading branch information
gibbz00 committed Jun 3, 2024
1 parent 855ee44 commit 37da235
Showing 1 changed file with 15 additions and 1 deletion.
16 changes: 15 additions & 1 deletion src/core/jwk/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,8 @@ use crate::{
};

use ed25519_dalek::pkcs8::DecodePrivateKey;
use ed25519_dalek::Signer;
use ed25519_dalek::{Signer, SigningKey};
use rand::RngCore;
use rsa::pkcs1::DecodeRsaPrivateKey;
use serde::{Deserialize, Serialize};
use sha2::{Digest, Sha256, Sha384, Sha512};
Expand Down Expand Up @@ -493,6 +494,19 @@ pub struct CoreEdDsaPrivateSigningKey {
key_pair: ed25519_dalek::SigningKey,
}
impl CoreEdDsaPrivateSigningKey {
/// Generate a new `CoreEdDsaPrivateSigningKey`
pub fn generate(kid: Option<JsonWebKeyId>) -> Self {
let mut rng = rand::rngs::OsRng;

let mut secret = ed25519_dalek::SecretKey::default();
rng.fill_bytes(&mut secret);

Self {
kid,
key_pair: SigningKey::from_bytes(&secret),
}
}

/// Converts an EdDSA private key (in PEM format) to a JWK representing its public key.
pub fn from_ed25519_pem(pem: &str, kid: Option<JsonWebKeyId>) -> Result<Self, String> {
Ok(Self {
Expand Down

0 comments on commit 37da235

Please sign in to comment.