Ecdh

Struct Ecdh 

Source
pub struct Ecdh(/* private fields */);

Implementations§

Source§

impl Ecdh

Source

pub fn new(cipher_suite: CipherSuite) -> Option<Self>

Methods from Deref<Target = Curve>§

Source

pub fn secret_key_size(&self) -> usize

Returns the amount of bytes of a secret key using this curve

Source

pub fn public_key_size(&self) -> usize

Source

pub fn hpke_sampling_method(&self) -> SamplingMethod

Trait Implementations§

Source§

impl Clone for Ecdh

Source§

fn clone(&self) -> Ecdh

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for Ecdh

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Deref for Ecdh

Source§

type Target = Curve

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl DhType for Ecdh

Source§

type Error = EcdhKemError

Source§

fn dh( &self, secret_key: &HpkeSecretKey, public_key: &HpkePublicKey, ) -> Result<Vec<u8>, Self::Error>

Source§

fn to_public( &self, secret_key: &HpkeSecretKey, ) -> Result<HpkePublicKey, Self::Error>

Outputs the public key corresponding to the given secret key bytes. If the secret key is malformed, the function should return an error.
Source§

fn generate(&self) -> Result<(HpkeSecretKey, HpkePublicKey), Self::Error>

Generate a fresh key pair. This is the only place where randomness is used in this module. The function could be implemented in the same way as derive with random ikm, but it could also be implemented directly with a crypto provider like OpenSSL.
Source§

fn bitmask_for_rejection_sampling(&self) -> SamplingMethod

If the output is Some(bitmask), then the Kem::derive function will generate the secret key by rejection sampling over random byte sequences with bitmask applied to the most significant byte. Read more
Source§

fn public_key_validate(&self, key: &HpkePublicKey) -> Result<(), Self::Error>

Source§

fn secret_key_size(&self) -> usize

Source§

fn public_key_size(&self) -> usize

Source§

impl PartialEq for Ecdh

Source§

fn eq(&self, other: &Ecdh) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for Ecdh

Source§

impl StructuralPartialEq for Ecdh

Auto Trait Implementations§

§

impl Freeze for Ecdh

§

impl RefUnwindSafe for Ecdh

§

impl Send for Ecdh

§

impl Sync for Ecdh

§

impl Unpin for Ecdh

§

impl UnwindSafe for Ecdh

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

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

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

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

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.