[−][src]Struct openssl::rsa::Rsa  
An RSA key.
Methods
impl Rsa<Public>[src] 
impl Rsa<Public>pub fn from_public_components(
    n: BigNum, 
    e: BigNum
) -> Result<Rsa<Public>, ErrorStack>[src] 
pub fn from_public_components(
    n: BigNum, 
    e: BigNum
) -> Result<Rsa<Public>, ErrorStack>Creates a new RSA key with only public components.
n is the modulus common to both public and private key.
e is the public exponent.
This corresponds to RSA_new and uses RSA_set0_key.
pub fn public_key_from_pem(pem: &[u8]) -> Result<Rsa<Public>, ErrorStack>[src] 
pub fn public_key_from_pem(pem: &[u8]) -> Result<Rsa<Public>, ErrorStack>Decodes a PEM-encoded SubjectPublicKeyInfo structure containing an RSA key.
The input should have a header of -----BEGIN PUBLIC KEY-----.
This corresponds to PEM_read_bio_RSA_PUBKEY.
pub fn public_key_from_pem_pkcs1(pem: &[u8]) -> Result<Rsa<Public>, ErrorStack>[src] 
pub fn public_key_from_pem_pkcs1(pem: &[u8]) -> Result<Rsa<Public>, ErrorStack>Decodes a PEM-encoded PKCS#1 RSAPublicKey structure.
The input should have a header of -----BEGIN RSA PUBLIC KEY-----.
This corresponds to PEM_read_bio_RSAPublicKey.
pub fn public_key_from_der(der: &[u8]) -> Result<Rsa<Public>, ErrorStack>[src] 
pub fn public_key_from_der(der: &[u8]) -> Result<Rsa<Public>, ErrorStack>Decodes a DER-encoded SubjectPublicKeyInfo structure containing an RSA key.
This corresponds to d2i_RSA_PUBKEY.
pub fn public_key_from_der_pkcs1(der: &[u8]) -> Result<Rsa<Public>, ErrorStack>[src] 
pub fn public_key_from_der_pkcs1(der: &[u8]) -> Result<Rsa<Public>, ErrorStack>Decodes a DER-encoded PKCS#1 RSAPublicKey structure.
This corresponds to d2i_RSAPublicKey.
impl Rsa<Private>[src] 
impl Rsa<Private>pub fn from_private_components(
    n: BigNum, 
    e: BigNum, 
    d: BigNum, 
    p: BigNum, 
    q: BigNum, 
    dmp1: BigNum, 
    dmq1: BigNum, 
    iqmp: BigNum
) -> Result<Rsa<Private>, ErrorStack>[src] 
pub fn from_private_components(
    n: BigNum, 
    e: BigNum, 
    d: BigNum, 
    p: BigNum, 
    q: BigNum, 
    dmp1: BigNum, 
    dmq1: BigNum, 
    iqmp: BigNum
) -> Result<Rsa<Private>, ErrorStack>Creates a new RSA key with private components (public components are assumed).
This a convenience method over
Rsa::build(n, e, d)?.set_factors(p, q)?.set_crt_params(dmp1, dmq1, iqmp)?.build()
pub fn generate(bits: u32) -> Result<Rsa<Private>, ErrorStack>[src] 
pub fn generate(bits: u32) -> Result<Rsa<Private>, ErrorStack>Generates a public/private key pair with the specified size.
The public exponent will be 65537.
pub fn private_key_from_pem(pem: &[u8]) -> Result<Rsa<Private>, ErrorStack>[src] 
pub fn private_key_from_pem(pem: &[u8]) -> Result<Rsa<Private>, ErrorStack>Deserializes a private key from a PEM-encoded PKCS#1 RSAPrivateKey structure.
This corresponds to PEM_read_bio_RSAPrivateKey.
pub fn private_key_from_pem_passphrase(
    pem: &[u8], 
    passphrase: &[u8]
) -> Result<Rsa<Private>, ErrorStack>[src] 
pub fn private_key_from_pem_passphrase(
    pem: &[u8], 
    passphrase: &[u8]
) -> Result<Rsa<Private>, ErrorStack>Deserializes a private key from a PEM-encoded encrypted PKCS#1 RSAPrivateKey structure.
This corresponds to PEM_read_bio_RSAPrivateKey.
pub fn private_key_from_pem_callback<F>(
    pem: &[u8], 
    callback: F
) -> Result<Rsa<Private>, ErrorStack> where
    F: FnOnce(&mut [u8]) -> Result<usize, ErrorStack>, [src] 
