pub struct EcPrivateKey<'a> {
pub private_key: &'a [u8],
pub parameters: Option<EcParameters>,
pub public_key: Option<&'a [u8]>,
}
Expand description
SEC1 elliptic curve private key.
Described in SEC1: Elliptic Curve Cryptography (Version 2.0) Appendix C.4 (p.108) and also RFC5915 Section 3:
ECPrivateKey ::= SEQUENCE {
version INTEGER { ecPrivkeyVer1(1) } (ecPrivkeyVer1),
privateKey OCTET STRING,
parameters [0] ECParameters {{ NamedCurve }} OPTIONAL,
publicKey [1] BIT STRING OPTIONAL
}
When encoded as PEM (text), keys in this format begin with the following:
-----BEGIN EC PRIVATE KEY-----
Fields§
§private_key: &'a [u8]
Private key data.
parameters: Option<EcParameters>
Elliptic curve parameters.
public_key: Option<&'a [u8]>
Public key data, optionally available if version is V2.
Trait Implementations§
source§impl<'a> Clone for EcPrivateKey<'a>
impl<'a> Clone for EcPrivateKey<'a>
source§fn clone(&self) -> EcPrivateKey<'a>
fn clone(&self) -> EcPrivateKey<'a>
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl<'a> Debug for EcPrivateKey<'a>
impl<'a> Debug for EcPrivateKey<'a>
source§impl<'a> DecodeValue<'a> for EcPrivateKey<'a>
impl<'a> DecodeValue<'a> for EcPrivateKey<'a>
source§impl EncodeValue for EcPrivateKey<'_>
impl EncodeValue for EcPrivateKey<'_>
source§impl PemLabel for EcPrivateKey<'_>
impl PemLabel for EcPrivateKey<'_>
source§impl<'a> TryFrom<&'a [u8]> for EcPrivateKey<'a>
impl<'a> TryFrom<&'a [u8]> for EcPrivateKey<'a>
source§impl TryFrom<&EcPrivateKey<'_>> for SecretDocument
impl TryFrom<&EcPrivateKey<'_>> for SecretDocument
source§impl TryFrom<EcPrivateKey<'_>> for SecretDocument
impl TryFrom<EcPrivateKey<'_>> for SecretDocument
impl<'a> Sequence<'a> for EcPrivateKey<'a>
Auto Trait Implementations§
impl<'a> Freeze for EcPrivateKey<'a>
impl<'a> RefUnwindSafe for EcPrivateKey<'a>
impl<'a> Send for EcPrivateKey<'a>
impl<'a> Sync for EcPrivateKey<'a>
impl<'a> Unpin for EcPrivateKey<'a>
impl<'a> UnwindSafe for EcPrivateKey<'a>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)source§impl<'a, T> Decode<'a> for Twhere
T: DecodeValue<'a> + FixedTag,
impl<'a, T> Decode<'a> for Twhere
T: DecodeValue<'a> + FixedTag,
source§impl<T> DecodePem for Twhere
T: DecodeOwned + PemLabel,
impl<T> DecodePem for Twhere
T: DecodeOwned + PemLabel,
source§impl<T> Encode for Twhere
T: EncodeValue + Tagged,
impl<T> Encode for Twhere
T: EncodeValue + Tagged,
source§fn encoded_len(&self) -> Result<Length, Error>
fn encoded_len(&self) -> Result<Length, Error>
Compute the length of this value in bytes when encoded as ASN.1 DER.
source§fn encode(&self, writer: &mut impl Writer) -> Result<(), Error>
fn encode(&self, writer: &mut impl Writer) -> Result<(), Error>
Encode this value as ASN.1 DER using the provided Writer
.
source§fn encode_to_slice<'a>(&self, buf: &'a mut [u8]) -> Result<&'a [u8], Error>
fn encode_to_slice<'a>(&self, buf: &'a mut [u8]) -> Result<&'a [u8], Error>
Encode this value to the provided byte slice, returning a sub-slice
containing the encoded message.