Crypto

Struct Crypto 

Source
pub struct Crypto<Data> {
    pub offset: VarInt,
    pub data: Data,
}

Fields§

§offset: VarInt

A variable-length integer specifying the byte offset in the stream for the data in this CRYPTO frame.

§data: Data

The cryptographic message data.

Implementations§

Source§

impl<Data> Crypto<Data>

Source

pub const fn tag(&self) -> u8

Source

pub fn map_data<F: FnOnce(Data) -> Out, Out>(self, map: F) -> Crypto<Out>

Converts the crypto data from one type to another

Source§

impl<Data: EncoderValue> Crypto<Data>

Source

pub fn try_fit(&self, capacity: usize) -> Result<usize, FitError>

Tries to fit the frame into the provided capacity

If ok, the new payload length is returned, otherwise the frame cannot fit.

Trait Implementations§

Source§

impl<Data> AckElicitable for Crypto<Data>

Source§

impl<Data> CongestionControlled for Crypto<Data>

Source§

impl<Data: Debug> Debug for Crypto<Data>

Source§

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

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

impl<'a, Data: DecoderValue<'a>> DecoderParameterizedValue<'a> for Crypto<Data>

Source§

impl<'a, Data: DecoderValueMut<'a>> DecoderParameterizedValueMut<'a> for Crypto<Data>

Source§

impl<Data: EncoderValue> EncoderValue for Crypto<Data>

Source§

fn encode<E: Encoder>(&self, buffer: &mut E)

Encodes the value into the encoder
Source§

fn encode_mut<E>(&mut self, encoder: &mut E)
where E: Encoder,

Encodes the value into the encoder, while potentially mutating the value itself
Source§

fn encoding_size(&self) -> usize

Returns the encoding size with no buffer constrains
Source§

fn encoding_size_for_encoder<E>(&self, encoder: &E) -> usize
where E: Encoder,

Returns the encoding size for the given encoder’s capacity
Source§

fn encode_with_len_prefix<Len, E>(&self, encoder: &mut E)
where Len: TryFrom<usize> + EncoderValue, E: Encoder, Self: Sized, <Len as TryFrom<usize>>::Error: Debug,

Encodes the value into the encoder with a prefix of Len
Source§

fn encode_to_vec(&self) -> Vec<u8>

Source§

impl<'a, AckRanges, Data> From<Crypto<Data>> for Frame<'a, AckRanges, Data>

Source§

fn from(v: Crypto<Data>) -> Frame<'a, AckRanges, Data>

Converts to this type from the input type.
Source§

impl<'a> From<Crypto<DecoderBuffer<'a>>> for CryptoRef<'a>

Source§

fn from(s: Crypto<DecoderBuffer<'a>>) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<Crypto<DecoderBufferMut<'a>>> for CryptoRef<'a>

Source§

fn from(s: Crypto<DecoderBufferMut<'a>>) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<Crypto<DecoderBufferMut<'a>>> for CryptoMut<'a>

Source§

fn from(s: Crypto<DecoderBufferMut<'a>>) -> Self

Converts to this type from the input type.
Source§

impl<Data> IntoEvent<Frame> for &Crypto<Data>
where Data: EncoderValue,

Source§

impl<Data: PartialEq> PartialEq for Crypto<Data>

Source§

fn eq(&self, other: &Crypto<Data>) -> 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<Data> Probing for Crypto<Data>

Source§

impl<Data: Eq> Eq for Crypto<Data>

Source§

impl<Data> StructuralPartialEq for Crypto<Data>

Auto Trait Implementations§

§

impl<Data> Freeze for Crypto<Data>
where Data: Freeze,

§

impl<Data> RefUnwindSafe for Crypto<Data>
where Data: RefUnwindSafe,

§

impl<Data> Send for Crypto<Data>
where Data: Send,

§

impl<Data> Sync for Crypto<Data>
where Data: Sync,

§

impl<Data> Unpin for Crypto<Data>
where Data: Unpin,

§

impl<Data> UnwindSafe for Crypto<Data>
where Data: UnwindSafe,

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> PacketPayloadEncoder for T
where T: EncoderValue,

Source§

fn encoding_size_hint<E>(&mut self, encoder: &E, minimum_len: usize) -> usize
where E: Encoder,

Returns an estimate of the encoding size of the payload. This may be inaccurate from what actually is encoded. Estimates should be less than or equal to what is actually written. Implementations can return 0 to skip encoding.
Source§

fn encode( &mut self, buffer: &mut Buffer<'_>, _minimum_len: usize, _header_len: usize, _tag_len: usize, )

Encodes the payload into the buffer. Implementations should ensure the encoding len is at least the minimum_len, otherwise the packet writing will panic.
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<T, U> Upcast<T> for U
where T: UpcastFrom<U>,

Source§

fn upcast(self) -> T

Source§

impl<T, B> UpcastFrom<Counter<T, B>> for T

Source§

fn upcast_from(value: Counter<T, B>) -> T

Source§

impl<T> FrameTrait for T