Struct RecursiveAuthority

Source
pub struct RecursiveAuthority { /* private fields */ }
Available on crate feature recursor only.
Expand description

An authority that performs recursive resolutions.

This uses the hickory-recursor crate for resolving requests.

Implementations§

Source§

impl RecursiveAuthority

Source

pub async fn try_from_config( origin: Name, _zone_type: ZoneType, config: &RecursiveConfig, root_dir: Option<&Path>, ) -> Result<Self, String>

Read the Authority for the origin from the specified configuration

Trait Implementations§

Source§

impl Authority for RecursiveAuthority

Source§

fn zone_type(&self) -> ZoneType

Always External

Source§

fn is_axfr_allowed(&self) -> bool

Always false for Forward zones

Source§

fn origin(&self) -> &LowerName

Get the origin of this zone, i.e. example.com is the origin for www.example.com

In the context of a forwarder, this is either a zone which this forwarder is associated, or ., the root zone for all zones. If this is not the root zone, then it will only forward for lookups which match the given zone name.

Source§

fn lookup<'life0, 'life1, 'async_trait>( &'life0 self, name: &'life1 LowerName, rtype: RecordType, lookup_options: LookupOptions, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Self::Lookup>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Forwards a lookup given the resolver configuration for this Forwarded zone

Source§

type Lookup = RecursiveLookup

Result of a lookup
Source§

fn can_validate_dnssec(&self) -> bool

Whether the authority can perform DNSSEC validation
Source§

fn update<'life0, 'life1, 'async_trait>( &'life0 self, _update: &'life1 MessageRequest, ) -> Pin<Box<dyn Future<Output = UpdateResult<bool>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Perform a dynamic update of a zone
Source§

fn search<'life0, 'life1, 'async_trait>( &'life0 self, request_info: RequestInfo<'life1>, lookup_options: LookupOptions, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Self::Lookup>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Using the specified query, perform a lookup against this zone. Read more
Source§

fn get_nsec_records<'life0, 'life1, 'async_trait>( &'life0 self, _name: &'life1 LowerName, _lookup_options: LookupOptions, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Self::Lookup>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Return the NSEC records based on the given name Read more
Source§

fn get_nsec3_records<'life0, 'life1, 'async_trait>( &'life0 self, _info: Nsec3QueryInfo<'life1>, _lookup_options: LookupOptions, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Self::Lookup>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Available on crate feature __dnssec only.
Return the NSEC3 records based on the information available for a query.
Source§

fn nx_proof_kind(&self) -> Option<&NxProofKind>

Available on crate feature __dnssec only.
Returns the kind of non-existence proof used for this zone.
Source§

fn consult<'life0, 'life1, 'async_trait>( &'life0 self, _name: &'life1 LowerName, _rtype: RecordType, _lookup_options: LookupOptions, last_result: LookupControlFlow<Box<dyn LookupObject>>, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Box<dyn LookupObject>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Consulting lookup for all Resource Records matching the given Name and RecordType. This will be called in a chained authority configuration after an authority in the chain has returned a lookup with a LookupControlFlow::Continue action. Every other authority in the chain will be called via this consult method, until one either returns a LookupControlFlow::Break action, or all authorities have been consulted. The authority that generated the primary lookup (the one returned via ‘lookup’) will not be consulted. Read more
Source§

