Struct k8s_gateway_api::v1alpha2::HttpRouteFilter
source · [−]pub struct HttpRouteFilter {
pub type: HttpRouteFilterType,
pub request_header_modifier: Option<HttpRequestHeaderFilter>,
pub request_mirror: Option<HttpRequestMirrorFilter>,
pub request_redirect: Option<HttpRequestRedirectFilter>,
pub url_rewrite: Option<HttpUrlRewriteFilter>,
pub extension_ref: Option<LocalObjectReference>,
}
Expand description
HTTPRouteFilter defines processing steps that must be completed during the request or response lifecycle. HTTPRouteFilters are meant as an extension point to express processing that may be done in Gateway implementations. Some examples include request or response modification, implementing authentication strategies, rate-limiting, and traffic shaping. API guarantee/conformance is defined based on the type of the filter.
Fields
type: HttpRouteFilterType
Type identifies the type of filter to apply. As with other API fields, types are classified into three conformance levels:
-
Core: Filter types and their corresponding configuration defined by “Support: Core” in this package, e.g. “RequestHeaderModifier”. All implementations must support core filters.
-
Extended: Filter types and their corresponding configuration defined by “Support: Extended” in this package, e.g. “RequestMirror”. Implementers are encouraged to support extended filters.
-
Custom: Filters that are defined and supported by specific vendors. In the future, filters showing convergence in behavior across multiple implementations will be considered for inclusion in extended or core conformance levels. Filter-specific configuration for such filters is specified using the ExtensionRef field.
Type
should be set to “ExtensionRef” for custom filters.
Implementers are encouraged to define custom implementation types to extend the core API with implementation-specific behavior.
If a reference to a custom filter type cannot be resolved, the filter MUST NOT be skipped. Instead, requests that would have been processed by that filter MUST receive a HTTP error response.
request_header_modifier: Option<HttpRequestHeaderFilter>
RequestHeaderModifier defines a schema for a filter that modifies request headers.
Support: Core
request_mirror: Option<HttpRequestMirrorFilter>
RequestMirror defines a schema for a filter that mirrors requests. Requests are sent to the specified destination, but responses from that destination are ignored.
Support: Extended
request_redirect: Option<HttpRequestRedirectFilter>
RequestRedirect defines a schema for a filter that responds to the request with an HTTP redirection.
Support: Core
url_rewrite: Option<HttpUrlRewriteFilter>
URLRewrite defines a schema for a filter that modifies a request during forwarding.
Support: Extended
extension_ref: Option<LocalObjectReference>
ExtensionRef is an optional, implementation-specific extension to the “filter” behavior. For example, resource “myroutefilter” in group “networking.example.net”). ExtensionRef MUST NOT be used for core and extended filters.
Support: Implementation-specific
Trait Implementations
sourceimpl Clone for HttpRouteFilter
impl Clone for HttpRouteFilter
sourcefn clone(&self) -> HttpRouteFilter
fn clone(&self) -> HttpRouteFilter
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
sourceimpl Debug for HttpRouteFilter
impl Debug for HttpRouteFilter
sourceimpl<'de> Deserialize<'de> for HttpRouteFilter
impl<'de> Deserialize<'de> for HttpRouteFilter
sourcefn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error> where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error> where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
sourceimpl JsonSchema for HttpRouteFilter
impl JsonSchema for HttpRouteFilter
sourcefn schema_name() -> String
fn schema_name() -> String
The name of the generated JSON Schema. Read more
sourcefn json_schema(gen: &mut SchemaGenerator) -> Schema
fn json_schema(gen: &mut SchemaGenerator) -> Schema
Generates a JSON Schema for this type. Read more
sourcefn is_referenceable() -> bool
fn is_referenceable() -> bool
Whether JSON Schemas generated for this type should be re-used where possible using the $ref
keyword. Read more
sourceimpl PartialEq<HttpRouteFilter> for HttpRouteFilter
impl PartialEq<HttpRouteFilter> for HttpRouteFilter
sourcefn eq(&self, other: &HttpRouteFilter) -> bool
fn eq(&self, other: &HttpRouteFilter) -> bool
This method tests for self
and other
values to be equal, and is used
by ==
. Read more
sourcefn ne(&self, other: &HttpRouteFilter) -> bool
fn ne(&self, other: &HttpRouteFilter) -> bool
This method tests for !=
.
sourceimpl Serialize for HttpRouteFilter
impl Serialize for HttpRouteFilter
impl StructuralPartialEq for HttpRouteFilter
Auto Trait Implementations
impl RefUnwindSafe for HttpRouteFilter
impl Send for HttpRouteFilter
impl Sync for HttpRouteFilter
impl Unpin for HttpRouteFilter
impl UnwindSafe for HttpRouteFilter
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more