Struct sec1::EcPrivateKey

source ·
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§

Returns a copy of the value. Read more
Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
Attempt to decode this message using the provided decoder.
Parse Self from the provided DER-encoded byte slice.
Call the provided function with a slice of Encodable trait objects representing the fields of this SEQUENCE. Read more
The type returned in the event of a conversion error.
Performs the conversion.

Auto Trait Implementations§

Blanket Implementations§

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more
Is the provided Tag decodable as a variant of this CHOICE?

Compute the length of this value in bytes when encoded as ASN.1 DER.

Encode this value as ASN.1 DER using the provided Encoder.

Encode this value to the provided byte slice, returning a sub-slice containing the encoded message. Read more
Compute the length of this value (sans [Tag]+Length header) when encoded as ASN.1 DER. Read more
Encode value (sans [Tag]+Length header) as ASN.1 DER using the provided Encoder. Read more
Get the Header used to encode this value.
ASN.1 tag

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Should always be Self
Get the ASN.1 tag that this type is encoded with.
The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning. Read more
Uses borrowed data to replace owned data, usually by cloning. Read more
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.