[−][src]Struct openssl::ec::EcKey  
Public and optional Private key on the given curve
OpenSSL documentation at EC_KEY_new
Methods
impl EcKey<Params>[src] 
impl EcKey<Params>pub fn from_curve_name(nid: Nid) -> Result<EcKey<Params>, ErrorStack>[src] 
pub fn from_curve_name(nid: Nid) -> Result<EcKey<Params>, ErrorStack>Constructs an EcKey corresponding to a known curve.
It will not have an associated public or private key. This kind of key is primarily useful
to be provided to the set_tmp_ecdh methods on Ssl and SslContextBuilder.
OpenSSL documenation at EC_KEY_new_by_curve_name
pub fn from_group(group: &EcGroupRef) -> Result<EcKey<Params>, ErrorStack>[src] 
pub fn from_group(group: &EcGroupRef) -> Result<EcKey<Params>, ErrorStack>Constructs an EcKey corresponding to a curve.
This corresponds to EC_KEY_set_group.
impl EcKey<Public>[src] 
impl EcKey<Public>pub fn from_public_key(
    group: &EcGroupRef, 
    public_key: &EcPointRef
) -> Result<EcKey<Public>, ErrorStack>[src] 
pub fn from_public_key(
    group: &EcGroupRef, 
    public_key: &EcPointRef
) -> Result<EcKey<Public>, ErrorStack>Constructs an EcKey from the specified group with the associated EcPoint, public_key.
This will only have the associated public_key.
Example
use openssl::bn::BigNumContext; use openssl::ec::*; use openssl::nid::Nid; use openssl::pkey::PKey; // get bytes from somewhere, i.e. this will not produce a valid key let public_key: Vec<u8> = vec![]; // create an EcKey from the binary form of a EcPoint let group = EcGroup::from_curve_name(Nid::SECP256K1).unwrap(); let mut ctx = BigNumContext::new().unwrap(); let point = EcPoint::from_bytes(&group, &public_key, &mut ctx).unwrap(); let key = EcKey::from_public_key(&group, &point);
pub fn from_public_key_affine_coordinates(
    group: &EcGroupRef, 
    x: &BigNumRef, 
    y: &BigNumRef
) -> Result<EcKey<Public>, ErrorStack>[src] 
pub fn from_public_key_affine_coordinates(
    group: &EcGroupRef, 
    x: &BigNumRef, 
    y: &BigNumRef
) -> Result<EcKey<Public>, ErrorStack>Constructs a public key from its affine coordinates.
impl EcKey<Private>[src] 
impl EcKey<Private>pub fn generate(group: &EcGroupRef) -> Result<EcKey<Private>, ErrorStack>[src] 
pub fn generate(group: &EcGroupRef) -> Result<EcKey<Private>, ErrorStack>Generates a new public/private key pair on the specified curve.
pub fn from_private_components(
    group: &EcGroupRef, 
    private_number: &BigNumRef, 
    public_key: &EcPointRef
) -> Result<EcKey<Private>, ErrorStack>[src] 
pub fn from_private_components(
    group: &EcGroupRef, 
    private_number: &BigNumRef, 
    public_key: &EcPointRef
) -> Result<EcKey<Private>, ErrorStack>Constructs an public/private key pair given a curve, a private key and a public key point.
pub fn private_key_from_pem(pem: &[u8]) -> Result<EcKey<Private>, ErrorStack>[src] 
pub fn private_key_from_pem(pem: &[u8]) -> Result<EcKey<Private>, ErrorStack>Deserializes a private key from a PEM-encoded ECPrivateKey structure.
The input should have a header of -----BEGIN EC PRIVATE KEY-----.
This corresponds to PEM_read_bio_ECPrivateKey.
pub fn private_key_from_pem_passphrase(
    pem: &[u8], 
    passphrase: &[u8]
) -> Result<EcKey<Private>, ErrorStack>[src] 
pub fn private_key_from_pem_passphrase(
    pem: &[u8], 
    passphrase: &[u8]
) -> Result<EcKey<Private>, ErrorStack>Deserializes a private key from a PEM-encoded encrypted ECPrivateKey structure.
The input should have a header of -----BEGIN EC PRIVATE KEY-----.
This corresponds to PEM_read_bio_ECPrivateKey.
pub fn private_key_from_pem_callback<F>(
    pem: &[u8], 
    callback: F
) -> Result<EcKey<Private>, ErrorStack> where
    F: FnOnce(&mut [u8]) -> Result<usize, ErrorStack>, [src] 
