Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions src/ccsr/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ openssl.workspace = true
reqwest.workspace = true
mz-tls-util = { path = "../tls-util" }
proptest.workspace = true
zeroize.workspace = true
proptest-derive.workspace = true
serde.workspace = true
serde_json.workspace = true
Expand Down
21 changes: 16 additions & 5 deletions src/ccsr/src/tls.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
use serde::{Deserialize, Serialize};

use mz_tls_util::pkcs12der_from_pem;
use zeroize::Zeroize;

/// A [Serde][serde]-enabled wrapper around [`reqwest::Identity`].
///
Expand All @@ -22,14 +23,24 @@ pub struct Identity {
pass: String,
}

impl Zeroize for Identity {
fn zeroize(&mut self) {
self.der.zeroize();
self.pass.zeroize();
}
}

impl Drop for Identity {
fn drop(&mut self) {
self.zeroize();
}
}

impl Identity {
/// Constructs an identity from a PEM-formatted key and certificate using OpenSSL.
pub fn from_pem(key: &[u8], cert: &[u8]) -> Result<Self, openssl::error::ErrorStack> {
let mut archive = pkcs12der_from_pem(key, cert)?;
Ok(Identity {
der: std::mem::take(&mut archive.der),
pass: std::mem::take(&mut archive.pass),
})
let (der, pass) = pkcs12der_from_pem(key, cert)?.into_parts();
Ok(Identity { der, pass })
}

/// Wraps [`reqwest::Identity::from_pkcs12_der`].
Expand Down
5 changes: 2 additions & 3 deletions src/storage-types/src/connections.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2006,9 +2006,8 @@ impl MySqlConnection<InlinedConnection> {
.read_string_in_task_if(in_task, identity.key)
.await?;
let cert = identity.cert.get_string(in_task, secrets_reader).await?;
let mut archive = mz_tls_util::pkcs12der_from_pem(key.as_bytes(), cert.as_bytes())?;
let der = std::mem::take(&mut archive.der);
let pass = std::mem::take(&mut archive.pass);
let (der, pass) =
mz_tls_util::pkcs12der_from_pem(key.as_bytes(), cert.as_bytes())?.into_parts();

// Add client identity to SSLOpts
ssl_opts = ssl_opts.map(|opts| {
Expand Down
9 changes: 9 additions & 0 deletions src/tls-util/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,15 @@ impl Drop for Pkcs12Archive {
}
}

impl Pkcs12Archive {
pub fn into_parts(self) -> (Vec<u8>, String) {
let mut md = std::mem::ManuallyDrop::new(self);
let der = std::mem::take(&mut md.der);
let pass = std::mem::take(&mut md.pass);
(der, pass)
}
}

/// Constructs an identity from a PEM-formatted key and certificate using OpenSSL.
pub fn pkcs12der_from_pem(
key: &[u8],
Expand Down
Loading