# [−][src]Enum sequoia_openpgp::crypto::mpis::PublicKey

Holds a public key.

Provides a typed and structured way of storing multiple MPIs (and the occasional elliptic curve) in packets.

## Variants

`RSA`

RSA public key.

### Fields of **RSA**

`DSA`

NIST DSA public key.

### Fields of **DSA**

`Elgamal`

Elgamal public key.

### Fields of **Elgamal**

`EdDSA`

DJBs "Twisted" Edwards curve DSA public key.

### Fields of **EdDSA**

`ECDSA`

NISTs Elliptic curve DSA public key.

### Fields of **ECDSA**

`ECDH`

Elliptic curve Elgamal public key.

### Fields of **ECDH**

`curve: Curve`

Curve we're using.

`q: MPI`

Public point.

`hash: HashAlgorithm`

Hash algorithm used for key derivation.

`sym: SymmetricAlgorithm`

Algorithm used w/the derived key.

`Unknown`

Unknown number of MPIs for an unknown algorithm.

### Fields of **Unknown**

## Methods

`impl PublicKey`

[src]

`impl PublicKey`

[src]

`pub fn serialized_len(&self) -> usize`

[src]

Number of octets all MPIs of this instance occupy when serialized.

`pub fn bits(&self) -> usize`

[src]

Returns the 'bits' of the public key.

For finite field crypto this returns the size of the field we operate
in, for ECC it returns `Curve::bits()`

. This information is useless and
should not be used to gauge the security of a particular key. This
function exists only because some legacy PGP application
like HKP need it.

## Trait Implementations

`impl Hash for PublicKey`

[src]

`impl Serialize for PublicKey`

[src]

`impl SerializeInto for PublicKey`

[src]

`fn serialized_len(&self) -> usize`

[src]

`fn serialize_into(&self, buf: &mut [u8]) -> Result<usize>`

[src]

`fn to_vec(&self) -> Result<Vec<u8>>`

[src]

Serializes the packet to a vector.

`impl Eq for PublicKey`

[src]

`impl PartialOrd<PublicKey> for PublicKey`

[src]

`fn partial_cmp(&self, other: &PublicKey) -> Option<Ordering>`

[src]

`fn lt(&self, other: &PublicKey) -> bool`

[src]

`fn le(&self, other: &PublicKey) -> bool`

[src]

`fn gt(&self, other: &PublicKey) -> bool`

[src]

`fn ge(&self, other: &PublicKey) -> bool`

[src]

`impl PartialEq<PublicKey> for PublicKey`

[src]

`impl Clone for PublicKey`

[src]

`fn clone(&self) -> PublicKey`

[src]

`fn clone_from(&mut self, source: &Self)`

1.0.0[src]

Performs copy-assignment from `source`

. Read more

`impl Ord for PublicKey`

[src]

`fn cmp(&self, other: &PublicKey) -> Ordering`

[src]

`fn max(self, other: Self) -> Self`

1.21.0[src]

Compares and returns the maximum of two values. Read more

`fn min(self, other: Self) -> Self`

1.21.0[src]

Compares and returns the minimum of two values. Read more

`impl Hash for PublicKey`

[src]

`fn hash<__H: Hasher>(&self, state: &mut __H)`

[src]

`fn hash_slice<H>(data: &[Self], state: &mut H) where`

H: Hasher,

1.3.0[src]

H: Hasher,

Feeds a slice of this type into the given [`Hasher`

]. Read more

`impl Debug for PublicKey`

[src]

`impl Arbitrary for PublicKey`

[src]

## Auto Trait Implementations

## Blanket Implementations

`impl<T> From for T`

[src]

`impl<T, U> Into for T where`

U: From<T>,

[src]

U: From<T>,

`impl<T> ToOwned for T where`

T: Clone,

[src]

T: Clone,

`impl<T, U> TryFrom for T where`

U: Into<T>,

[src]

U: Into<T>,

`type Error = Infallible`

The type returned in the event of a conversion error.

`fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>`

[src]

`impl<T> Borrow for T where`

T: ?Sized,

[src]

T: ?Sized,

`impl<T> BorrowMut for T where`

T: ?Sized,

[src]

T: ?Sized,

`fn borrow_mut(&mut self) -> &mut T`

[src]

`impl<T> Any for T where`

T: 'static + ?Sized,

[src]

T: 'static + ?Sized,

`impl<T, U> TryInto for T where`

U: TryFrom<T>,

[src]

U: TryFrom<T>,