use openssl::ec::EcKey;
use openssl::pkey;
use crate::cert::EC_GROUP_P256;
use crate::Result;
#[derive(Clone, Debug)]
pub(crate) struct AcmeKey {
private_key: EcKey<pkey::Private>,
key_id: Option<String>,
}
impl AcmeKey {
pub(crate) fn new() -> AcmeKey {
let pri_key = EcKey::generate(&*EC_GROUP_P256).expect("EcKey");
Self::from_key(pri_key)
}
pub(crate) fn from_pem(pem: &[u8]) -> Result<AcmeKey> {
let pri_key =
EcKey::private_key_from_pem(pem).map_err(|e| format!("Failed to read PEM: {}", e))?;
Ok(Self::from_key(pri_key))
}
fn from_key(private_key: EcKey<pkey::Private>) -> AcmeKey {
AcmeKey {
private_key,
key_id: None,
}
}
pub(crate) fn to_pem(&self) -> Vec<u8> {
self.private_key
.private_key_to_pem()
.expect("private_key_to_pem")
}
pub(crate) fn private_key(&self) -> &EcKey<pkey::Private> {
&self.private_key
}
pub(crate) fn key_id(&self) -> &str {
self.key_id.as_ref().unwrap()
}
pub(crate) fn set_key_id(&mut self, kid: String) {
self.key_id = Some(kid)
}
}