diff --git a/plugins/grpc-plugin/src/tls.rs b/plugins/grpc-plugin/src/tls.rs index 545c447b4..18f72e819 100644 --- a/plugins/grpc-plugin/src/tls.rs +++ b/plugins/grpc-plugin/src/tls.rs @@ -96,14 +96,19 @@ fn generate_or_load_identity( // Configure the certificate we want. let subject_alt_names = vec!["cln".to_string(), "localhost".to_string()]; let mut params = rcgen::CertificateParams::new(subject_alt_names)?; - params.is_ca = if parent.is_none() { - rcgen::IsCa::Ca(rcgen::BasicConstraints::Unconstrained) + if parent.is_none() { + params.is_ca = rcgen::IsCa::Ca(rcgen::BasicConstraints::Unconstrained); + params.key_usages.push(rcgen::KeyUsagePurpose::KeyCertSign); } else { - rcgen::IsCa::NoCa - }; + params.is_ca = rcgen::IsCa::NoCa; + params.key_usages.push(rcgen::KeyUsagePurpose::DigitalSignature); + params.key_usages.push(rcgen::KeyUsagePurpose::KeyEncipherment); + params.key_usages.push(rcgen::KeyUsagePurpose::KeyAgreement); + } params .distinguished_name .push(rcgen::DnType::CommonName, name); + params.use_authority_key_identifier_extension = true; let cert = match parent { None => params.self_signed(&keypair), diff --git a/plugins/rest-plugin/src/certs.rs b/plugins/rest-plugin/src/certs.rs index d01c1e55a..e6ab61345 100644 --- a/plugins/rest-plugin/src/certs.rs +++ b/plugins/rest-plugin/src/certs.rs @@ -12,6 +12,8 @@ pub fn generate_certificates(certs_path: &PathBuf, rest_host: &str) -> Result<() "localhost".to_string(), ])?; ca_params.is_ca = rcgen::IsCa::Ca(rcgen::BasicConstraints::Unconstrained); + ca_params.key_usages.push(rcgen::KeyUsagePurpose::KeyCertSign); + ca_params.use_authority_key_identifier_extension = true; let ca_key = KeyPair::generate()?; let ca_cert = ca_params.self_signed(&ca_key)?; @@ -30,6 +32,10 @@ pub fn generate_certificates(certs_path: &PathBuf, rest_host: &str) -> Result<() "localhost".to_string(), ])?; server_params.is_ca = rcgen::IsCa::NoCa; + server_params.key_usages.push(rcgen::KeyUsagePurpose::DigitalSignature); + server_params.key_usages.push(rcgen::KeyUsagePurpose::KeyEncipherment); + server_params.key_usages.push(rcgen::KeyUsagePurpose::KeyAgreement); + server_params.use_authority_key_identifier_extension = true; server_params.distinguished_name = DistinguishedName::new(); server_params .distinguished_name diff --git a/plugins/wss-proxy-plugin/src/certs.rs b/plugins/wss-proxy-plugin/src/certs.rs index 2e56b26dd..b08b7d3e7 100644 --- a/plugins/wss-proxy-plugin/src/certs.rs +++ b/plugins/wss-proxy-plugin/src/certs.rs @@ -18,6 +18,8 @@ pub fn generate_certificates(certs_path: &PathBuf, wss_host: &[String]) -> Resul "localhost".to_string(), ])?; ca_params.is_ca = rcgen::IsCa::Ca(rcgen::BasicConstraints::Unconstrained); + ca_params.key_usages.push(rcgen::KeyUsagePurpose::KeyCertSign); + ca_params.use_authority_key_identifier_extension = true; let ca_key = KeyPair::generate()?; let ca_cert = ca_params.self_signed(&ca_key)?; @@ -36,6 +38,10 @@ pub fn generate_certificates(certs_path: &PathBuf, wss_host: &[String]) -> Resul "localhost".to_string(), ])?; server_params.is_ca = rcgen::IsCa::NoCa; + server_params.key_usages.push(rcgen::KeyUsagePurpose::DigitalSignature); + server_params.key_usages.push(rcgen::KeyUsagePurpose::KeyEncipherment); + server_params.key_usages.push(rcgen::KeyUsagePurpose::KeyAgreement); + server_params.use_authority_key_identifier_extension = true; server_params.distinguished_name = DistinguishedName::new(); server_params .distinguished_name