pub struct ProxyConnector<S> { /* private fields */ }Available on crate features
http and http-full and socks5 only.Expand description
Proxy connector which supports http(s) and socks5(h) proxy address
Connector will look at ProxyAddress to determine which proxy
connector to use if one is configured
Implementations§
Source§impl<S> ProxyConnector<S>
impl<S> ProxyConnector<S>
Sourcepub fn required(
inner: S,
socks_proxy_layer: Socks5ProxyConnectorLayer,
http_proxy_layer: HttpProxyConnectorLayer,
) -> ProxyConnector<Arc<S>>
pub fn required( inner: S, socks_proxy_layer: Socks5ProxyConnectorLayer, http_proxy_layer: HttpProxyConnectorLayer, ) -> ProxyConnector<Arc<S>>
Creates a new required ProxyConnector.
This connector will fail if no ProxyAddress is configured
Sourcepub fn optional(
inner: S,
socks_proxy_layer: Socks5ProxyConnectorLayer,
http_proxy_layer: HttpProxyConnectorLayer,
) -> ProxyConnector<Arc<S>>
pub fn optional( inner: S, socks_proxy_layer: Socks5ProxyConnectorLayer, http_proxy_layer: HttpProxyConnectorLayer, ) -> ProxyConnector<Arc<S>>
Creates a new optional ProxyConnector.
This connector will forward to the inner connector if no ProxyAddress is configured
Trait Implementations§
Source§impl<Request, S> Service<Request> for ProxyConnector<S>where
S: ConnectorService<Request, Connection: Stream + Unpin>,
Request: TryRefIntoTransportContext<Error: Into<BoxError> + Send + 'static> + Send + ExtensionsMut + 'static,
impl<Request, S> Service<Request> for ProxyConnector<S>where
S: ConnectorService<Request, Connection: Stream + Unpin>,
Request: TryRefIntoTransportContext<Error: Into<BoxError> + Send + 'static> + Send + ExtensionsMut + 'static,
Source§type Response = EstablishedClientConnection<MaybeProxiedConnection<<S as ConnectorService<Request>>::Connection>, Request>
type Response = EstablishedClientConnection<MaybeProxiedConnection<<S as ConnectorService<Request>>::Connection>, Request>
The type of response returned by the service.
Source§async fn serve(&self, req: Request) -> Result<Self::Response, Self::Error>
async fn serve(&self, req: Request) -> Result<Self::Response, Self::Error>
Serve a response or error for the given request,
using the given context.
§fn boxed(self) -> BoxService<Request, Self::Response, Self::Error>
fn boxed(self) -> BoxService<Request, Self::Response, Self::Error>
Box this service to allow for dynamic dispatch.
Auto Trait Implementations§
impl<S> Freeze for ProxyConnector<S>where
S: Freeze,
impl<S> !RefUnwindSafe for ProxyConnector<S>
impl<S> Send for ProxyConnector<S>where
S: Send,
impl<S> Sync for ProxyConnector<S>where
S: Sync,
impl<S> Unpin for ProxyConnector<S>where
S: Unpin,
impl<S> !UnwindSafe for ProxyConnector<S>
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
Mutably borrows from an owned value. Read more
§impl<S, Request, Connection> ConnectorService<Request> for S
impl<S, Request, Connection> ConnectorService<Request> for S
§type Connection = Connection
type Connection = Connection
Connection returned by the
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
Establish a connection, which often involves some kind of handshake,
or connection revival.
§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<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> ⓘ
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<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>
Create a new
Policy that returns Action::Follow only if self and other return
Action::Follow. Read more§impl<T, U> RamaTryFrom<T> for Uwhere
U: TryFrom<T>,
impl<T, U> RamaTryFrom<T> for Uwhere
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
fn rama_try_from(value: T) -> Result<U, <U as RamaTryFrom<T>>::Error>
§impl<T, U, CrateMarker> RamaTryInto<U, CrateMarker> for Twhere
U: RamaTryFrom<T, CrateMarker>,
impl<T, U, CrateMarker> RamaTryInto<U, CrateMarker> for Twhere
U: RamaTryFrom<T, CrateMarker>,
type Error = <U as RamaTryFrom<T, CrateMarker>>::Error
fn rama_try_into(self) -> Result<U, <U as RamaTryFrom<T, CrateMarker>>::Error>
§impl<S, RequestIn, RequestOut> RequestInspector<RequestIn> for S
impl<S, RequestIn, RequestOut> RequestInspector<RequestIn> for S
type RequestOut = RequestOut
§fn inspect_request(
&self,
req: RequestIn,
) -> impl Future<Output = Result<<S as RequestInspector<RequestIn>>::RequestOut, <S as RequestInspector<RequestIn>>::Error>> + Send
fn inspect_request( &self, req: RequestIn, ) -> impl Future<Output = Result<<S as RequestInspector<RequestIn>>::RequestOut, <S as RequestInspector<RequestIn>>::Error>> + Send
Inspect the request, modify it if needed or desired, and return it.