Struct domain::base::iana::rcode::OptRcode

source ·
pub struct OptRcode(/* private fields */);
Expand description

Extended DNS Response Codes for OPT records.

Originally, the response code embedded in the header of each DNS message was four bits long. This code, defined in [RFC 1035], is represented by the Rcode type. The extension mechanism for DNS initially defined in RFC 2671 and updated by RFC 6891 added eight more bits to be stored in the OPT pseudo-resource record. This type represents the complete 12 bit extended response code.

There is a third, 16 bit wide response code for transaction authentication (TSIG) defined in RFC 2845 and represented by the TsigRcode type. The code mostly shares the same name space except for an unfortunate collision in between the BADVERS and BADSIG values. Because of this, we decided to have separate types.

The values for all three response code types are defined in the IANA DNS RCODEs registry. This type is complete as of 2019-01-28.

The 12-bit extended RCODE defined by RFC 6891 stores the lowest 4-bits of the extended RCODE in the main DNS header RCODE field and stores the remaining 8-bits (right shifted by 4-bits) in the OPT record header RCODE field, like so:

NoError:    0 = 0b0000_0000_0000
                            ^^^^ Stored in DNS header RCODE field
                  ^^^^_^^^^      Stored in OPT header RCODE field

FormErr:    1 = 0b0000_0000_0001
                            ^^^^ Stored in DNS header RCODE field
                  ^^^^_^^^^      Stored in OPT header RCODE field

BadVers:   16 = 0b0000_0001_0000
                            ^^^^ Stored in DNS header RCODE field
                  ^^^^_^^^^      Stored in OPT header RCODE field

BadCookie: 23 = 0b0000_0001_0111
                            ^^^^ Stored in DNS header RCODE field
                  ^^^^_^^^^      Stored in OPT header RCODE field

This type offers several functions to ease working with the separate parts and the combined value of an extended RCODE:

Implementations§

source§

impl OptRcode

source

pub const NOERROR: Self = _

No error condition.

(Otherwise known as success.)

Defined in RFC 1035.

source

pub const FORMERR: Self = _

Format error.

The name server was unable to interpret the query.

Defined in RFC 1035.

source

pub const SERVFAIL: Self = _

Server failure.

The name server was unable to process this query due to a problem with the name server.

Defined in RFC 1035.

source

pub const NXDOMAIN: Self = _

Name error.

The domain name given in the query does not exist at the name server.

Defined in RFC 1035.

source

pub const NOTIMP: Self = _

Not implemented.

The name server does not support the requested kind of query.

Defined in RFC 1035.

source

pub const REFUSED: Self = _

Query refused.

The name server refused to perform the operation requested by the query for policy reasons.

Defined in RFC 1035.

source

pub const YXDOMAIN: Self = _

Name exists when it should not.

Returned for an UPDATE query when a domain requested to not exist does in fact exist.

Returned when resolving a DNAME redirection when the resulting name exceeds the length of 255 octets.

Defined in RFC 2136 for the UPDATE query and RFC 6672 for DNAME redirection.

source

pub const YXRRSET: Self = _

RR set exists when it should not.

Returned for an UPDATE query when an RRset requested to not exist does in fact exist.

Defined in RFC 2136.

source

pub const NXRRSET: Self = _

RR set that should exist does not.

Returned for an UPDATE query when an RRset requested to exist does not.

Defined in RFC 2136.

source

pub const NOTAUTH: Self = _

Server not authoritative for zone or client not authorized.

Returned for an UPDATE query when the server is not an authoritative name server for the requested domain.

Returned for queries using TSIG when authorisation failed.

Defined in RFC 2136 for UPDATE and RFC 2845 for TSIG.

source

pub const NOTZONE: Self = _

Name not contained in zone.

A name used in the prerequisite or update section is not within the zone given in the zone section.

Defined in RFC 2136.

source

pub const BADVERS: Self = _

Bad OPT version.

A name server does not implement the EDNS version requested in the OPT record.

Defined in RFC 6891.

source

pub const BADCOOKIE: Self = _

Bad or missing server cookie.

The request contained a COOKIE option either without a server cookie or with a server cookie that did not validate.

Defined in RFC 7873.

source§

impl OptRcode

source

pub const fn checked_from_int(value: u16) -> Option<OptRcode>

Creates an rcode from an integer, returning None if invalid.

The rcode is valid if the upper four bits of value are all zero.

source

pub const fn masked_from_int(value: u16) -> OptRcode

Creates an rcode from an integer, only considering the lower four bits.

This function will ignore the upper four bit of value.

source

pub const fn from_rcode(rcode: Rcode) -> Self

Creates an OPT rcode from a plain rcode.

source

pub const fn to_int(self) -> u16

Returns the integer value for this rcode.

Only the lower 12 bits of the returned octet are used by the rcode. The upper four bits are always zero.

source

pub fn from_parts(rcode: Rcode, ext: u8) -> OptRcode

Creates an extended rcode value from its parts.

source

pub fn to_parts(self) -> (Rcode, u8)

Returns the two parts of an extended rcode value.

source

pub fn rcode(self) -> Rcode

Returns the rcode part of the extended rcode.

source

pub fn ext(self) -> u8

Returns the extended octet of the extended rcode.

source

pub fn is_ext(&self) -> bool

Returns true if the RCODE is extended, false otherwise.

source

pub const fn to_mnemonic(self) -> Option<&'static [u8]>

Returns the mnemonic for this value if there is one.

Trait Implementations§

source§

impl Clone for OptRcode

source§

fn clone(&self) -> OptRcode

Returns a copy 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 Debug for OptRcode

source§

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

Formats the value using the given formatter. Read more
source§

impl Display for OptRcode

source§

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

Formats the value using the given formatter. Read more
source§

impl From<OptRcode> for TsigRcode

source§

fn from(value: OptRcode) -> TsigRcode

Converts to this type from the input type.
source§

impl From<OptRcode> for u16

source§

fn from(value: OptRcode) -> u16

Converts to this type from the input type.
source§

impl From<Rcode> for OptRcode

source§

fn from(value: Rcode) -> OptRcode

Converts to this type from the input type.
source§

impl FromStr for OptRcode

source§

type Err = ()

The associated error which can be returned from parsing.
source§

fn from_str(s: &str) -> Result<Self, Self::Err>

Parses a string s to return a value of this type. Read more
source§

impl Hash for OptRcode

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl Ord for OptRcode

source§

fn cmp(&self, other: &OptRcode) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized + PartialOrd,

Restrict a value to a certain interval. Read more
source§

impl PartialEq for OptRcode

source§

fn eq(&self, other: &OptRcode) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl PartialOrd for OptRcode

source§

fn partial_cmp(&self, other: &OptRcode) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
source§

impl TryFrom<u16> for OptRcode

source§

type Error = InvalidRcode

The type returned in the event of a conversion error.
source§

fn try_from(value: u16) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl Copy for OptRcode

source§

impl Eq for OptRcode

source§

impl StructuralPartialEq for OptRcode

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
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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<Source, Target> OctetsInto<Target> for Source
where Target: OctetsFrom<Source>,

source§

type Error = <Target as OctetsFrom<Source>>::Error

source§

fn try_octets_into( self, ) -> Result<Target, <Source as OctetsInto<Target>>::Error>

Performs the conversion.
source§

fn octets_into(self) -> Target
where Self::Error: Into<Infallible>,

Performs an infallible conversion.
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> 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> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. 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