pub fn private_key_from_pem_callback<F>(
    pem: &[u8], 
    callback: F
) -> Result<Rsa<Private>, ErrorStack> where
    F: FnOnce(&mut [u8]) -> Result<usize, ErrorStack>, Deserializes a private key from a PEM-encoded encrypted PKCS#1 RSAPrivateKey structure.
The callback should fill the password into the provided buffer and return its length.
This corresponds to PEM_read_bio_RSAPrivateKey.
pub fn private_key_from_der(der: &[u8]) -> Result<Rsa<Private>, ErrorStack>[src] 
pub fn private_key_from_der(der: &[u8]) -> Result<Rsa<Private>, ErrorStack>Decodes a DER-encoded PKCS#1 RSAPrivateKey structure.
This corresponds to d2i_RSAPrivateKey.
Methods from Deref<Target = RsaRef<T>>
pub fn private_key_to_pem(&self) -> Result<Vec<u8>, ErrorStack>[src] 
pub fn private_key_to_pem(&self) -> Result<Vec<u8>, ErrorStack>Serializes the private key to a PEM-encoded PKCS#1 RSAPrivateKey structure.
The output will have a header of -----BEGIN RSA PRIVATE KEY-----.
This corresponds to PEM_write_bio_RSAPrivateKey.
pub fn private_key_to_pem_passphrase(
    &self, 
    cipher: Cipher, 
    passphrase: &[u8]
) -> Result<Vec<u8>, ErrorStack>[src] 
pub fn private_key_to_pem_passphrase(
    &self, 
    cipher: Cipher, 
    passphrase: &[u8]
) -> Result<Vec<u8>, ErrorStack>Serializes the private key to a PEM-encoded encrypted PKCS#1 RSAPrivateKey structure.
The output will have a header of -----BEGIN RSA PRIVATE KEY-----.
This corresponds to PEM_write_bio_RSAPrivateKey.
pub fn private_key_to_der(&self) -> Result<Vec<u8>, ErrorStack>[src] 
pub fn private_key_to_der(&self) -> Result<Vec<u8>, ErrorStack>Serializes the private key to a DER-encoded PKCS#1 RSAPrivateKey structure.
This corresponds to i2d_RSAPrivateKey.
pub fn private_decrypt(
    &self, 
    from: &[u8], 
    to: &mut [u8], 
    padding: Padding
) -> Result<usize, ErrorStack>[src] 
pub fn private_decrypt(
    &self, 
    from: &[u8], 
    to: &mut [u8], 
    padding: Padding
) -> Result<usize, ErrorStack>Decrypts data using the private key, returning the number of decrypted bytes.
Panics
Panics if self has no private components, or if to is smaller
than self.size().
pub fn private_encrypt(
    &self, 
    from: &[u8], 
    to: &mut [u8], 
    padding: Padding
) -> Result<usize, ErrorStack>[src] 
pub fn private_encrypt(
    &self, 
    from: &[u8], 
    to: &mut [u8], 
    padding: Padding
) -> Result<usize, ErrorStack>Encrypts data using the private key, returning the number of encrypted bytes.
Panics
Panics if self has no private components, or if to is smaller
than self.size().
pub fn d(&self) -> &BigNumRef[src] 
pub fn d(&self) -> &BigNumRefReturns a reference to the private exponent of the key.
This corresponds to RSA_get0_key.
pub fn p(&self) -> Option<&BigNumRef>[src] 
pub fn p(&self) -> Option<&BigNumRef>Returns a reference to the first factor of the exponent of the key.
This corresponds to RSA_get0_factors.
pub fn q(&self) -> Option<&BigNumRef>[src] 
pub fn q(&self) -> Option<&BigNumRef>Returns a reference to the second factor of the exponent of the key.
This corresponds to RSA_get0_factors.
pub fn dmp1(&self) -> Option<&BigNumRef>[src] 
pub fn dmp1(&self) -> Option<&BigNumRef>Returns a reference to the first exponent used for CRT calculations.
This corresponds to RSA_get0_crt_params.
pub fn dmq1(&self) -> Option<&BigNumRef>[src] 
pub fn dmq1(&self) -> Option<&BigNumRef>Returns a reference to the second exponent used for CRT calculations.
This corresponds to RSA_get0_crt_params.
pub fn iqmp(&self) -> Option<&BigNumRef>[src] 
pub fn iqmp(&self) -> Option<&BigNumRef>Returns a reference to the coefficient used for CRT calculations.
This corresponds to RSA_get0_crt_params.
pub fn public_key_to_pem(&self) -> Result<Vec<u8>, ErrorStack>[src] 
pub fn public_key_to_pem(&self) -> Result<Vec<u8>, ErrorStack>Serializes the public key into a PEM-encoded SubjectPublicKeyInfo structure.
The output will have a header of -----BEGIN PUBLIC KEY-----.
This corresponds to PEM_write_bio_RSA_PUBKEY.
pub fn public_key_to_der(&self) -> Result<Vec<u8>, ErrorStack>[src] 
pub fn public_key_to_der(&self) -> Result<Vec<u8>, ErrorStack>Serializes the public key into a DER-encoded SubjectPublicKeyInfo structure.
This corresponds to i2d_RSA_PUBKEY.
pub fn public_key_to_pem_pkcs1(&self) -> Result<Vec<u8>, ErrorStack>[src] 
pub fn public_key_to_pem_pkcs1(&self) -> Result<Vec<u8>, ErrorStack>Serializes the public key into a PEM-encoded PKCS#1 RSAPublicKey structure.
The output will have a header of -----BEGIN RSA PUBLIC KEY-----.
This corresponds to PEM_write_bio_RSAPublicKey.
pub fn public_key_to_der_pkcs1(&self) -> Result<Vec<u8>, ErrorStack>[src] 
pub fn public_key_to_der_pkcs1(&self) -> Result<Vec<u8>, ErrorStack>Serializes the public key into a DER-encoded PKCS#1 RSAPublicKey structure.
This corresponds to i2d_RSAPublicKey.
pub fn size(&self) -> u32[src] 
pub fn size(&self) -> u32Returns the size of the modulus in bytes.
This corresponds to RSA_size.
pub fn public_decrypt(
    &self, 
    from: &[u8], 
    to: &mut [u8], 
    padding: Padding
) -> Result<usize, ErrorStack>[src] 
pub fn public_decrypt(
    &self, 
    from: &[u8], 
    to: &mut [u8], 
    padding: Padding
) -> Result<usize, ErrorStack>Decrypts data using the public key, returning the number of decrypted bytes.
Panics
Panics if to is smaller than self.size().
pub fn public_encrypt(
    &self, 
    from: &[u8], 
    to: &mut [u8], 
    padding: Padding
) -> Result<usize, ErrorStack>[src] 
pub fn public_encrypt(
    &self, 
    from: &[u8], 
    to: &mut [u8], 
    padding: Padding
) -> Result<usize, ErrorStack>Encrypts data using the public key, returning the number of encrypted bytes.
Panics
Panics if to is smaller than self.size().
pub fn n(&self) -> &BigNumRef[src] 
pub fn n(&self) -> &BigNumRefReturns a reference to the modulus of the key.
This corresponds to RSA_get0_key.
pub fn e(&self) -> &BigNumRef[src] 
pub fn e(&self) -> &BigNumRefReturns a reference to the public exponent of the key.
This corresponds to RSA_get0_key.
Trait Implementations
impl<T> Clone for Rsa<T>[src] 
impl<T> Clone for Rsa<T>fn clone(&self) -> Rsa<T>[src] 
fn clone(&self) -> Rsa<T>Returns a copy of the value. Read more
fn clone_from(&mut self, source: &Self)1.0.0[src] 
fn clone_from(&mut self, source: &Self)Performs copy-assignment from source. Read more
impl<T> Drop for Rsa<T>[src] 
impl<T> Drop for Rsa<T>impl<T> Sync for Rsa<T>[src] 
impl<T> Sync for Rsa<T>impl<T> AsRef<RsaRef<T>> for Rsa<T>[src] 
impl<T> AsRef<RsaRef<T>> for Rsa<T>impl<T> Send for Rsa<T>[src] 
impl<T> Send for Rsa<T>impl<T> Debug for Rsa<T>[src] 
impl<T> Debug for Rsa<T>fn fmt(&self, f: &mut Formatter) -> Result[src] 
fn fmt(&self, f: &mut Formatter) -> ResultFormats the value using the given formatter. Read more
impl<T> Deref for Rsa<T>[src] 
impl<T> Deref for Rsa<T>type Target = RsaRef<T>
The resulting type after dereferencing.
fn deref(&self) -> &RsaRef<T>[src] 
fn deref(&self) -> &RsaRef<T>Dereferences the value.
impl<T> DerefMut for Rsa<T>[src] 
impl<T> DerefMut for Rsa<T>impl<T> Borrow<RsaRef<T>> for Rsa<T>[src] 
impl<T> Borrow<RsaRef<T>> for Rsa<T>impl<T> ForeignType for Rsa<T>[src] 
impl<T> ForeignType for Rsa<T>Blanket Implementations
impl<T> From for T[src] 
impl<T> From for Timpl<T, U> Into for T where
    U: From<T>, [src] 
