domain::rdata::rfc1035

Struct Txt

source
pub struct Txt<Octs: ?Sized>(/* private fields */);
Expand description

TXT record data.

TXT records hold descriptive text. While it may appear as a single text, it internally consists of a sequence of one or more character strings. The type holds this sequence in its encoded form, i.e., each character string is at most 255 octets long and preceded by an octet with its length.

The type provides means to iterate over these strings, either as CharStrs via iter_charstrs or as plain octets slices via iter. There is a short cut for the most common case of there being exactly one character string in as_flat_slice. Finally, the two methods text and try_text allow combining the content into one single octets sequence.

The TXT record type is defined in RFC 1035, section 3.3.14.

§Presentation format

TXT record data appears in zone files as the white-space delimited sequence of its constituent character strings. This means that if these strings are not quoted, each “word” results in a character string of its own. Thus, the quoted form of the character string’s presentation format is preferred.

§Display

The Display implementation prints the sequence of character strings in their quoted presentation format separated by a single space.

§Serde support

When the serde feature is enabled, the type supports serialization and deserialization. The format differs for human readable and compact serialization formats.

For human-readable formats, the type serializes into a newtype Txt wrapping a sequence of serialized CharStrs. The deserializer supports a non-canonical form as a single string instead of the sequence. In this case the string is broken up into chunks of 255 octets if it is longer. However, not all format implementations support alternative deserialization based on the encountered type. In particular, serde-json doesn’t, so it will only accept sequences.

For compact formats, the type serializes as a newtype Txt that contains a byte array of the wire format representation of the content.

Implementations§

source§

impl<Octs: FromBuilder> Txt<Octs>

source

pub fn build_from_slice(text: &[u8]) -> Result<Self, TxtAppendError>
where <Octs as FromBuilder>::Builder: EmptyBuilder + AsRef<[u8]> + AsMut<[u8]>,

Creates a new Txt record from a single slice.

If the slice is longer than 255 octets, it will be broken up into multiple character strings where all but the last string will be 255 octets long.

If the slice is longer than 65,535 octets or longer than what fits into the octets type used, an error is returned.

source§

impl<Octs> Txt<Octs>

source

pub fn from_octets(octets: Octs) -> Result<Self, TxtError>
where Octs: AsRef<[u8]>,

Creates new TXT record data from its encoded content.

The octets sequence most contain correctly encoded TXT record data. That is, it must contain a sequence of at least one character string of at most 255 octets each preceded by a length octet. An empty sequence is not allowed.

Returns an error if octets does not contain correctly encoded TXT record data.

source§

impl Txt<[u8]>

source

pub fn from_slice(slice: &[u8]) -> Result<&Self, TxtError>

Creates new TXT record data on an octets slice.

The slice must contain correctly encoded TXT record data, that is a sequence of encoded character strings. See

source§

impl<Octs> Txt<Octs>

source

