aboutsummaryrefslogtreecommitdiff
path: root/openssl/src
diff options
context:
space:
mode:
authorSteven Fackler <[email protected]>2016-01-19 19:59:00 -0800
committerSteven Fackler <[email protected]>2016-01-19 19:59:00 -0800
commit50bf7a933b52785ac4b5e4621813fcf28e62ddaf (patch)
treecabb93dce85825b5000af015124f8f5444597ee9 /openssl/src
parentFix should_panic check (diff)
parentx509: impl Clone using references & CRYPTO_add() (diff)
downloadrust-openssl-50bf7a933b52785ac4b5e4621813fcf28e62ddaf.tar.xz
rust-openssl-50bf7a933b52785ac4b5e4621813fcf28e62ddaf.zip
Merge pull request #336 from jmesmon/x509-pky-clone
impl Clone for PKey and X509 by using their 'references' member
Diffstat (limited to 'openssl/src')
-rw-r--r--openssl/src/c_helpers.c8
-rw-r--r--openssl/src/crypto/pkey.rs14
-rw-r--r--openssl/src/x509/mod.rs14
3 files changed, 36 insertions, 0 deletions
diff --git a/openssl/src/c_helpers.c b/openssl/src/c_helpers.c
index 402c36ec..1b48565e 100644
--- a/openssl/src/c_helpers.c
+++ b/openssl/src/c_helpers.c
@@ -7,3 +7,11 @@ void rust_SSL_clone(SSL *ssl) {
void rust_SSL_CTX_clone(SSL_CTX *ctx) {
CRYPTO_add(&ctx->references,1,CRYPTO_LOCK_SSL_CTX);
}
+
+void rust_EVP_PKEY_clone(EVP_PKEY *pkey) {
+ CRYPTO_add(&pkey->references,1,CRYPTO_LOCK_EVP_PKEY);
+}
+
+void rust_X509_clone(X509 *x509) {
+ CRYPTO_add(&x509->references,1,CRYPTO_LOCK_X509);
+}
diff --git a/openssl/src/crypto/pkey.rs b/openssl/src/crypto/pkey.rs
index 9d653c13..934a93ed 100644
--- a/openssl/src/crypto/pkey.rs
+++ b/openssl/src/crypto/pkey.rs
@@ -52,6 +52,10 @@ fn openssl_hash_nid(hash: HashType) -> c_int {
}
}
+extern "C" {
+ fn rust_EVP_PKEY_clone(pkey: *mut ffi::EVP_PKEY);
+}
+
pub struct PKey {
evp: *mut ffi::EVP_PKEY,
parts: Parts,
@@ -600,6 +604,16 @@ impl Drop for PKey {
}
}
+impl Clone for PKey {
+ fn clone(&self) -> Self {
+ unsafe {
+ rust_EVP_PKEY_clone(self.evp);
+ }
+
+ PKey::from_handle(self.evp, self.parts)
+ }
+}
+
#[cfg(test)]
mod tests {
use std::path::Path;
diff --git a/openssl/src/x509/mod.rs b/openssl/src/x509/mod.rs
index ffd478ef..f31de89b 100644
--- a/openssl/src/x509/mod.rs
+++ b/openssl/src/x509/mod.rs
@@ -507,6 +507,20 @@ impl<'ctx> X509<'ctx> {
}
}
+extern "C" {
+ fn rust_X509_clone(x509: *mut ffi::X509);
+}
+
+impl<'ctx> Clone for X509<'ctx> {
+ fn clone(&self) -> X509<'ctx> {
+ unsafe { rust_X509_clone(self.handle) }
+ /* FIXME: given that we now have refcounting control, 'owned' should be uneeded, the 'ctx
+ * is probably also uneeded. We can remove both to condense the x509 api quite a bit
+ */
+ X509::new(self.handle, true)
+ }
+}
+
impl<'ctx> Drop for X509<'ctx> {
fn drop(&mut self) {
if self.owned {