Trait DnsHandle
pub trait DnsHandle:
'static
+ Clone
+ Send
+ Sync
+ Unpin {
type Response: Stream<Item = Result<DnsResponse, ProtoError>> + Send + Unpin + 'static;
// Required method
fn send<R>(&self, request: R) -> Self::Response
where R: Into<DnsRequest> + Unpin + Send + 'static;
// Provided methods
fn is_verifying_dnssec(&self) -> bool { ... }
fn is_using_edns(&self) -> bool { ... }
fn lookup(&self, query: Query, options: DnsRequestOptions) -> Self::Response { ... }
}
Expand description
A trait for implementing high level functions of DNS.
Required Associated Types§
type Response: Stream<Item = Result<DnsResponse, ProtoError>> + Send + Unpin + 'static
type Response: Stream<Item = Result<DnsResponse, ProtoError>> + Send + Unpin + 'static
The associated response from the response stream, this should resolve to the Response messages
Required Methods§
Provided Methods§
fn is_verifying_dnssec(&self) -> bool
fn is_verifying_dnssec(&self) -> bool
Only returns true if and only if this DNS handle is validating DNSSEC.
If the DnsHandle impl is wrapping other clients, then the correct option is to delegate the question to the wrapped client.
fn is_using_edns(&self) -> bool
fn is_using_edns(&self) -> bool
Allow for disabling EDNS
fn lookup(&self, query: Query, options: DnsRequestOptions) -> Self::Response
fn lookup(&self, query: Query, options: DnsRequestOptions) -> Self::Response
A classic DNS query
This is identical to query
, but instead takes a Query
object.
§Arguments
query
- the query to lookupoptions
- options to use when constructing the message
Dyn Compatibility§
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.