diff options
| author | Steven Fackler <[email protected]> | 2018-05-13 01:50:13 +0100 |
|---|---|---|
| committer | GitHub <[email protected]> | 2018-05-13 01:50:13 +0100 |
| commit | 5debc1ba5a78963acea2229fd9be5f0e5e0aaa99 (patch) | |
| tree | 038bdf9321c35c96e44ab32a274bde8322de5150 /openssl/src | |
| parent | Merge Ssl impl blocks (diff) | |
| parent | Implement Clone for Rsa (diff) | |
| download | rust-openssl-5debc1ba5a78963acea2229fd9be5f0e5e0aaa99.tar.xz rust-openssl-5debc1ba5a78963acea2229fd9be5f0e5e0aaa99.zip | |
Merge pull request #918 from sfackler/rsa-clone
Implement Clone for Rsa
Diffstat (limited to 'openssl/src')
| -rw-r--r-- | openssl/src/rsa.rs | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/openssl/src/rsa.rs b/openssl/src/rsa.rs index ec1de35f..0ad55b96 100644 --- a/openssl/src/rsa.rs +++ b/openssl/src/rsa.rs @@ -77,6 +77,23 @@ generic_foreign_type_and_impl_send_sync! { pub struct RsaRef<T>; } +impl<T> Clone for Rsa<T> { + fn clone(&self) -> Rsa<T> { + (**self).to_owned() + } +} + +impl<T> ToOwned for RsaRef<T> { + type Owned = Rsa<T>; + + fn to_owned(&self) -> Rsa<T> { + unsafe { + ffi::RSA_up_ref(self.as_ptr()); + Rsa::from_ptr(self.as_ptr()) + } + } +} + impl<T> RsaRef<T> where T: HasPrivate, @@ -845,7 +862,7 @@ mod test { #[test] fn test_pem_pkcs1_padding() { - let keypair = super::Rsa::generate(512).unwrap(); + let keypair = super::Rsa::generate(2048).unwrap(); let pubkey_pem = keypair.public_key_to_pem_pkcs1().unwrap(); let pubkey = super::Rsa::public_key_from_pem_pkcs1(&pubkey_pem).unwrap(); let msg = "foo".as_bytes(); @@ -862,4 +879,10 @@ mod test { assert_eq!(len1, len2); assert_ne!(encrypted1, encrypted2); } + + #[test] + fn clone() { + let key = Rsa::generate(2048).unwrap(); + key.clone(); + } } |