Struct Cors
pub struct Cors<S> { /* private fields */ }http only.Expand description
Middleware which adds headers for CORS.
See the module docs for an example.
Implementations§
§impl<S> Cors<S>
impl<S> Cors<S>
pub fn new(inner: S) -> Cors<S>
pub fn new(inner: S) -> Cors<S>
Create a new Cors.
See CorsLayer::new for more details.
pub fn permissive(inner: S) -> Cors<S>
pub fn permissive(inner: S) -> Cors<S>
A permissive configuration.
See CorsLayer::permissive for more details.
pub fn very_permissive(inner: S) -> Cors<S>
pub fn very_permissive(inner: S) -> Cors<S>
A very permissive configuration.
See CorsLayer::very_permissive for more details.
pub fn into_inner(self) -> S
pub fn into_inner(self) -> S
Consumes self, returning the underlying service.
pub fn try_with_allow_credentials(self) -> Result<Cors<S>, OpaqueError>
pub fn try_with_allow_credentials(self) -> Result<Cors<S>, OpaqueError>
Always set the Access-Control-Allow-Credentials header.
§Errors
Errors in case any of the other CORS headers which support the wildcard value have been set to use it.
pub fn try_set_allow_credentials(&mut self) -> Result<&mut Cors<S>, OpaqueError>
pub fn try_set_allow_credentials(&mut self) -> Result<&mut Cors<S>, OpaqueError>
Always set the Access-Control-Allow-Credentials header.
§Errors
Errors in case any of the other CORS headers which support the wildcard value have been set to use it.
pub fn with_allow_credentials_if(
self,
predicate: impl Fn(&HeaderValue, &Parts) -> bool + Send + Sync + 'static,
) -> Cors<S>
pub fn with_allow_credentials_if( self, predicate: impl Fn(&HeaderValue, &Parts) -> bool + Send + Sync + 'static, ) -> Cors<S>
Set the Access-Control-Allow-Credentials header if predicate is satisfied.
pub fn set_allow_credentials_if(
&mut self,
predicate: impl Fn(&HeaderValue, &Parts) -> bool + Send + Sync + 'static,
) -> &mut Cors<S>
pub fn set_allow_credentials_if( &mut self, predicate: impl Fn(&HeaderValue, &Parts) -> bool + Send + Sync + 'static, ) -> &mut Cors<S>
Set the Access-Control-Allow-Credentials header if predicate is satisfied.
pub fn try_with_allow_headers(
self,
headers: AccessControlAllowHeaders,
) -> Result<Cors<S>, OpaqueError>
pub fn try_with_allow_headers( self, headers: AccessControlAllowHeaders, ) -> Result<Cors<S>, OpaqueError>
Set the value of the Access-Control-Allow-Headers header.
§Errors
Errors in case credentials are allowed and the given header
contains the wildcard value (*).
pub fn try_set_allow_headers(
&mut self,
headers: AccessControlAllowHeaders,
) -> Result<&mut Cors<S>, OpaqueError>
pub fn try_set_allow_headers( &mut self, headers: AccessControlAllowHeaders, ) -> Result<&mut Cors<S>, OpaqueError>
Set the value of the Access-Control-Allow-Headers header.
§Errors
Errors in case credentials are allowed and the given header
contains the wildcard value (*).
pub fn with_max_age(self, header: AccessControlMaxAge) -> Cors<S>
pub fn with_max_age(self, header: AccessControlMaxAge) -> Cors<S>
Set the value of the Access-Control-Max-Age header.
By default the header will not be set which disables caching and will require a preflight call for all requests.
Note that each browser has a maximum internal value that takes precedence when the Access-Control-Max-Age is greater. For more details see mdn.
If you need more flexibility, you can use supply a function which can dynamically decide the optional max-age based on the origin and other parts of each preflight request.
pub fn set_max_age(&mut self, header: AccessControlMaxAge) -> &mut Cors<S>
pub fn set_max_age(&mut self, header: AccessControlMaxAge) -> &mut Cors<S>
Set the value of the Access-Control-Max-Age header.
By default the header will not be set which disables caching and will require a preflight call for all requests.
Note that each browser has a maximum internal value that takes precedence when the Access-Control-Max-Age is greater. For more details see mdn.
If you need more flexibility, you can use supply a function which can dynamically decide the optional max-age based on the origin and other parts of each preflight request.
pub fn with_max_age_if(
self,
predicate: impl Fn(&HeaderValue, &Parts) -> Option<Seconds> + Send + Sync + 'static,
) -> Cors<S>
pub fn with_max_age_if( self, predicate: impl Fn(&HeaderValue, &Parts) -> Option<Seconds> + Send + Sync + 'static, ) -> Cors<S>
Set the Access-Control-Max-Age header if predicate is satisfied.
See Self::with_max_age and Self::set_max_age for more information.
pub fn set_max_age_if(
&mut self,
predicate: impl Fn(&HeaderValue, &Parts) -> Option<Seconds> + Send + Sync + 'static,
) -> &mut Cors<S>
pub fn set_max_age_if( &mut self, predicate: impl Fn(&HeaderValue, &Parts) -> Option<Seconds> + Send + Sync + 'static, ) -> &mut Cors<S>
Set the Access-Control-Max-Age header if predicate is satisfied.
See Self::with_max_age and Self::set_max_age for more information.
pub fn try_with_allow_methods(
self,
methods: AccessControlAllowMethods,
) -> Result<Cors<S>, OpaqueError>
pub fn try_with_allow_methods( self, methods: AccessControlAllowMethods, ) -> Result<Cors<S>, OpaqueError>
Set the value of the Access-Control-Allow-Methods header.
§Errors
Errors in case credentials are allowed and the given header
contains the wildcard value (*).
pub fn try_set_allow_methods(
&mut self,
methods: AccessControlAllowMethods,
) -> Result<&mut Cors<S>, OpaqueError>
pub fn try_set_allow_methods( &mut self, methods: AccessControlAllowMethods, ) -> Result<&mut Cors<S>, OpaqueError>
Set the value of the Access-Control-Allow-Methods header.
§Errors
Errors in case credentials are allowed and the given header
contains the wildcard value (*).
pub fn try_with_allow_origin_any(self) -> Result<Cors<S>, OpaqueError>
pub fn try_with_allow_origin_any(self) -> Result<Cors<S>, OpaqueError>
Only set the Access-Control-Allow-Origin header with the wildcard value (*).
§Errors
Errors in case credentials are allowed.
pub fn try_set_allow_origin_any(&mut self) -> Result<&mut Cors<S>, OpaqueError>
pub fn try_set_allow_origin_any(&mut self) -> Result<&mut Cors<S>, OpaqueError>
Only set the Access-Control-Allow-Origin header with the wildcard value (*).
§Errors
Errors in case credentials are allowed.
pub fn with_allow_origin_if_null(self) -> Cors<S>
pub fn with_allow_origin_if_null(self) -> Cors<S>
Only set the Access-Control-Allow-Origin header with the “null” value when that is the origin.
Note: The value null should not be used.
It may seem safe to return Access-Control-Allow-Origin: "null";
however, the origin of resources that use a non-hierarchical scheme
(such as data: or file:) and sandboxed documents is serialized as null.
Many browsers will grant such documents access to a response with an
Access-Control-Allow-Origin: null header, and any origin can create a
hostile document with a null origin. Therefore, the null value for the
Access-Control-Allow-Origin header should be avoided
pub fn set_allow_origin_if_null(&mut self) -> &mut Cors<S>
pub fn set_allow_origin_if_null(&mut self) -> &mut Cors<S>
Only set the Access-Control-Allow-Origin header with the “null” value when that is the origin.
Note: The value null should not be used.
It may seem safe to return Access-Control-Allow-Origin: "null";
however, the origin of resources that use a non-hierarchical scheme
(such as data: or file:) and sandboxed documents is serialized as null.
Many browsers will grant such documents access to a response with an
Access-Control-Allow-Origin: null header, and any origin can create a
hostile document with a null origin. Therefore, the null value for the
Access-Control-Allow-Origin header should be avoided
pub fn with_allow_origin_if(
self,
predicate: impl Fn(&HeaderValue, &Parts) -> bool + Send + Sync + 'static,
) -> Cors<S>
pub fn with_allow_origin_if( self, predicate: impl Fn(&HeaderValue, &Parts) -> bool + Send + Sync + 'static, ) -> Cors<S>
Set the value of the Access-Control-Allow-Origin header if the predicate satisfied.
pub fn set_allow_origin_if(
&mut self,
predicate: impl Fn(&HeaderValue, &Parts) -> bool + Send + Sync + 'static,
) -> &mut Cors<S>
pub fn set_allow_origin_if( &mut self, predicate: impl Fn(&HeaderValue, &Parts) -> bool + Send + Sync + 'static, ) -> &mut Cors<S>
Set the value of the Access-Control-Allow-Origin header if the predicate satisfied.
pub fn try_with_expose_headers(
self,
headers: AccessControlExposeHeaders,
) -> Result<Cors<S>, OpaqueError>
pub fn try_with_expose_headers( self, headers: AccessControlExposeHeaders, ) -> Result<Cors<S>, OpaqueError>
Set the value of the Access-Control-Expose-Headers header.
§Errors
Errors in case credentials are allowed and the given header
contains the wildcard value (*).
pub fn try_set_expose_headers(
&mut self,
headers: AccessControlExposeHeaders,
) -> Result<&mut Cors<S>, OpaqueError>
pub fn try_set_expose_headers( &mut self, headers: AccessControlExposeHeaders, ) -> Result<&mut Cors<S>, OpaqueError>
Set the value of the Access-Control-Expose-Headers header.
§Errors
Errors in case credentials are allowed and the given header
contains the wildcard value (*).
pub fn with_allow_private_network(self) -> Cors<S>
pub fn with_allow_private_network(self) -> Cors<S>
Always set the Access-Control-Allow-Private-Network header.
pub fn set_allow_private_network(&mut self) -> &mut Cors<S>
pub fn set_allow_private_network(&mut self) -> &mut Cors<S>
Always set the Access-Control-Allow-Private-Network header.
pub fn with_allow_private_network_if(
self,
predicate: impl Fn(&HeaderValue, &Parts) -> bool + Send + Sync + 'static,
) -> Cors<S>
pub fn with_allow_private_network_if( self, predicate: impl Fn(&HeaderValue, &Parts) -> bool + Send + Sync + 'static, ) -> Cors<S>
Set the Access-Control-Allow-Private-Network header if predicate is satisfied.
pub fn set_allow_private_network_if(
&mut self,
predicate: impl Fn(&HeaderValue, &Parts) -> bool + Send + Sync + 'static,
) -> &mut Cors<S>
pub fn set_allow_private_network_if( &mut self, predicate: impl Fn(&HeaderValue, &Parts) -> bool + Send + Sync + 'static, ) -> &mut Cors<S>
Set the Access-Control-Allow-Private-Network header if predicate is satisfied.
Trait Implementations§
§impl<S, ReqBody, ResBody> Service<Request<ReqBody>> for Cors<S>
impl<S, ReqBody, ResBody> Service<Request<ReqBody>> for Cors<S>
§type Output = <S as Service<Request<ReqBody>>>::Output
type Output = <S as Service<Request<ReqBody>>>::Output
§async fn serve(
&self,
req: Request<ReqBody>,
) -> Result<<Cors<S> as Service<Request<ReqBody>>>::Output, <Cors<S> as Service<Request<ReqBody>>>::Error>
async fn serve( &self, req: Request<ReqBody>, ) -> Result<<Cors<S> as Service<Request<ReqBody>>>::Output, <Cors<S> as Service<Request<ReqBody>>>::Error>
§fn boxed(self) -> BoxService<Input, Self::Output, Self::Error>
fn boxed(self) -> BoxService<Input, Self::Output, Self::Error>
Auto Trait Implementations§
impl<S> !Freeze for Cors<S>
impl<S> !RefUnwindSafe for Cors<S>
impl<S> Send for Cors<S>where
S: Send,
impl<S> Sync for Cors<S>where
S: Sync,
impl<S> Unpin for Cors<S>where
S: Unpin,
impl<S> !UnwindSafe for Cors<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,
§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§unsafe fn clone_to_uninit(&self, dest: *mut u8)
unsafe fn clone_to_uninit(&self, dest: *mut u8)
clone_to_uninit)§impl<S, Input, Connection> ConnectorService<Input> for S
impl<S, Input, Connection> ConnectorService<Input> for S
§type Connection = Connection
type Connection = Connection
ConnectorService§fn connect(
&self,
input: Input,
) -> impl Future<Output = Result<EstablishedClientConnection<<S as ConnectorService<Input>>::Connection, Input>, <S as ConnectorService<Input>>::Error>> + Send
fn connect( &self, input: Input, ) -> impl Future<Output = Result<EstablishedClientConnection<<S as ConnectorService<Input>>::Connection, Input>, <S as ConnectorService<Input>>::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<S, R> IntoEndpointService<(R,)> for S
impl<S, R> IntoEndpointService<(R,)> for S
§fn into_endpoint_service(
self,
) -> impl Service<Request, Output = Response, Error = Infallible>
fn into_endpoint_service( self, ) -> impl Service<Request, Output = Response, Error = Infallible>
rama_core::Service.§impl<S, R, State> IntoEndpointServiceWithState<(R,), State> for S
impl<S, R, State> IntoEndpointServiceWithState<(R,), State> for S
§fn into_endpoint_service_with_state(
self,
_state: State,
) -> impl Service<Request, Output = Response, Error = Infallible>
fn into_endpoint_service_with_state( self, _state: State, ) -> impl Service<Request, Output = Response, Error = Infallible>
rama_core::Service with state.§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