diff options
| author | Steven Fackler <[email protected]> | 2016-08-10 21:07:41 -0700 |
|---|---|---|
| committer | Steven Fackler <[email protected]> | 2016-08-10 21:07:41 -0700 |
| commit | 5e6b8e68fdcc94c6d7a931925bb32b145caeb3db (patch) | |
| tree | cc7175eb0d2b30b7f7c7279711fab64424587c5a /openssl/src/crypto | |
| parent | Asn1 and Bignum renames (diff) | |
| download | rust-openssl-5e6b8e68fdcc94c6d7a931925bb32b145caeb3db.tar.xz rust-openssl-5e6b8e68fdcc94c6d7a931925bb32b145caeb3db.zip | |
More API cleanup
Diffstat (limited to 'openssl/src/crypto')
| -rw-r--r-- | openssl/src/crypto/rsa.rs | 31 |
1 files changed, 21 insertions, 10 deletions
diff --git a/openssl/src/crypto/rsa.rs b/openssl/src/crypto/rsa.rs index e68b2420..822f305f 100644 --- a/openssl/src/crypto/rsa.rs +++ b/openssl/src/crypto/rsa.rs @@ -1,6 +1,7 @@ use ffi; use std::fmt; use std::ptr; +use std::mem; use libc::{c_int, c_void, c_char, c_ulong}; use bn::{BigNum, BigNumRef}; @@ -26,8 +27,10 @@ impl RSA { pub fn from_public_components(n: BigNum, e: BigNum) -> Result<RSA, ErrorStack> { unsafe { let rsa = try_ssl_null!(ffi::RSA_new()); - (*rsa).n = n.into_raw(); - (*rsa).e = e.into_raw(); + (*rsa).n = n.as_ptr(); + (*rsa).e = e.as_ptr(); + mem::forget(n); + mem::forget(e); Ok(RSA(rsa)) } } @@ -43,14 +46,22 @@ impl RSA { -> Result<RSA, ErrorStack> { unsafe { let rsa = try_ssl_null!(ffi::RSA_new()); - (*rsa).n = n.into_raw(); - (*rsa).e = e.into_raw(); - (*rsa).d = d.into_raw(); - (*rsa).p = p.into_raw(); - (*rsa).q = q.into_raw(); - (*rsa).dmp1 = dp.into_raw(); - (*rsa).dmq1 = dq.into_raw(); - (*rsa).iqmp = qi.into_raw(); + (*rsa).n = n.as_ptr(); + (*rsa).e = e.as_ptr(); + (*rsa).d = d.as_ptr(); + (*rsa).p = p.as_ptr(); + (*rsa).q = q.as_ptr(); + (*rsa).dmp1 = dp.as_ptr(); + (*rsa).dmq1 = dq.as_ptr(); + (*rsa).iqmp = qi.as_ptr(); + mem::forget(n); + mem::forget(e); + mem::forget(d); + mem::forget(p); + mem::forget(q); + mem::forget(dp); + mem::forget(dq); + mem::forget(qi); Ok(RSA(rsa)) } } |