pub struct UrlResolver {
pub base_url: Option<Url>,
}Expand description
Decides which URLs are allowed to be loaded.
Currently only contains the base URL.
The plan is to add: base_only: Only allow to load content from the same base URL. By default include_xml: Allows to use xi:include with XML. Enabled by default. include_text: Allows to use xi:include with text. Enabled by default. local_only: Only allow to load content from the local filesystem. Enabled by default.
Fields§
§base_url: Option<Url>Base URL; all relative references will be resolved with respect to this.
Implementations§
Source§impl UrlResolver
impl UrlResolver
Sourcepub fn new(base_url: Option<Url>) -> Self
pub fn new(base_url: Option<Url>) -> Self
Creates a UrlResolver with defaults, and sets the base_url.
Sourcepub fn resolve_href(&self, href: &str) -> Result<AllowedUrl, AllowedUrlError>
pub fn resolve_href(&self, href: &str) -> Result<AllowedUrl, AllowedUrlError>
Decides which URLs are allowed to be loaded based on the presence of a base URL.
This function implements the policy described in “Security and locations of referenced files” in the crate documentation.
Trait Implementations§
Source§impl Clone for UrlResolver
impl Clone for UrlResolver
Source§fn clone(&self) -> UrlResolver
fn clone(&self) -> UrlResolver
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreAuto Trait Implementations§
impl Freeze for UrlResolver
impl RefUnwindSafe for UrlResolver
impl Send for UrlResolver
impl Sync for UrlResolver
impl Unpin for UrlResolver
impl UnwindSafe for UrlResolver
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> Pointable for T
impl<T> Pointable for T
§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.