[−][src]Enum biscuit::StringOrUri
Represents a choice between a URI or an arbitrary string. Both variants will serialize to a string. According to RFC 7519, any string containing the ":" character will be deserialized as a URL. Any invalid URLs will be treated as a deserialization failure. The URL is parsed according to the URL Standard which supersedes RFC 3986 as required in the JWT RFC.
Examples
extern crate biscuit; #[macro_use] extern crate serde_derive; extern crate serde_json; use std::str::FromStr; use biscuit::{SingleOrMultiple, StringOrUri}; #[derive(Debug, Eq, PartialEq, Serialize, Deserialize)] struct SingleOrMultipleStringOrUris { values: SingleOrMultiple<StringOrUri>, } let multiple = SingleOrMultipleStringOrUris { values: SingleOrMultiple::Multiple(vec![FromStr::from_str("foo").unwrap(), FromStr::from_str("https://www.bar.com/").unwrap(), FromStr::from_str("http://baz/").unwrap()]), }; let expected_json = r#"{"values":["foo","https://www.bar.com/","http://baz/"]}"#; let serialized = serde_json::to_string(&multiple).unwrap(); assert_eq!(expected_json, serialized); let deserialized: SingleOrMultipleStringOrUris = serde_json::from_str(&serialized).unwrap(); assert_eq!(deserialized, multiple);
Variants
String(String)
A generic string
Uri(Url)
A parsed URI
Trait Implementations
impl AsRef<str> for StringOrUri
[src]
impl PartialEq<StringOrUri> for StringOrUri
[src]
fn eq(&self, other: &StringOrUri) -> bool
[src]
fn ne(&self, other: &StringOrUri) -> bool
[src]
impl Clone for StringOrUri
[src]
fn clone(&self) -> StringOrUri
[src]
fn clone_from(&mut self, source: &Self)
1.0.0[src]
Performs copy-assignment from source
. Read more
impl Eq for StringOrUri
[src]
impl Display for StringOrUri
[src]
impl Debug for StringOrUri
[src]
impl Hash for StringOrUri
[src]
fn hash<__H: Hasher>(&self, state: &mut __H)
[src]
fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher,
1.3.0[src]
H: Hasher,
Feeds a slice of this type into the given [Hasher
]. Read more
impl FromStr for StringOrUri
[src]
type Err = Error
The associated error which can be returned from parsing.
fn from_str(input: &str) -> Result<Self, Self::Err>
[src]
Parses a &str
into a StringOrUri
.
According to RFC 7519, any string containing the ":" character
will be treated as a URL. Any invalid URLs will be treated as failure.
impl Serialize for StringOrUri
[src]
impl<'de> Deserialize<'de> for StringOrUri
[src]
fn deserialize<D>(deserializer: D) -> Result<StringOrUri, D::Error> where
D: Deserializer<'de>,
[src]
D: Deserializer<'de>,
Auto Trait Implementations
impl Send for StringOrUri
impl Sync for StringOrUri
Blanket Implementations
impl<T, U> Into for T where
U: From<T>,
[src]
U: From<T>,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
impl<T> ToString for T where
T: Display + ?Sized,
[src]
T: Display + ?Sized,
impl<T> From for T
[src]
impl<T, U> TryFrom for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T> Borrow for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T, U> TryInto for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> DeserializeOwned for T where
T: Deserialize<'de>,
[src]
T: Deserialize<'de>,
impl<Q, K> Equivalent for Q where
K: Borrow<Q> + ?Sized,
Q: Eq + ?Sized,
[src]
K: Borrow<Q> + ?Sized,
Q: Eq + ?Sized,