impl<T, U> Into for T where
    U: From<T>, impl<T> ToOwned for T where
    T: Clone, [src] 
impl<T> ToOwned for T where
    T: Clone, type Owned = T
fn to_owned(&self) -> T[src] 
fn to_owned(&self) -> TCreates owned data from borrowed data, usually by cloning. Read more
fn clone_into(&self, target: &mut T)[src] 
fn clone_into(&self, target: &mut T)🔬 This is a nightly-only experimental API.  (toowned_clone_into)
recently added
Uses borrowed data to replace owned data, usually by cloning. Read more
impl<T, U> TryFrom for T where
    T: From<U>, [src] 
impl<T, U> TryFrom for T where
    T: From<U>, type Error = !
try_from)The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src] 
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>try_from)Performs the conversion.
impl<T> Borrow for T where
    T: ?Sized, [src] 
impl<T> Borrow for T where
    T: ?Sized, impl<T> BorrowMut for T where
    T: ?Sized, [src] 
impl<T> BorrowMut for T where
    T: ?Sized, fn borrow_mut(&mut self) -> &mut T[src] 
fn borrow_mut(&mut self) -> &mut TMutably borrows from an owned value. Read more
impl<T, U> TryInto for T where
    U: TryFrom<T>, [src] 
impl<T, U> TryInto for T where
    U: TryFrom<T>, type Error = <U as TryFrom<T>>::Error
try_from)The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src] 
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>try_from)Performs the conversion.
impl<T> Any for T where
    T: 'static + ?Sized, [src] 
impl<T> Any for T where
    T: 'static + ?Sized, fn get_type_id(&self) -> TypeId[src] 
fn get_type_id(&self) -> TypeId🔬 This is a nightly-only experimental API.  (get_type_id)
this method will likely be replaced by an associated static
Gets the TypeId of self. Read more