Struct ProxyDBService
pub struct ProxyDBService<S, D, P, F> { /* private fields */ }Expand description
A Service which selects a Proxy based on the given [Context].
Depending on the ProxyFilterMode the selection proxies might be optional,
or use the default ProxyFilter in case none is defined.
A predicate can be used to provide additional filtering on the found proxies,
that otherwise did match the used ProxyFilter.
See the crate docs for examples and more info on the usage of this service.
Implementations§
§impl<S, D> ProxyDBService<S, D, bool, ()>
impl<S, D> ProxyDBService<S, D, bool, ()>
pub const fn new(inner: S, db: D) -> ProxyDBService<S, D, bool, ()>
pub const fn new(inner: S, db: D) -> ProxyDBService<S, D, bool, ()>
Create a new ProxyDBService with the given inner Service and ProxyDB.
§impl<S, D, P, F> ProxyDBService<S, D, P, F>
impl<S, D, P, F> ProxyDBService<S, D, P, F>
pub fn filter_mode(self, mode: ProxyFilterMode) -> ProxyDBService<S, D, P, F>
pub fn filter_mode(self, mode: ProxyFilterMode) -> ProxyDBService<S, D, P, F>
Set a ProxyFilterMode to define the behaviour surrounding
ProxyFilter usage, e.g. if a proxy filter is required to be available or not,
or what to do if it is optional and not available.
pub fn set_filter_mode(
&mut self,
mode: ProxyFilterMode,
) -> &mut ProxyDBService<S, D, P, F>
pub fn set_filter_mode( &mut self, mode: ProxyFilterMode, ) -> &mut ProxyDBService<S, D, P, F>
Set a ProxyFilterMode to define the behaviour surrounding
ProxyFilter usage, e.g. if a proxy filter is required to be available or not,
or what to do if it is optional and not available.
pub const fn preserve_proxy(self, preserve: bool) -> ProxyDBService<S, D, P, F>
pub const fn preserve_proxy(self, preserve: bool) -> ProxyDBService<S, D, P, F>
Define whether or not an existing ProxyAddress (in the [Context])
should be overwritten or not. By default preserve=false,
meaning we will overwrite the proxy address in case we selected one now.
NOTE even when preserve=false it might still be that there’s
a ProxyAddress in case it was set by a previous layer.
pub fn set_preserve_proxy(
&mut self,
preserve: bool,
) -> &mut ProxyDBService<S, D, P, F>
pub fn set_preserve_proxy( &mut self, preserve: bool, ) -> &mut ProxyDBService<S, D, P, F>
Define whether or not an existing ProxyAddress (in the [Context])
should be overwritten or not. By default preserve=false,
meaning we will overwrite the proxy address in case we selected one now.
NOTE even when preserve=false it might still be that there’s
a ProxyAddress in case it was set by a previous layer.
pub fn select_predicate<Predicate>(
self,
p: Predicate,
) -> ProxyDBService<S, D, Predicate, F>
pub fn select_predicate<Predicate>( self, p: Predicate, ) -> ProxyDBService<S, D, Predicate, F>
Set a ProxyQueryPredicate that will be used
to possibly filter out proxies that according to the filters are correct,
but not according to the predicate.
pub fn username_formatter<Formatter>(
self,
f: Formatter,
) -> ProxyDBService<S, D, P, Formatter>
pub fn username_formatter<Formatter>( self, f: Formatter, ) -> ProxyDBService<S, D, P, Formatter>
Set a UsernameFormatter that will be used to format
the username based on the selected Proxy. This is required
in case the proxy is a router that accepts or maybe even requires
username labels to configure proxies further down/up stream.
pub fn into_inner(self) -> S
pub fn into_inner(self) -> S
Consumes self, returning the underlying service.
Trait Implementations§
§impl<S, D, P, F> Clone for ProxyDBService<S, D, P, F>
impl<S, D, P, F> Clone for ProxyDBService<S, D, P, F>
§fn clone(&self) -> ProxyDBService<S, D, P, F>
fn clone(&self) -> ProxyDBService<S, D, P, F>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more§impl<S, D, P, F> Debug for ProxyDBService<S, D, P, F>
impl<S, D, P, F> Debug for ProxyDBService<S, D, P, F>
§impl<S, D, P, F, Request> Service<Request> for ProxyDBService<S, D, P, F>where
S: Service<Request>,
<S as Service<Request>>::Error: Into<Box<dyn Error + Sync + Send>> + Send + Sync + 'static,
D: ProxyDB,
<D as ProxyDB>::Error: Into<Box<dyn Error + Sync + Send>> + Send + Sync + 'static,
P: ProxyQueryPredicate,
F: UsernameFormatter,
Request: TryRefIntoTransportContext + ExtensionsMut + Send + 'static,
<Request as TryRefIntoTransportContext>::Error: Into<Box<dyn Error + Sync + Send>> + Send + 'static,
impl<S, D, P, F, Request> Service<Request> for ProxyDBService<S, D, P, F>where
S: Service<Request>,
<S as Service<Request>>::Error: Into<Box<dyn Error + Sync + Send>> + Send + Sync + 'static,
D: ProxyDB,
<D as ProxyDB>::Error: Into<Box<dyn Error + Sync + Send>> + Send + Sync + 'static,
P: ProxyQueryPredicate,
F: UsernameFormatter,
Request: TryRefIntoTransportContext + ExtensionsMut + Send + 'static,
<Request as TryRefIntoTransportContext>::Error: Into<Box<dyn Error + Sync + Send>> + Send + 'static,
§async fn serve(
&self,
req: Request,
) -> Result<<ProxyDBService<S, D, P, F> as Service<Request>>::Response, <ProxyDBService<S, D, P, F> as Service<Request>>::Error>
async fn serve( &self, req: Request, ) -> Result<<ProxyDBService<S, D, P, F> as Service<Request>>::Response, <ProxyDBService<S, D, P, F> as Service<Request>>::Error>
§fn boxed(self) -> BoxService<Request, Self::Response, Self::Error>
fn boxed(self) -> BoxService<Request, Self::Response, Self::Error>
Auto Trait Implementations§
impl<S, D, P, F> Freeze for ProxyDBService<S, D, P, F>
impl<S, D, P, F> RefUnwindSafe for ProxyDBService<S, D, P, F>
impl<S, D, P, F> Send for ProxyDBService<S, D, P, F>
impl<S, D, P, F> Sync for ProxyDBService<S, D, P, F>
impl<S, D, P, F> Unpin for ProxyDBService<S, D, P, F>
impl<S, D, P, F> UnwindSafe for ProxyDBService<S, D, P, F>
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<S, Request, Connection> ConnectorService<Request> for S
impl<S, Request, Connection> ConnectorService<Request> for S
§type Connection = Connection
type Connection = Connection
ConnectorService§fn connect(
&self,
req: Request,
) -> impl Future<Output = Result<EstablishedClientConnection<<S as ConnectorService<Request>>::Connection, Request>, <S as ConnectorService<Request>>::Error>> + Send
fn connect( &self, req: Request, ) -> impl Future<Output = Result<EstablishedClientConnection<<S as ConnectorService<Request>>::Connection, Request>, <S as ConnectorService<Request>>::Error>> + Send
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self> ⓘ
fn with_context(self, otel_cx: Context) -> WithContext<Self> ⓘ
§fn with_current_context(self) -> WithContext<Self> ⓘ
fn with_current_context(self) -> WithContext<Self> ⓘ
§impl<S, Body> HttpClientExt for S
impl<S, Body> HttpClientExt for S
§type ExecuteResponse = Response<Body>
type ExecuteResponse = Response<Body>
execute method.§type ExecuteError = <S as Service<Request>>::Error
type ExecuteError = <S as Service<Request>>::Error
execute method.§fn get(
&self,
url: impl IntoUrl,
) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
fn get( &self, url: impl IntoUrl, ) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
GET request to a URL. Read more§fn post(
&self,
url: impl IntoUrl,
) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
fn post( &self, url: impl IntoUrl, ) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
POST request to a URL. Read more§fn put(
&self,
url: impl IntoUrl,
) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
fn put( &self, url: impl IntoUrl, ) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
PUT request to a URL. Read more§fn patch(
&self,
url: impl IntoUrl,
) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
fn patch( &self, url: impl IntoUrl, ) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
PATCH request to a URL. Read more§fn delete(
&self,
url: impl IntoUrl,
) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
fn delete( &self, url: impl IntoUrl, ) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
DELETE request to a URL. Read more§fn head(
&self,
url: impl IntoUrl,
) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
fn head( &self, url: impl IntoUrl, ) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
HEAD request to a URL. Read more§fn connect(
&self,
url: impl IntoUrl,
) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
fn connect( &self, url: impl IntoUrl, ) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
CONNECT request to a URL. Read more§fn request(
&self,
method: Method,
url: impl IntoUrl,
) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
fn request( &self, method: Method, url: impl IntoUrl, ) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
§fn build_from_request<RequestBody>(
&self,
request: Request<RequestBody>,
) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
fn build_from_request<RequestBody>( &self, request: Request<RequestBody>, ) -> RequestBuilder<'_, S, <S as HttpClientExt>::ExecuteResponse>
§fn execute(
&self,
request: Request,
) -> impl Future<Output = Result<<S as HttpClientExt>::ExecuteResponse, <S as HttpClientExt>::ExecuteError>>
fn execute( &self, request: Request, ) -> impl Future<Output = Result<<S as HttpClientExt>::ExecuteResponse, <S as HttpClientExt>::ExecuteError>>
Request. Read more§impl<S, Body> HttpClientWebSocketExt<Body> for S
impl<S, Body> HttpClientWebSocketExt<Body> for S
§fn websocket(
&self,
url: impl IntoUrl,
) -> WebSocketRequestBuilder<WithService<'_, S, Body>>
fn websocket( &self, url: impl IntoUrl, ) -> WebSocketRequestBuilder<WithService<'_, S, Body>>
WebSocketRequestBuilder] to be used to establish a WebSocket connection over http/1.1.§fn websocket_h2(
&self,
url: impl IntoUrl,
) -> WebSocketRequestBuilder<WithService<'_, S, Body>>
fn websocket_h2( &self, url: impl IntoUrl, ) -> WebSocketRequestBuilder<WithService<'_, S, Body>>
WebSocketRequestBuilder to be used to establish a WebSocket connection over h2.§fn websocket_with_request<RequestBody>(
&self,
req: Request<RequestBody>,
) -> WebSocketRequestBuilder<WithService<'_, S, Body>>
fn websocket_with_request<RequestBody>( &self, req: Request<RequestBody>, ) -> WebSocketRequestBuilder<WithService<'_, S, Body>>
WebSocketRequestBuilder starting from the given request. Read more§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
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> ⓘ
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> ⓘ
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<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§fn and<P, B, E>(self, other: P) -> And<T, P>
fn and<P, B, E>(self, other: P) -> And<T, P>
Policy that returns Action::Follow only if self and other return
Action::Follow. Read more