pub struct Utf8StringRef<'a> { /* private fields */ }
Available on crate feature pkcs8 only.
Expand description

ASN.1 UTF8String type.

Supports the full UTF-8 encoding.

Note that the Decode and Encode traits are impl’d for Rust’s str primitive, which decodes/encodes as a Utf8StringRef.

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 PrintableStringRef.

This is a zero-copy reference type which borrows from the input data.

Implementations§

§

impl<'a> Utf8StringRef<'a>

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

Create a new ASN.1 UTF8String.

Trait Implementations§

§

impl<'a> AsRef<[u8]> for Utf8StringRef<'a>

§

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

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

impl<'a> AsRef<str> for Utf8StringRef<'a>

§

fn as_ref(&self) -> &str

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

impl<'a> Clone for Utf8StringRef<'a>

§

fn clone(&self) -> Utf8StringRef<'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
§

impl<'a> Debug for Utf8StringRef<'a>

§

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

Formats the value using the given formatter. Read more
§

impl<'__der, 'a> DecodeValue<'__der> for Utf8StringRef<'a>
where '__der: 'a,

§

fn decode_value<R>( reader: &mut R, header: Header ) -> Result<Utf8StringRef<'a>, Error>
where R: Reader<'__der>,

Attempt to decode this message using the provided Reader.
§

impl<'a> Deref for Utf8StringRef<'a>

§

type Target = StrRef<'a>

The resulting type after dereferencing.
§

fn deref(&self) -> &<Utf8StringRef<'a> as Deref>::Target

Dereferences the value.
§

impl<'a> Display for Utf8StringRef<'a>

§

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

Formats the value using the given formatter. Read more
§

impl<'a> EncodeValue for Utf8StringRef<'a>

§

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

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

fn encode_value(&self, writer: &mut impl Writer) -> Result<(), Error>

Encode value (sans [Tag]+Length header) as ASN.1 DER using the provided Writer.
§

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

Get the Header used to encode this value.
§

impl FixedTag for Utf8StringRef<'_>

§

const TAG: Tag = Tag::Utf8String

ASN.1 tag
§

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

§

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

Converts to this type from the input type.
§

impl<'a> From<Utf8StringRef<'a>> for AnyRef<'a>

§

fn from(utf_string: Utf8StringRef<'a>) -> AnyRef<'a>

Converts to this type from the input type.
§

impl<'a> Ord for Utf8StringRef<'a>

§

fn cmp(&self, other: &Utf8StringRef<'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
§

impl<'a> PartialEq for Utf8StringRef<'a>

§

fn eq(&self, other: &Utf8StringRef<'a>) -> bool

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

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

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

impl<'a> PartialOrd for Utf8StringRef<'a>

§

fn partial_cmp(&self, other: &Utf8StringRef<'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

This method 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

This method 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

This method 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

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

impl<'__der, 'a> TryFrom<&'__der Any> for Utf8StringRef<'a>
where '__der: 'a,

Available on crate feature alloc only.
§

type Error = Error

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

fn try_from(any: &'__der Any) -> Result<Utf8StringRef<'a>, Error>

Performs the conversion.
§

impl<'__der, 'a> TryFrom<AnyRef<'__der>> for Utf8StringRef<'a>
where '__der: 'a,

§

type Error = Error

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

fn try_from(any: AnyRef<'__der>) -> Result<Utf8StringRef<'a>, Error>

Performs the conversion.
§

impl<'a> Copy for Utf8StringRef<'a>

§

impl<'a> Eq for Utf8StringRef<'a>

§

impl<'a> StructuralPartialEq for Utf8StringRef<'a>

Auto Trait Implementations§

§

impl<'a> RefUnwindSafe for Utf8StringRef<'a>

§

impl<'a> Send for Utf8StringRef<'a>

§

impl<'a> Sync for Utf8StringRef<'a>

§

impl<'a> Unpin for Utf8StringRef<'a>

§

impl<'a> UnwindSafe for Utf8StringRef<'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
§

impl<'a, T> Choice<'a> for T
where T: Decode<'a> + FixedTag,

§

fn can_decode(tag: Tag) -> bool

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

impl<'a, T> Decode<'a> for T
where T: DecodeValue<'a> + FixedTag,

§

fn decode<R>(reader: &mut R) -> Result<T, Error>
where R: Reader<'a>,

Attempt to decode this message using the provided decoder.
§

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

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

impl<T> DerOrd for T

§

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

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

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

§

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

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

§

fn encode(&self, writer: &mut impl Writer) -> Result<(), Error>

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

§

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

Encode this value to the provided byte slice, returning a sub-slice containing the encoded message.
§

fn encode_to_vec(&self, buf: &mut Vec<u8>) -> Result<Length, Error>

Available on crate feature alloc only.
Encode this message as ASN.1 DER, appending it to the provided byte vector.
§

fn to_der(&self) -> Result<Vec<u8>, Error>

Available on crate feature alloc only.
Encode this type as DER, returning a byte vector.
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> Same for T

§

type Output = T

Should always be Self
§

impl<T> Tagged for T
where T: FixedTag,

§

fn tag(&self) -> Tag

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

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

§

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

§

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

impl<T> ValueOrd for T
where T: OrdIsValueOrd,

§

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

impl<T> DecodeOwned for T
where T: for<'a> Decode<'a>,