Struct tor_llcrypto::pk::curve25519::StaticSecret   
source · [−]pub struct StaticSecret(_);Expand description
A Diffie-Hellman secret key that can be used to compute multiple SharedSecrets.
This type is identical to the EphemeralSecret type, except that the
StaticSecret::diffie_hellman method does not consume the secret key, and the type provides
serialization methods to save and load key material.  This means that the secret may be used
multiple times (but does not have to be).
Warning
If you’re uncertain about whether you should use this, then you likely
should not be using this.  Our strongly recommended advice is to use
EphemeralSecret at all times, as that type enforces at compile-time that
secret keys are never reused, which can have very serious security
implications for many protocols.
Implementations
sourceimpl StaticSecret
 
impl StaticSecret
sourcepub fn diffie_hellman(&self, their_public: &PublicKey) -> SharedSecret
 
pub fn diffie_hellman(&self, their_public: &PublicKey) -> SharedSecret
Perform a Diffie-Hellman key agreement between self and
their_public key to produce a SharedSecret.
sourcepub fn new<T>(csprng: T) -> StaticSecret where
    T: RngCore + CryptoRng, 
 
pub fn new<T>(csprng: T) -> StaticSecret where
    T: RngCore + CryptoRng, 
Generate an x25519 key.
Trait Implementations
sourceimpl Clone for StaticSecret
 
impl Clone for StaticSecret
sourcefn clone(&self) -> StaticSecret
 
fn clone(&self) -> StaticSecret
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source. Read more
sourceimpl Drop for StaticSecret
 
impl Drop for StaticSecret
sourceimpl<'a> From<&'a StaticSecret> for PublicKey
 
impl<'a> From<&'a StaticSecret> for PublicKey
sourcefn from(secret: &'a StaticSecret) -> PublicKey
 
fn from(secret: &'a StaticSecret) -> PublicKey
Given an x25519 StaticSecret key, compute its corresponding PublicKey.
Auto Trait Implementations
impl RefUnwindSafe for StaticSecret
impl Send for StaticSecret
impl Sync for StaticSecret
impl Unpin for StaticSecret
impl UnwindSafe for StaticSecret
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
    T: ?Sized, 
 
impl<T> BorrowMut<T> for T where
    T: ?Sized, 
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToOwned for T where
    T: Clone, 
 
impl<T> ToOwned for T where
    T: Clone, 
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
 
fn clone_into(&self, target: &mut T)
toowned_clone_into)Uses borrowed data to replace owned data, usually by cloning. Read more