rustls::crypto::aws_lc_rs::pq::hybrid

Struct Layout

Source
pub(crate) struct Layout {
    pub(crate) classical_share_len: usize,
    pub(crate) post_quantum_client_share_len: usize,
    pub(crate) post_quantum_server_share_len: usize,
    pub(crate) post_quantum_first: bool,
}

Fields§

§classical_share_len: usize

Length of classical key share.

§post_quantum_client_share_len: usize

Length of post-quantum key share sent by client

§post_quantum_server_share_len: usize

Length of post-quantum key share sent by server

§post_quantum_first: bool

Whether the post-quantum element comes first in shares and secrets.

For dismal and unprincipled reasons, SECP256R1MLKEM768 has the classical element first, while X25519MLKEM768 has it second.

Implementations§

Source§

impl Layout

Source

fn split_received_client_share<'a>( &self, share: &'a [u8], ) -> Option<(&'a [u8], &'a [u8])>

Source

fn split_received_server_share<'a>( &self, share: &'a [u8], ) -> Option<(&'a [u8], &'a [u8])>

Source

fn split<'a>( &self, share: &'a [u8], post_quantum_share_len: usize, ) -> Option<(&'a [u8], &'a [u8])>

Source

fn concat(&self, post_quantum: &[u8], classical: &[u8]) -> Vec<u8>

Trait Implementations§

Source§

impl Clone for Layout

Source§

fn clone(&self) -> Layout

Returns a copy 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 Layout

Source§

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

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

impl Copy for Layout

Auto Trait Implementations§

§

impl Freeze for Layout

§

impl RefUnwindSafe for Layout

§

impl Send for Layout

§

impl Sync for Layout

§

impl Unpin for Layout

§

impl UnwindSafe for Layout

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, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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> 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.