rustls::crypto::cipher

Struct InboundOpaqueMessage

Source
pub struct InboundOpaqueMessage<'a> {
    pub typ: ContentType,
    pub version: ProtocolVersion,
    pub payload: BorrowedPayload<'a>,
}
Expand description

A TLS frame, named TLSPlaintext in the standard.

This inbound type borrows its encrypted payload from a buffer elsewhere. It is used for joining and is consumed by decryption.

Fields§

§typ: ContentType§version: ProtocolVersion§payload: BorrowedPayload<'a>

Implementations§

Source§

impl<'a> InboundOpaqueMessage<'a>

Source

pub fn new( typ: ContentType, version: ProtocolVersion, payload: &'a mut [u8], ) -> Self

Construct a new InboundOpaqueMessage from constituent fields.

payload is borrowed.

Source

pub fn into_plain_message(self) -> InboundPlainMessage<'a>

Force conversion into a plaintext message.

This should only be used for messages that are known to be in plaintext. Otherwise, the InboundOpaqueMessage should be decrypted into a PlainMessage using a MessageDecrypter.

Source

pub fn into_plain_message_range( self, range: Range<usize>, ) -> InboundPlainMessage<'a>

Force conversion into a plaintext message.

range restricts the resulting message: this function panics if it is out of range for the underlying message payload.

This should only be used for messages that are known to be in plaintext. Otherwise, the InboundOpaqueMessage should be decrypted into a PlainMessage using a MessageDecrypter.

Source

pub fn into_tls13_unpadded_message( self, ) -> Result<InboundPlainMessage<'a>, Error>

For TLS1.3 (only), checks the length msg.payload is valid and removes the padding.

Returns an error if the message (pre-unpadding) is too long, or the padding is invalid, or the message (post-unpadding) is too long.

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, 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.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 24 bytes