ContextRouteRegistry

Struct ContextRouteRegistry 

Source
pub struct ContextRouteRegistry { /* private fields */ }
Expand description

Context-level route handler registry.

Routes registered here apply to all pages in the context. New pages automatically inherit these routes.

Implementations§

Source§

impl ContextRouteRegistry

Source

pub fn new(connection: Arc<CdpConnection>, context_id: String) -> Self

Create a new context route registry.

Source

pub async fn register_page_registry(&self, registry: &Arc<RouteHandlerRegistry>)

Register a page’s route registry with this context.

When a new route is added to the context, Fetch will be enabled on all registered page registries before the route() call returns.

Source

pub fn subscribe_route_changes(&self) -> Receiver<RouteChangeNotification>

Subscribe to route change notifications.

Pages use this to know when they need to enable Fetch domain for newly added context routes.

Source

pub async fn route<M, H, Fut>( &self, pattern: M, handler: H, ) -> Result<(), NetworkError>
where M: Into<UrlPattern>, H: Fn(Route) -> Fut + Send + Sync + 'static, Fut: Future<Output = Result<(), NetworkError>> + Send + 'static,

Register a route handler for the given pattern.

The handler will be applied to all pages in the context.

§Errors

Returns an error if registering the route handler fails.

Source

pub async fn route_predicate<P, H, Fut>( &self, predicate: P, handler: H, ) -> Result<(), NetworkError>
where P: Fn(&str) -> bool + Send + Sync + 'static, H: Fn(Route) -> Fut + Send + Sync + 'static, Fut: Future<Output = Result<(), NetworkError>> + Send + 'static,

Register a route handler with a predicate function.

§Errors

Returns an error if registering the route handler fails.

Source

pub async fn unroute(&self, pattern: &str)

Unregister handlers matching the given pattern.

Source

pub async fn unroute_all(&self)

Unregister all handlers.

Source

pub async fn has_routes(&self) -> bool

Check if there are any registered routes.

Source

pub async fn route_count(&self) -> usize

Get the number of registered routes.

Source

pub async fn apply_to_page( &self, page_registry: &RouteHandlerRegistry, ) -> Result<(), NetworkError>

👎Deprecated: Use set_context_routes on RouteHandlerRegistry instead

Apply context routes to a page’s route registry.

This should be called when a new page is created to copy context routes to the page.

§Errors

Returns an error if applying routes to the page fails.

Source

pub async fn find_handler( &self, url: &str, ) -> Option<Arc<dyn Fn(Route) -> Pin<Box<dyn Future<Output = Result<(), NetworkError>> + Send>> + Send + Sync>>

Try to handle a request with context routes.

Returns Some(handler) if a matching handler is found, None otherwise. This is called by page route registries as a fallback.

Source

pub async fn find_all_handlers( &self, url: &str, ) -> Vec<Arc<dyn Fn(Route) -> Pin<Box<dyn Future<Output = Result<(), NetworkError>> + Send>> + Send + Sync>>

Find all matching handlers for a URL.

Returns all handlers that match the URL in reverse order (LIFO). This is used for fallback chaining - handlers are tried in order until one handles the request.

Trait Implementations§

Source§

impl Debug for ContextRouteRegistry

Source§

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

Formats the value using the given formatter. Read more

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more