Struct QDns

Source
pub struct QDns<LOC: Sync + Send = SocketBase, TAP: SocketTaps<LOC> = SocketBase, MC: MutexedCaches = IoInterf> { /* private fields */ }
Expand description

A main instance which contains all common logic. All requests for name/host resolutions should be perfomed using this structure.

let dns_req = 
    QDns::<SocketBase, SocketBase, IoInterf>::make_empty(Some(cust.clone()), QuerySetup::default(), cache.clone())
        .await
        .unwrap();

 dns_req.add_request(QType::SOA, "protonmail.com");

This struct is for the async with the user provided interface to the async executor items like sockets, files, etc…

feature = “built_in_async” which s enabled by the feature use_async_tokio.

§Generics

  • LOC - this generic do nothing and needed to overcome the problem of the foreign stucts and traits implemented outside of the crate. “only traits defined in the current crate can be implemented for types defined outside of the crate”. Usually is set to the same type as TAP. By default, it is preset to SocketBase.

  • TAP - a generic which should implement SocketTaps which will be used by the crate. By default, it is pre set to SocketBase.

  • MC - a generic which should implement MutexedCaches which provides the file and mutex funtionality. By default, it is pre set to TokioInterf.

Implementations§

Source§

impl QDns<SocketBase>

Source

pub async fn builtin_make_empty( resolvers: Option<Arc<ResolveConfig>>, opts: QuerySetup, cache: Arc<CachesController<TokioInterf>>, ) -> CDnsResult<QDns<SocketBase, SocketBase, TokioInterf>>

Initializes new empty storage for requests.

In some cases it is good idea to combine different requests, because by default all requests are performed in parallel. But in some cases it is bad idea.

§Arguments
  • resolvers - an Arc ResolveConfig which contains configuration i.e nameservers

  • planned_reqs_len - how many requests are planned

  • opts - QuerySetup additional options or overrides. Use default() for default values.

  • cache - a Arc to CachesController which should be prepared before calling this function.

§Returns

A CDnsResult is returned (Result alias) where:

  • Result::Ok is returned with the new instance.

  • Result::Err is returned with error description. The error may happen during attempt to read resolv config or obtain a cached verion.

Source

pub fn buildin_add_request( &mut self, qtype: QType, req_name: impl Into<QDnsName>, )

Adds a new request to current instance.

§Arguemnts
  • qtype - a QType type of the request

  • req_name - a Into QDnsName which is target. i.e ‘localhost’ or ‘domain.tld’

Source

pub async fn buildin_make_a_aaaa_request( resolvers_opt: Option<Arc<ResolveConfig>>, req_name: impl Into<QDnsName>, opts: QuerySetup, cache: Arc<CachesController<TokioInterf>>, ) -> CDnsResult<Self>

This is helper which makes for you an A, AAAA query. The order of A and AAAA is defined in the ResolveConfig.

Use this function directly. Do not use QDns::make_empty

§Arguments
  • resolvers - an Option value Arc ResolveConfig which can be used to override the system’s resolv.conf

  • req_name - a Into QDnsName which is target i.e ‘localhost’ or ‘domain.tld’

  • opts - QuerySetup additional options or overrides. Use default() for default values.

  • cache - a Arc to CachesController which should be prepared before calling this function.

§Returns

A CDnsResult is returned;

  • Result::Ok - with Self as inner type

  • Result::Err is returned with error description. The error may happen during attempt to read resolv config or obtain a cached verion.

Source§

impl<LOC: Sync + Send, TAP: SocketTaps<LOC>, MC: MutexedCaches> QDns<LOC, TAP, MC>

Source

pub async fn make_empty( resolvers: Option<Arc<ResolveConfig>>, opts: QuerySetup, cache: Arc<CachesController<MC>>, ) -> CDnsResult<QDns<LOC, TAP, MC>>

Initializes new empty storage for requests.

§Arguments
  • resolvers - an Arc ResolveConfig which contains configuration i.e nameservers

  • planned_reqs_len - how many requests are planned

  • opts - QuerySetup additional options or overrides. Use default() for default values.

  • cache - a Arc to CachesController which should be prepared before calling this function.

§Returns

A CDnsResult is returned (Result alias) where:

  • Result::Ok is returned with the new instance.

  • Result::Err is returned with error description. The error may happen during attempt to read resolv config or obtain a cached verion.

Source

pub fn add_request(&mut self, qtype: QType, req_name: impl Into<QDnsName>)

Adds a new request to current instance.

§Arguemnts
  • qtype - a QType type of the request

  • req_name - a Into QDnsName which is target. i.e ‘localhost’ or ‘domain.tld’

Source

pub async fn make_a_aaaa_request( resolvers_opt: Option<Arc<ResolveConfig>>, req_name: impl Into<QDnsName>, opts: QuerySetup, cache: Arc<CachesController<MC>>, ) -> CDnsResult<Self>

This is helper which makes for you an A, AAAA query. The order of A and AAAA is defined in the ResolveConfig.

Use this function directly. Do not use QDns::make_empty

§Arguments
  • resolvers - an Option value Arc ResolveConfig which can be used to override the system’s resolv.conf

  • req_name - a Into QDnsName which is target i.e ‘localhost’ or ‘domain.tld’

  • opts - QuerySetup additional options or overrides. Use default() for default values.

  • cache - a Arc to CachesController which should be prepared before calling this function.

§Returns

A CDnsResult is returned;

  • Result::Ok - with Self as inner type

  • Result::Err is returned with error description. The error may happen during attempt to read resolv config or obtain a cached verion.

Source

pub async fn query(self) -> QDnsQueryResult

Runs the created query/ies consuming the instance.

§Returns

A QDnsQueryResult is returned. It contains a pairs of the request and response result.

Trait Implementations§

Source§

impl<LOC: Clone + Sync + Send, TAP: Clone + SocketTaps<LOC>, MC: Clone + MutexedCaches> Clone for QDns<LOC, TAP, MC>

Source§

fn clone(&self) -> QDns<LOC, TAP, MC>

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<LOC: Debug + Sync + Send, TAP: Debug + SocketTaps<LOC>, MC: Debug + MutexedCaches> Debug for QDns<LOC, TAP, MC>

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<LOC, TAP, MC> Freeze for QDns<LOC, TAP, MC>

§

impl<LOC, TAP, MC> RefUnwindSafe for QDns<LOC, TAP, MC>

§

impl<LOC, TAP, MC> Send for QDns<LOC, TAP, MC>

§

impl<LOC, TAP, MC> Sync for QDns<LOC, TAP, MC>

§

impl<LOC, TAP, MC> Unpin for QDns<LOC, TAP, MC>
where TAP: Unpin, LOC: Unpin,

§

impl<LOC, TAP, MC> UnwindSafe for QDns<LOC, TAP, MC>

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