pub struct ClientStateMachine<I, R: Rng> { /* private fields */ }
Expand description
The DHCPv6 core state machine.
This struct maintains the state machine for a DHCPv6 client, and expects an imperative shell to drive it by taking necessary actions (e.g. send packets, schedule timers, etc.) and dispatch events (e.g. packets received, timer expired, etc.). All the functions provided by this struct are pure-functional. All state transition functions return a list of actions that the imperative shell should take to complete the transition.
Implementations§
Source§impl<I: Instant, R: Rng> ClientStateMachine<I, R>
impl<I: Instant, R: Rng> ClientStateMachine<I, R>
Sourcepub fn start_stateless(
transaction_id: [u8; 3],
options_to_request: Vec<OptionCode>,
rng: R,
now: I,
) -> (Self, Actions<I>)
pub fn start_stateless( transaction_id: [u8; 3], options_to_request: Vec<OptionCode>, rng: R, now: I, ) -> (Self, Actions<I>)
Starts the client in Stateless mode, as defined in RFC 8415, Section 6.1.
The client exchanges messages with servers to obtain the configuration
information specified in options_to_request
.
Sourcepub fn start_stateful(
transaction_id: [u8; 3],
client_id: ClientDuid,
configured_non_temporary_addresses: HashMap<IAID, HashSet<Ipv6Addr>>,
configured_delegated_prefixes: HashMap<IAID, HashSet<Subnet<Ipv6Addr>>>,
options_to_request: Vec<OptionCode>,
rng: R,
now: I,
) -> (Self, Actions<I>)
pub fn start_stateful( transaction_id: [u8; 3], client_id: ClientDuid, configured_non_temporary_addresses: HashMap<IAID, HashSet<Ipv6Addr>>, configured_delegated_prefixes: HashMap<IAID, HashSet<Subnet<Ipv6Addr>>>, options_to_request: Vec<OptionCode>, rng: R, now: I, ) -> (Self, Actions<I>)
Starts the client in Stateful mode, as defined in RFC 8415, Section 6.2 and RFC 8415, Section 6.3.
The client exchanges messages with server(s) to obtain non-temporary
addresses in configured_non_temporary_addresses
, delegated prefixes in
configured_delegated_prefixes
and the configuration information in
options_to_request
.
pub fn get_dns_servers(&self) -> Vec<Ipv6Addr>
Sourcepub fn handle_timeout(
&mut self,
timeout_type: ClientTimerType,
now: I,
) -> Actions<I>
pub fn handle_timeout( &mut self, timeout_type: ClientTimerType, now: I, ) -> Actions<I>
Handles a timeout event, dispatches based on timeout type.
§Panics
handle_timeout
panics if current state is None.
Sourcepub fn handle_message_receive<B: SplitByteSlice>(
&mut self,
msg: Message<'_, B>,
now: I,
) -> Actions<I>
pub fn handle_message_receive<B: SplitByteSlice>( &mut self, msg: Message<'_, B>, now: I, ) -> Actions<I>
Trait Implementations§
Auto Trait Implementations§
impl<I, R> Freeze for ClientStateMachine<I, R>
impl<I, R> RefUnwindSafe for ClientStateMachine<I, R>where
R: RefUnwindSafe,
I: RefUnwindSafe,
impl<I, R> Send for ClientStateMachine<I, R>
impl<I, R> Sync for ClientStateMachine<I, R>
impl<I, R> Unpin for ClientStateMachine<I, R>
impl<I, R> UnwindSafe for ClientStateMachine<I, R>where
R: UnwindSafe,
I: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more