aboutsummaryrefslogtreecommitdiff
path: root/openssl/src/crypto/rsa.rs
diff options
context:
space:
mode:
Diffstat (limited to 'openssl/src/crypto/rsa.rs')
-rw-r--r--openssl/src/crypto/rsa.rs46
1 files changed, 46 insertions, 0 deletions
diff --git a/openssl/src/crypto/rsa.rs b/openssl/src/crypto/rsa.rs
new file mode 100644
index 00000000..fca94465
--- /dev/null
+++ b/openssl/src/crypto/rsa.rs
@@ -0,0 +1,46 @@
+use ffi;
+use bn::BigNum;
+use std::fmt;
+
+pub struct RSA {
+ rsa_obj : ffi::RSA
+}
+
+impl RSA {
+ // The following getters are unsafe, since BigNum::new_from_ffi fails upon null pointers
+ pub fn n(&self) -> BigNum {
+ unsafe {
+ BigNum::new_from_ffi(self.rsa_obj.n).unwrap()
+ }
+ }
+
+ pub fn d(&self) -> BigNum {
+ unsafe {
+ BigNum::new_from_ffi(self.rsa_obj.d).unwrap()
+ }
+ }
+
+ pub fn e(&self) -> BigNum {
+ unsafe {
+ BigNum::new_from_ffi(self.rsa_obj.e).unwrap()
+ }
+ }
+
+ pub fn p(&self) -> BigNum {
+ unsafe {
+ BigNum::new_from_ffi(self.rsa_obj.p).unwrap()
+ }
+ }
+
+ pub fn q(&self) -> BigNum {
+ unsafe {
+ BigNum::new_from_ffi(self.rsa_obj.q).unwrap()
+ }
+ }
+}
+
+impl fmt::Debug for RSA {
+ fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
+ write!(f, "RSA")
+ }
+}