pub enum HttpRouteFilter {
RequestHeaderModifier {
request_header_modifier: HttpRequestHeaderFilter,
},
ResponseHeaderModifier {
response_header_modifier: HttpRequestHeaderFilter,
},
RequestMirror {
request_mirror: HttpRequestMirrorFilter,
},
RequestRedirect {
request_redirect: HttpRequestRedirectFilter,
},
URLRewrite {
url_rewrite: HttpUrlRewriteFilter,
},
ExtensionRef {
extension_ref: 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.
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.
Variants§
RequestHeaderModifier
RequestHeaderModifier defines a schema for a filter that modifies request headers.
Support: Core
Fields
request_header_modifier: HttpRequestHeaderFilter
ResponseHeaderModifier
ResponseHeaderModifier defines a schema for a filter that modifies response headers.
Support: Extended
Fields
response_header_modifier: HttpRequestHeaderFilter
RequestMirror
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
Fields
request_mirror: HttpRequestMirrorFilter
RequestRedirect
RequestRedirect defines a schema for a filter that responds to the request with an HTTP redirection.
Support: Core
Fields
request_redirect: HttpRequestRedirectFilter
URLRewrite
URLRewrite defines a schema for a filter that modifies a request during forwarding.
Support: Extended
Fields
url_rewrite: HttpUrlRewriteFilter
ExtensionRef
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
Fields
extension_ref: LocalObjectReference
Trait Implementations§
Source§impl Clone for HttpRouteFilter
impl Clone for HttpRouteFilter
Source§fn clone(&self) -> HttpRouteFilter
fn clone(&self) -> HttpRouteFilter
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for HttpRouteFilter
impl Debug for HttpRouteFilter
Source§impl<'de> Deserialize<'de> for HttpRouteFilter
impl<'de> Deserialize<'de> for HttpRouteFilter
Source§fn 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>,
Source§impl From<GrpcRouteFilter> for HttpRouteFilter
impl From<GrpcRouteFilter> for HttpRouteFilter
Source§fn from(filter: GrpcRouteFilter) -> Self
fn from(filter: GrpcRouteFilter) -> Self
Source§impl JsonSchema for HttpRouteFilter
impl JsonSchema for HttpRouteFilter
Source§fn schema_name() -> String
fn schema_name() -> String
Source§fn schema_id() -> Cow<'static, str>
fn schema_id() -> Cow<'static, str>
Source§fn json_schema(generator: &mut SchemaGenerator) -> Schema
fn json_schema(generator: &mut SchemaGenerator) -> Schema
Source§fn is_referenceable() -> bool
fn is_referenceable() -> bool
$ref
keyword. Read more