Skip to main content

DeepLinkConfig

Struct DeepLinkConfig 

Source
pub struct DeepLinkConfig {
    pub schemes: Vec<String>,
    pub domains: Vec<String>,
    pub path_prefixes: Vec<String>,
}
Expand description

Declarative runtime filter for inbound deep links.

Fields§

§schemes: Vec<String>§domains: Vec<String>§path_prefixes: Vec<String>

Implementations§

Source§

impl DeepLinkConfig

Source

pub fn new() -> Self

Creates an empty deep-link configuration.

Add schemes, domains, and optional path prefixes before installing it in a shell. An empty config intentionally matches no URLs.

Source

pub fn scheme(self, scheme: impl Into<String>) -> Self

Allows a custom URL scheme.

scheme is normalized by trimming whitespace, removing a trailing colon, and lowercasing. Use this for routes such as myapp://item/123.

Source

pub fn domain(self, domain: impl Into<String>) -> Self

Allows an HTTP or HTTPS domain.

domain is normalized by trimming whitespace, removing a trailing dot, and lowercasing. Use this for app links, universal links, and web routes that should enter the Fission app.

Source

pub fn path_prefix(self, prefix: impl Into<String>) -> Self

Restricts accepted links to a path prefix.

Prefixes are normalized to start with /. Add one or more prefixes when only part of a domain should route into the app, such as /invite or /checkout.

Source

pub fn is_empty(&self) -> bool

Returns true when no scheme, domain, or path rule has been configured.

Empty configs match no URLs. This prevents a shell from accidentally accepting every external URL before the app has declared its routes.

Source

pub fn matches(&self, url: &str) -> bool

Returns whether a URL is accepted by this deep-link configuration.

url is parsed as a simple absolute URL. The URL matches when its scheme or domain is allowed and, if path prefixes were configured, its path starts with one of those prefixes.

Source

pub fn source_for(&self, url: &str) -> DeepLinkSource

Classifies a URL according to this configuration.

Use this in shell code when creating DeepLinkReceived actions. The result distinguishes configured custom schemes and associated domains from ordinary web URLs or external URLs.

Trait Implementations§

Source§

impl Clone for DeepLinkConfig

Source§

fn clone(&self) -> DeepLinkConfig

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for DeepLinkConfig

Source§

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

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

impl Default for DeepLinkConfig

Source§

fn default() -> DeepLinkConfig

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for DeepLinkConfig

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl PartialEq for DeepLinkConfig

Source§

fn eq(&self, other: &DeepLinkConfig) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · 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 Serialize for DeepLinkConfig

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Eq for DeepLinkConfig

Source§

impl StructuralPartialEq for DeepLinkConfig

Auto Trait Implementations§

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

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
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> ToOwned for T
where T: Clone,

Source§

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, U> TryFrom<U> for T
where U: Into<T>,

Source§

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

Source§

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> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,