Struct MessageIntegrity

Source
pub struct MessageIntegrity { /* private fields */ }
Expand description

The MessageIntegrity Attribute

Implementations§

Source§

impl MessageIntegrity

Source

pub fn new(hmac: [u8; 20]) -> Self

Create a new MessageIntegrity Attribute

§Examples
let hmac = [0;20];
let integrity = MessageIntegrity::new(hmac);
assert_eq!(integrity.hmac(), &hmac);
Source

pub fn hmac(&self) -> &[u8; 20]

Retrieve the value of the hmac

§Examples
let hmac = [0; 20];
let integrity = MessageIntegrity::new(hmac);
assert_eq!(integrity.hmac(), &hmac);
Source

pub fn compute(data: &[u8], key: &[u8]) -> Result<[u8; 20], StunWriteError>

Compute the Message Integrity value of a chunk of data using a key

Note: use MessageIntegrity::verify for the actual verification to ensure constant time checks of the values to defeat certain types of timing attacks.

§Examples
let key = [40; 10];
let data = [10; 30];
let expected = [209, 217, 210, 15, 124, 78, 87, 181, 211, 233, 165, 180, 44, 142, 81, 233, 138, 186, 184, 97];
let integrity = MessageIntegrity::compute(&data, &key).unwrap();
assert_eq!(integrity, expected);
Source

pub fn verify( data: &[u8], key: &[u8], expected: &[u8; 20], ) -> Result<(), StunParseError>

Compute the Message Integrity value of a chunk of data using a key

§Examples
let key = [40; 10];
let data = [10; 30];
let expected = [209, 217, 210, 15, 124, 78, 87, 181, 211, 233, 165, 180, 44, 142, 81, 233, 138, 186, 184, 97];
assert_eq!(MessageIntegrity::verify(&data, &key, &expected).unwrap(), ());

Trait Implementations§

Source§

impl Attribute for MessageIntegrity

Source§

fn get_type(&self) -> AttributeType

Retrieve the type of an Attribute.
Source§

fn length(&self) -> u16

Retrieve the length of an Attribute. This is not the padded length as stored in a Message and does not include the size of the attribute header.
Source§

impl AttributeFromRaw<'_> for MessageIntegrity

Source§

fn from_raw_ref(raw: &RawAttribute<'_>) -> Result<Self, StunParseError>
where Self: Sized,

Produce an Attribute from a RawAttribute
Source§

fn from_raw(raw: RawAttribute<'a>) -> Result<Self, StunParseError>
where Self: Sized,

Produce an Attribute from a RawAttribute
Source§

impl AttributeStaticType for MessageIntegrity

Source§

impl AttributeWrite for MessageIntegrity

Source§

fn to_raw(&self) -> RawAttribute<'_>

Produce a RawAttribute from this Attribute
Source§

fn write_into_unchecked(&self, dest: &mut [u8])

Write attribute to the provided destination buffer. Read more
Source§

impl Clone for MessageIntegrity

Source§

fn clone(&self) -> MessageIntegrity

Returns a duplicate 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 MessageIntegrity

Source§

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

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

impl Display for MessageIntegrity

Source§

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

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

impl PartialEq for MessageIntegrity

Source§

fn eq(&self, other: &MessageIntegrity) -> 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 TryFrom<&RawAttribute<'_>> for MessageIntegrity

Source§

type Error = StunParseError

The type returned in the event of a conversion error.
Source§

fn try_from(raw: &RawAttribute<'_>) -> Result<Self, Self::Error>

Performs the conversion.
Source§

impl Eq for MessageIntegrity

Source§

impl StructuralPartialEq for MessageIntegrity

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<A> AttributeExt for A
where A: Attribute + ?Sized,

Source§

fn padded_len(&self) -> usize

The length in bytes of an Attribute as stored in a Message including any padding and the attribute header.
Source§

impl<A> AttributeWriteExt for A
where A: AttributeWrite + ?Sized,

Source§

fn write_header(&self, dest: &mut [u8]) -> Result<usize, StunWriteError>

Write the 4 byte attribute header into the provided destination buffer returning the number of bytes written, or an error.
Source§

fn write_header_unchecked(&self, dest: &mut [u8]) -> usize

Write the 4 byte attribute header into the provided destination buffer returning the number of bytes written. Read more
Source§

fn write_into(&self, dest: &mut [u8]) -> Result<usize, StunWriteError>

Write this attribute into the provided destination buffer returning the number of bytes written, or an error.
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, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> Same for T

Source§

type Output = T

Should always be Self
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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more