pub fn private_key_from_pem_callback<F>(
    pem: &[u8], 
    callback: F
) -> Result<EcKey<Private>, ErrorStack> where
    F: FnOnce(&mut [u8]) -> Result<usize, ErrorStack>, Deserializes a private key from a PEM-encoded encrypted ECPrivateKey structure.
The callback should fill the password into the provided buffer and return its length.
The input should have a header of -----BEGIN EC PRIVATE KEY-----.
This corresponds to PEM_read_bio_ECPrivateKey.
pub fn private_key_from_der(der: &[u8]) -> Result<EcKey<Private>, ErrorStack>[src] 
pub fn private_key_from_der(der: &[u8]) -> Result<EcKey<Private>, ErrorStack>Decodes a DER-encoded elliptic curve private key structure.
This corresponds to d2i_ECPrivateKey.
Methods from Deref<Target = EcKeyRef<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 ECPrivateKey structure.
The output will have a header of -----BEGIN EC PRIVATE KEY-----.
This corresponds to PEM_write_bio_ECPrivateKey.
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 ECPrivateKey structure.
The output will have a header of -----BEGIN EC PRIVATE KEY-----.
This corresponds to PEM_write_bio_ECPrivateKey.
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 into a DER-encoded ECPrivateKey structure.
This corresponds to i2d_ECPrivateKey.
pub fn private_key(&self) -> &BigNumRef[src] 
pub fn private_key(&self) -> &BigNumRefReturn [EcPoint] associated with the private key
OpenSSL documentation at EC_KEY_get0_private_key
pub fn public_key(&self) -> &EcPointRef[src] 
pub fn public_key(&self) -> &EcPointRefReturns the public key.
OpenSSL documentation at EC_KEY_get0_pubic_key
pub fn group(&self) -> &EcGroupRef[src] 
pub fn group(&self) -> &EcGroupRefReturn [EcGroup] of the EcKey
OpenSSL documentation at EC_KEY_get0_group
pub fn check_key(&self) -> Result<(), ErrorStack>[src] 
pub fn check_key(&self) -> Result<(), ErrorStack>Checks the key for validity.
OpenSSL documenation at EC_KEY_check_key
Trait Implementations
impl<T> Clone for EcKey<T>[src] 
impl<T> Clone for EcKey<T>fn clone(&self) -> EcKey<T>[src] 
fn clone(&self) -> EcKey<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 EcKey<T>[src] 
impl<T> Drop for EcKey<T>impl<T> Sync for EcKey<T>[src] 
impl<T> Sync for EcKey<T>impl<T> AsRef<EcKeyRef<T>> for EcKey<T>[src] 
impl<T> AsRef<EcKeyRef<T>> for EcKey<T>impl<T> Send for EcKey<T>[src] 
impl<T> Send for EcKey<T>impl<T> Deref for EcKey<T>[src] 
impl<T> Deref for EcKey<T>type Target = EcKeyRef<T>
The resulting type after dereferencing.
fn deref(&self) -> &EcKeyRef<T>[src] 
fn deref(&self) -> &EcKeyRef<T>Dereferences the value.
impl<T> DerefMut for EcKey<T>[src] 
impl<T> DerefMut for EcKey<T>impl<T> Borrow<EcKeyRef<T>> for EcKey<T>[src] 
impl<T> Borrow<EcKeyRef<T>> for EcKey<T>impl<T> ForeignType for EcKey<T>[src] 
impl<T> ForeignType for EcKey<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