dns_server_watcher

Struct DnsServers

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

The DNS servers learned from all sources.

Implementations§

Source§

impl DnsServers

Source

pub fn set_servers_from_source( &mut self, source: DnsServersUpdateSource, servers: Vec<DnsServer_>, )

Sets the DNS servers discovered from source.

Source

pub fn consolidated(&self) -> Vec<SocketAddress>

Returns a consolidated list of server addresses.

The servers will be returned deduplicated by their address and sorted by the source that each server was learned from. The servers will be sorted in most to least preferred order, with the most preferred server first. The preference of the servers is NDP, DHCPv4, DHCPv6 then Static, where NDP is the most preferred. No ordering is guaranteed across servers from different sources of the same source-kind, but ordering within a source is maintained.

Example, say we had servers SA1 and SA2 set for DHCPv6 interface A, and SB1 and SB2 for DHCPv6 interface B. The consolidated list will be either one of [SA1, SA2, SB1, SB2] or [SB1, SB2, SA1, SA2]. Notice how the ordering across sources (DHCPv6 interface A vs DHCPv6 interface B) is not fixed, but the ordering within the source ([SA1, SA2] for DHCPv6 interface A and [SB1, SB2] for DHCPv6 interface B) is maintained.

Note, if multiple DnsServer_s have the same address but different sources, only the DnsServer_ with the most preferred source will be present in the consolidated list of servers.

Source

pub fn consolidated_dns_servers(&self) -> Vec<DnsServer_>

Returns a consolidated list of DnsServer_ structs.

The servers will be returned deduplicated by their address and sorted by the source that each server was learned from. The servers will be sorted in most to least preferred order, with the most preferred server first. The preference of the servers is NDP, DHCPv4, DHCPv6 then Static, where NDP is the most preferred. No ordering is guaranteed across servers from different sources of the same source-kind, but ordering within a source is maintained.

Example, say we had servers SA1 and SA2 set for DHCPv6 interface A, and SB1 and SB2 for DHCPv6 interface B. The consolidated list will be either one of [SA1, SA2, SB1, SB2] or [SB1, SB2, SA1, SA2]. Notice how the ordering across sources (DHCPv6 interface A vs DHCPv6 interface B) is not fixed, but the ordering within the source ([SA1, SA2] for DHCPv6 interface A and [SB1, SB2] for DHCPv6 interface B) is maintained.

Note, if multiple DnsServer_s have the same address but different sources, only the DnsServer_ with the most preferred source will be present in the consolidated list of servers.

Trait Implementations§

Source§

impl Default for DnsServers

Source§

fn default() -> DnsServers

Returns the “default value” for a type. 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.

§

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, 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<St> WithTag for St

§

fn tagged<T>(self, tag: T) -> Tagged<T, St>

Produce a new stream from this one which yields item tupled with a constant tag