Struct der::asn1::Utf8String

source ·
pub struct Utf8String<'a> { /* private fields */ }
Expand description

ASN.1 UTF8String type.

Supports the full UTF-8 encoding.

Note that the Decodable and Encodable traits are impl’d for Rust’s str primitive, which decodes/encodes as a Utf8String.

You are free to use str instead of this type, however it’s still provided for explicitness in cases where it might be ambiguous with other ASN.1 string encodings such as PrintableString.

Implementations§

source§

impl<'a> Utf8String<'a>

source

pub fn new<T>(input: &'a T) -> Result<Self>
where T: AsRef<[u8]> + ?Sized,

Create a new ASN.1 UTF8String.

source

pub fn as_str(&self) -> &'a str

Borrow the string as a str.

source

pub fn as_bytes(&self) -> &'a [u8]

Borrow the string as bytes.

source

pub fn len(&self) -> Length

Get the length of the inner byte slice.

source

pub fn is_empty(&self) -> bool

Is the inner string empty?

Trait Implementations§

source§

impl AsRef<[u8]> for Utf8String<'_>

source§

fn as_ref(&self) -> &[u8]

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl AsRef<str> for Utf8String<'_>

source§

fn as_ref(&self) -> &str

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl<'a> Clone for Utf8String<'a>

source§

fn clone(&self) -> Utf8String<'a>

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<'a> Debug for Utf8String<'a>

source§

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

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

impl<'a> DecodeValue<'a> for Utf8String<'a>

source§

fn decode_value(decoder: &mut Decoder<'a>, length: Length) -> Result<Self>

Attempt to decode this message using the provided Decoder.
source§

impl<'a> Display for Utf8String<'a>

source§

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

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

impl EncodeValue for Utf8String<'_>

source§

fn value_len(&self) -> Result<Length>

Compute the length of this value (sans Tag+Length header) when encoded as ASN.1 DER.
source§

fn encode_value(&self, encoder: &mut Encoder<'_>) -> Result<()>

Encode value (sans Tag+Length header) as ASN.1 DER using the provided Encoder.
source§

fn header(&self) -> Result<Header>
where Self: Tagged,

Get the Header used to encode this value.
source§

impl FixedTag for Utf8String<'_>

source§

const TAG: Tag = Tag::Utf8String

ASN.1 tag
source§

impl<'a> From<&Utf8String<'a>> for Utf8String<'a>

source§

fn from(value: &Utf8String<'a>) -> Utf8String<'a>

Converts to this type from the input type.
source§

impl<'a> From<Utf8String<'a>> for &'a [u8]

source§

fn from(utf8_string: Utf8String<'a>) -> &'a [u8]

Converts to this type from the input type.
source§

impl<'a> From<Utf8String<'a>> for Any<'a>

source§

fn from(printable_string: Utf8String<'a>) -> Any<'a>

Converts to this type from the input type.
source§

impl<'a> Ord for Utf8String<'a>

source§

fn cmp(&self, other: &Utf8String<'a>) -> 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<'a> PartialEq for Utf8String<'a>

source§

fn eq(&self, other: &Utf8String<'a>) -> 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<'a> PartialOrd for Utf8String<'a>

source§

fn partial_cmp(&self, other: &Utf8String<'a>) -> 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<'a> TryFrom<Any<'a>> for Utf8String<'a>

§

type Error = Error

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

fn try_from(any: Any<'a>) -> Result<Utf8String<'a>>

Performs the conversion.
source§

impl<'a> Copy for Utf8String<'a>

source§

impl<'a> Eq for Utf8String<'a>

source§

impl OrdIsValueOrd for Utf8String<'_>

source§

impl<'a> StructuralPartialEq for Utf8String<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for Utf8String<'a>

§

impl<'a> RefUnwindSafe for Utf8String<'a>

§

impl<'a> Send for Utf8String<'a>

§

impl<'a> Sync for Utf8String<'a>

§

impl<'a> Unpin for Utf8String<'a>

§

impl<'a> UnwindSafe for Utf8String<'a>

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<'a, T> Choice<'a> for T
where T: Decodable<'a> + FixedTag,

source§

fn can_decode(tag: Tag) -> bool

Is the provided Tag decodable as a variant of this CHOICE?
source§

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

source§

default 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> CloneToUninit for T
where T: Copy,

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<'a, T> Decodable<'a> for T
where T: DecodeValue<'a> + FixedTag,

source§

fn decode(decoder: &mut Decoder<'a>) -> Result<T, Error>

Attempt to decode this message using the provided decoder.
source§

fn from_der(bytes: &'a [u8]) -> Result<Self>

Parse Self from the provided DER-encoded byte slice.
source§

impl<T> DerOrd for T

source§

fn der_cmp(&self, other: &T) -> Result<Ordering, Error>

Return an Ordering between self and other when serialized as ASN.1 DER.
source§

impl<T> Encodable for T
where T: EncodeValue + Tagged,

source§

fn encoded_len(&self) -> Result<Length, Error>

Compute the length of this value in bytes when encoded as ASN.1 DER.

source§

fn encode(&self, encoder: &mut Encoder<'_>) -> Result<(), Error>

Encode this value as ASN.1 DER using the provided Encoder.

source§

fn encode_to_slice<'a>(&self, buf: &'a mut [u8]) -> Result<&'a [u8]>

Encode this value to the provided byte slice, returning a sub-slice containing the encoded message.
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> Tagged for T
where T: FixedTag,

source§

fn tag(&self) -> Tag

Get the ASN.1 tag that this type is encoded with.
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

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

§

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<T> ValueOrd for T
where T: OrdIsValueOrd,

source§

fn value_cmp(&self, other: &T) -> Result<Ordering, Error>

Return an Ordering between value portion of TLV-encoded self and other when serialized as ASN.1 DER.