StaticSecret

Struct StaticSecret 

Source
pub struct StaticSecret { /* private fields */ }
Expand description

X25519 static secret key for key exchange

This key should be generated once and stored securely. For Perfect Forward Secrecy, use ephemeral keys for each session.

Implementations§

Source§

impl StaticSecret

Source

pub fn generate() -> Self

Generate a new random static secret

Source

pub fn from_bytes(bytes: [u8; 32]) -> Self

Create from raw bytes

Source

pub fn public_key(&self) -> PublicKey

Get the corresponding public key

Source

pub fn diffie_hellman(&self, their_public: &PublicKey) -> SharedSecret

Perform Diffie-Hellman key exchange

Source

pub fn to_bytes(&self) -> [u8; 32]

Export as bytes (use with caution - prefer keeping in memory)

Trait Implementations§

Source§

impl Drop for StaticSecret

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

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> 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> Same for T

Source§

type Output = T

Should always be Self
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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V