Struct trust_dns_proto::serialize::binary::Restrict
source · pub struct Restrict<T>(_);
Expand description
Untrusted types will be wrapped in this type.
To gain access to the data, some form of verification through one of the public methods is necessary.
Implementations§
source§impl<T> Restrict<T>
impl<T> Restrict<T>
sourcepub fn verify<'a, F: Fn(&'a T) -> bool>(&'a self, f: F) -> Verified<'a, T>
pub fn verify<'a, F: Fn(&'a T) -> bool>(&'a self, f: F) -> Verified<'a, T>
It is the responsibility of this function to verify the contained type is valid.
use trust_dns_proto::serialize::binary::Restrict;
let unrestricted = Restrict::new(0).verify(|r| *r == 0).then(|r| *r + 1).unwrap();
assert!(unrestricted == 1);
Returns
If f
returns true then the value is valid and a chainable Verified
type is returned
sourcepub fn verify_unwrap<F: Fn(&T) -> bool>(self, f: F) -> Result<T, T>
pub fn verify_unwrap<F: Fn(&T) -> bool>(self, f: F) -> Result<T, T>
It is the responsibility of this function to verify the contained type is valid.
use trust_dns_proto::serialize::binary::Restrict;
let unrestricted = Restrict::new(0).verify_unwrap(|r| *r == 0).unwrap();
assert!(unrestricted == 0);
Returns
If f
returns true then the value is valid and Ok(T)
is returned. Otherwise
Err(T)
is returned.
sourcepub fn unverified(self) -> T
pub fn unverified(self) -> T
Unwraps the value without verifying the data, akin to Result::unwrap and Option::unwrap, but will not panic
sourcepub fn map<R, F: Fn(T) -> R>(self, f: F) -> Restrict<R>
pub fn map<R, F: Fn(T) -> R>(self, f: F) -> Restrict<R>
Map the internal type of the restriction
use trust_dns_proto::serialize::binary::Restrict;
let restricted = Restrict::new(0).map(|b| vec![b, 1]);
assert!(restricted.verify(|v| v == &[0, 1]).is_valid());
assert!(!restricted.verify(|v| v == &[1, 0]).is_valid());