Struct pqc_kyber::Ake[][src]

pub struct Ake {
    pub shared_secret: SharedSecret,
    // some fields omitted
}
Expand description

Used for mutually authenticated key exchange between two parties.

Example:

let mut rng = rand::thread_rng();
 
let mut alice = Ake::new();
let mut bob = Ake::new();
 
let alice_keys = keypair(&mut rng);
let bob_keys = keypair(&mut rng);
 
let client_init = alice.client_init(&bob_keys.public, &mut rng);
let server_send = bob.server_receive(client_init, &alice_keys.public, &bob_keys.secret, &mut rng)?;
let client_confirm = alice.client_confirm(server_send, &alice_keys.secret);
 
assert_eq!(alice.shared_secret, bob.shared_secret);

Fields

shared_secret: SharedSecret

The resulting shared secret from a key exchange

Implementations

impl Ake[src]

pub fn new() -> Self[src]

Builds a new AKE struct

let mut kex = Ake::new();

pub fn client_init<R>(&mut self, pubkey: &PublicKey, rng: &mut R) -> AkeSendInit where
    R: CryptoRng + RngCore
[src]

Initiates a Mutually Authenticated Key Exchange.

let mut rng = rand::thread_rng();
let mut alice = Ake::new();
let bob_keys = keypair(&mut rng);
let client_init = alice.client_init(&bob_keys.public, &mut rng);

pub fn server_receive<R>(
    &mut self,
    ake_send_a: AkeSendInit,
    pubkey: &PublicKey,
    secretkey: &SecretKey,
    rng: &mut R
) -> Result<AkeSendResponse, KyberError> where
    R: CryptoRng + RngCore
[src]

Handles and authenticates the output of a client_init() request

let mut alice = Ake::new();
let mut bob = Ake::new();
let alice_keys = keypair(&mut rng);
let bob_keys = keypair(&mut rng);
let client_init = alice.client_init(&bob_keys.public, &mut rng);
let server_send = bob.server_receive(client_init, &alice_keys.public, &bob_keys.secret, &mut rng)?;

pub fn client_confirm(
    &mut self,
    send_b: AkeSendResponse,
    secretkey: &SecretKey
) -> Result<(), KyberError>
[src]

Decapsulates and authenticates the shared secret from the output of server_receive()

let server_send = bob.server_receive(client_init, &alice_keys.public, &bob_keys.secret, &mut rng)?;
let client_confirm = alice.client_confirm(server_send, &alice_keys.secret);
assert_eq!(alice.shared_secret, bob.shared_secret);

Trait Implementations

impl Clone for Ake[src]

fn clone(&self) -> Ake[src]

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)1.0.0[src]

Performs copy-assignment from source. Read more

impl Debug for Ake[src]

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

Formats the value using the given formatter. Read more

impl Default for Ake[src]

fn default() -> Self[src]

Returns the “default value” for a type. Read more

impl PartialEq<Ake> for Ake[src]

fn eq(&self, other: &Ake) -> bool[src]

This method tests for self and other values to be equal, and is used by ==. Read more

fn ne(&self, other: &Ake) -> bool[src]

This method tests for !=.

impl Copy for Ake[src]

impl Eq for Ake[src]

impl StructuralEq for Ake[src]

impl StructuralPartialEq for Ake[src]

Auto Trait Implementations

impl RefUnwindSafe for Ake

impl Send for Ake

impl Sync for Ake

impl Unpin for Ake

impl UnwindSafe for Ake

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

pub fn to_owned(&self) -> T[src]

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

pub fn clone_into(&self, target: &mut T)[src]

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

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

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

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

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

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

Performs the conversion.