fn ns<'life0, 'async_trait>( &'life0 self, lookup_options: LookupOptions, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Self::Lookup>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Get the NS, NameServer, record for the zone
Source§

fn soa<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Self::Lookup>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Returns the SOA of the authority. Read more
Source§

fn soa_secure<'life0, 'async_trait>( &'life0 self, lookup_options: LookupOptions, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Self::Lookup>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Returns the SOA record for the zone

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<A, L> AuthorityObject for A
where A: Authority<Lookup = L> + Send + Sync + 'static, L: LookupObject + Send + Sync + 'static,

Source§

fn zone_type(&self) -> ZoneType

What type is this zone

Source§

fn is_axfr_allowed(&self) -> bool

Return true if AXFR is allowed

Source§

fn can_validate_dnssec(&self) -> bool

Whether the authority can perform DNSSEC validation

Source§

fn update<'life0, 'life1, 'async_trait>( &'life0 self, update: &'life1 MessageRequest, ) -> Pin<Box<dyn Future<Output = Result<bool, ResponseCode>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, A: 'async_trait,

Perform a dynamic update of a zone

Source§

fn origin(&self) -> &LowerName

Get the origin of this zone, i.e. example.com is the origin for www.example.com

Source§

fn lookup<'life0, 'life1, 'async_trait>( &'life0 self, name: &'life1 LowerName, rtype: RecordType, lookup_options: LookupOptions, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Box<dyn LookupObject>>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, A: 'async_trait,

Looks up all Resource Records matching the given Name and RecordType.

§Arguments
  • name - The name to look up.
  • rtype - The RecordType to look up. RecordType::ANY will return all records matching name. RecordType::AXFR will return all record types except RecordType::SOA due to the requirements that on zone transfers the RecordType::SOA must both precede and follow all other records.
  • lookup_options - Query-related lookup options (e.g., DNSSEC DO bit, supported hash algorithms, etc.)
§Return value

A LookupControlFlow containing the lookup that should be returned to the client.

Source§

fn consult<'life0, 'life1, 'async_trait>( &'life0 self, name: &'life1 LowerName, rtype: RecordType, lookup_options: LookupOptions, last_result: LookupControlFlow<Box<dyn LookupObject>>, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Box<dyn LookupObject>>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, A: 'async_trait,

Consulting lookup for all Resource Records matching the given Name and RecordType. This will be called in a chained authority configuration after an authority in the chain has returned a lookup with a LookupControlFlow::Continue action. Every other authority in the chain will be called via this consult method, until one either returns a LookupControlFlow::Break action, or all authorities have been consulted. The authority that generated the primary lookup (the one returned via ‘lookup’) will not be consulted.

§Arguments
  • name - The name to look up.
  • rtype - The RecordType to look up. RecordType::ANY will return all records matching name. RecordType::AXFR will return all record types except RecordType::SOA due to the requirements that on zone transfers the RecordType::SOA must both precede and follow all other records.
  • lookup_options - Query-related lookup options (e.g., DNSSEC DO bit, supported hash algorithms, etc.)
  • last_result - The lookup returned by a previous authority in a chained configuration. If a subsequent authority does not modify this lookup, it will be returned to the client after consulting all authorities in the chain.
§Return value

A LookupControlFlow containing the lookup that should be returned to the client. This can be the same last_result that was passed in, or a new lookup, depending on the logic of the authority in question.

Source§

fn search<'life0, 'life1, 'async_trait>( &'life0 self, request_info: RequestInfo<'life1>, lookup_options: LookupOptions, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Box<dyn LookupObject>>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, A: 'async_trait,

Using the specified query, perform a lookup against this zone.

§Arguments
  • request_info - the query to perform the lookup with.
  • lookup_options - Query-related lookup options (e.g., DNSSEC DO bit, supported hash algorithms, etc.)
§Return value

A LookupControlFlow containing the lookup that should be returned to the client.

Source§

fn get_nsec_records<'life0, 'life1, 'async_trait>( &'life0 self, name: &'life1 LowerName, lookup_options: LookupOptions, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Box<dyn LookupObject>>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, A: 'async_trait,

Return the NSEC records based on the given name

§Arguments
  • name - given this name (i.e. the lookup name), return the NSEC record that is less than this
  • lookup_options - Query-related lookup options (e.g., DNSSEC DO bit, supported hash algorithms, etc.)
Source§

fn get_nsec3_records<'life0, 'life1, 'async_trait>( &'life0 self, info: Nsec3QueryInfo<'life1>, lookup_options: LookupOptions, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Box<dyn LookupObject>>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, A: 'async_trait,

Available on crate feature __dnssec only.

Return the NSEC3 records based on the given query information.

Source§

fn nx_proof_kind(&self) -> Option<&NxProofKind>

Available on crate feature __dnssec only.

Returns the kind of non-existence proof used for this zone.

Source§

fn ns<'life0, 'async_trait>( &'life0 self, lookup_options: LookupOptions, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Box<dyn LookupObject>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Get the NS, NameServer, record for the zone
Source§

fn soa<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Box<dyn LookupObject>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Returns the SOA of the authority. Read more
Source§

fn soa_secure<'life0, 'async_trait>( &'life0 self, lookup_options: LookupOptions, ) -> Pin<Box<dyn Future<Output = LookupControlFlow<Box<dyn LookupObject>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Returns the SOA record for the zone
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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

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

Initializes a with the given initializer. Read more
Source§

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

Dereferences the given pointer. Read more
Source§

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

Mutably dereferences the given pointer. Read more
Source§

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.
Source§

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

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,

Source§

impl<T> MaybeSendSync for T