pub fn parse<'a, Src: Octets<Range<'a> = Octs> + ?Sized>( parser: &mut Parser<'a, Src>, ) -> Result<Self, ParseError>
where Octs: AsRef<[u8]>,

Parses TXT record data from the beginning of a parser.

source

pub fn scan<S: Scanner<Octets = Octs>>( scanner: &mut S, ) -> Result<Self, S::Error>

Scans TXT record data.

source§

impl<Octs: AsRef<[u8]> + ?Sized> Txt<Octs>

source

pub fn iter(&self) -> TxtIter<'_>

Returns an iterator over the character strings as slices.

The returned iterator will always return at least one octets slice.

source

pub fn iter_charstrs(&self) -> TxtCharStrIter<'_>

Returns an iterator over the character strings.

The returned iterator will always return at least one octets slice.

source

pub fn as_flat_slice(&self) -> Option<&[u8]>

Returns the content if it consists of a single character string.

source

pub fn len(&self) -> usize

Returns the length of the TXT record data.

Note that this is the length of the encoded record data and therefore never the length of the text, not even if there is only a single character string – it is still preceded by a length octet.

Note further that TXT record data is not allowed to be empty, so there is no is_empty method.

source

pub fn try_text<T: FromBuilder>( &self, ) -> Result<T, <<T as FromBuilder>::Builder as OctetsBuilder>::AppendError>

Returns the text content.

The method appends the content of each character string to a newly created octets builder. It does not add any delimiters between the character string.

If your octets builder is not space limited, you can use text instead.

source

pub fn text<T: FromBuilder>(&self) -> T

Returns the text content.

The method appends the content of each character string to a newly created octets builder. It does not add any delimiters between the character string.

This method is only available for octets builder types that are not space limited. You can use try_text with all builder types.

Trait Implementations§

source§

impl<Octs, Other> CanonicalOrd<Txt<Other>> for Txt<Octs>
where Octs: AsRef<[u8]>, Other: AsRef<[u8]>,

source§

fn canonical_cmp(&self, other: &Txt<Other>) -> Ordering

Returns the canonical ordering between self and other.
source§

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

Returns whether self is canonically less than other.
source§

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

Returns whether self is canonically less than or equal to other.
source§

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

Returns whether self is canonically greater than other.
source§

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

Returns whether self is canonically greater than or equal to other.
source§

impl<Octs: Clone + ?Sized> Clone for Txt<Octs>

source§

fn clone(&self) -> Txt<Octs>

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<Octs: AsRef<[u8]>> ComposeRecordData for Txt<Octs>

source§

fn rdlen(&self, _compress: bool) -> Option<u16>

Returns the length of the record data if available. Read more
source§

fn compose_rdata<Target: Composer + ?Sized>( &self, target: &mut Target, ) -> Result<(), Target::AppendError>

Appends the wire format of the record data into target.
source§

fn compose_canonical_rdata<Target: Composer + ?Sized>( &self, target: &mut Target, ) -> Result<(), Target::AppendError>

Appends the canonical wire format of the record data into target.
source§

fn compose_len_rdata<Target: Composer + ?Sized>( &self, target: &mut Target, ) -> Result<(), Target::AppendError>

Appends the record data prefixed with its length.
source§

fn compose_canonical_len_rdata<Target: Composer + ?Sized>( &self, target: &mut Target, ) -> Result<(), Target::AppendError>

Appends the record data prefixed with its length.
source§

impl<Octs: AsRef<[u8]>> Debug for Txt<Octs>

source§

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

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

impl<Octs: AsRef<[u8]>> Display for Txt<Octs>

source§

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

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

impl<O, N> From<Txt<O>> for AllRecordData<O, N>

source§

fn from(value: Txt<O>) -> Self

Converts to this type from the input type.
source§

impl<O, N> From<Txt<O>> for ZoneRecordData<O, N>

source§

fn from(value: Txt<O>) -> Self

Converts to this type from the input type.
source§

impl<Octs: AsRef<[u8]>> Hash for Txt<Octs>

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<'a, Octs: AsRef<[u8]>> IntoIterator for &'a Txt<Octs>

source§

type Item = &'a [u8]

The type of the elements being iterated over.
source§

type IntoIter = TxtIter<'a>

Which kind of iterator are we turning this into?
source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more
source§

impl<Octs, SrcOcts> OctetsFrom<Txt<SrcOcts>> for Txt<Octs>
where Octs: OctetsFrom<SrcOcts>,

source§

type Error = <Octs as OctetsFrom<SrcOcts>>::Error

source§

fn try_octets_from(source: Txt<SrcOcts>) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl<Octs: AsRef<[u8]>> Ord for Txt<Octs>

source§

fn cmp(&self, other: &Self) -> 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,

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

impl<'a, Octs> ParseRecordData<'a, Octs> for Txt<Octs::Range<'a>>
where Octs: Octets + ?Sized,

source§

fn parse_rdata( rtype: Rtype, parser: &mut Parser<'a, Octs>, ) -> Result<Option<Self>, ParseError>

Parses the record data. Read more
source§

impl<Octs, Other> PartialEq<Txt<Other>> for Txt<Octs>
where Octs: AsRef<[u8]>, Other: AsRef<[u8]>,

source§

fn eq(&self, other: &Txt<Other>) -> 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<Octs, Other> PartialOrd<Txt<Other>> for Txt<Octs>
where Octs: AsRef<[u8]>, Other: AsRef<[u8]>,

source§

fn partial_cmp(&self, other: &Txt<Other>) -> 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<Octs> RecordData for Txt<Octs>

source§

fn rtype(&self) -> Rtype

Returns the record type associated with this record data instance. Read more
source§

impl<Octs: AsRef<[u8]>> Eq for Txt<Octs>

Auto Trait Implementations§

§

impl<Octs> Freeze for Txt<Octs>
where Octs: Freeze + ?Sized,

§

impl<Octs> RefUnwindSafe for Txt<Octs>
where Octs: RefUnwindSafe + ?Sized,

§

impl<Octs> Send for Txt<Octs>
where Octs: Send + ?Sized,

§

impl<Octs> Sync for Txt<Octs>
where Octs: Sync + ?Sized,

§

impl<Octs> Unpin for Txt<Octs>
where Octs: Unpin + ?Sized,

§

impl<Octs> UnwindSafe for Txt<Octs>
where Octs: UnwindSafe + ?Sized,

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