wlan_rsn

Struct Authenticator

Source
pub struct Authenticator {
    pub auth_cfg: Config,
    /* private fields */
}

Fields§

§auth_cfg: Config

Implementations§

Source§

impl Authenticator

Source

pub fn new_wpa2psk_ccmp128( nonce_rdr: Arc<NonceReader>, gtk_provider: Arc<Mutex<GtkProvider>>, psk: Psk, s_addr: MacAddr, s_protection: ProtectionInfo, a_addr: MacAddr, a_protection: ProtectionInfo, ) -> Result<Authenticator, Error>

WPA2-PSK CCMP-128 Authenticator which supports 4-Way Handshake. The Authenticator does not support GTK rotations.

Source

pub fn new_wpa3( nonce_rdr: Arc<NonceReader>, gtk_provider: Arc<Mutex<GtkProvider>>, igtk_provider: Arc<Mutex<IgtkProvider>>, ssid: Ssid, password: Vec<u8>, s_addr: MacAddr, s_protection: ProtectionInfo, a_addr: MacAddr, a_protection: ProtectionInfo, ) -> Result<Authenticator, Error>

WPA3 Authenticator which supports 4-Way Handshake. The Authenticator does not support GTK rotations.

Source

pub fn get_negotiated_protection(&self) -> &NegotiatedProtection

Source

pub fn reset(&mut self)

Resets all established Security Associations and invalidates all derived keys in this ESSSA. The Authenticator must be reset or destroyed when the underlying 802.11 association terminates. The replay counter is also reset.

Source

pub fn initiate(&mut self, update_sink: &mut UpdateSink) -> Result<(), Error>

initiate(...) must be called when the Authenticator should start establishing a security association with a client. The Authenticator must always initiate the security association in the current system as EAPOL request frames from clients are not yet supported. This method can be called multiple times to re-initiate the security association, however, calling this method will invalidate all established security associations and their derived keys.

Source

pub fn on_eapol_frame<B: SplitByteSlice>( &mut self, update_sink: &mut UpdateSink, frame: Frame<B>, ) -> Result<(), Error>

Entry point for all incoming EAPOL frames. Incoming frames can be corrupted, invalid or of unsupported types; the Authenticator will filter and drop all unexpected frames. Outbound EAPOL frames, status and key updates will be pushed into the update_sink. The method will return an Error if the frame was invalid.

Source

pub fn on_eapol_conf( &mut self, update_sink: &mut UpdateSink, result: EapolResultCode, ) -> Result<(), Error>

Source

pub fn on_sae_handshake_ind( &mut self, update_sink: &mut UpdateSink, ) -> Result<(), Error>

Source

pub fn on_sae_frame_rx( &mut self, update_sink: &mut UpdateSink, frame: SaeFrame, ) -> Result<(), Error>

Trait Implementations§

Source§

impl Debug for Authenticator

Source§

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

Formats the value using the given formatter. Read more

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
§

impl<T, D> Encode<Ambiguous1, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
§

impl<T, D> Encode<Ambiguous2, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. 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> OptionalField for T
where T: ?Sized,

Source§

const PRESENT: Presence<Self> = _

Source§

const ABSENT: Presence<Self> = _

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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.
§

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

§

fn vzip(self) -> V