httpv3

package
v1.36.3-20230619202708... Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: unknown License: Apache-2.0 Imports: 7 Imported by: 0

Documentation

Index

Constants

View Source
const HttpProtocolOptions_AutoConfig_case case_HttpProtocolOptions_UpstreamProtocolOptions = 5
View Source
const HttpProtocolOptions_ExplicitHttpConfig_Http2ProtocolOptions_case case_HttpProtocolOptions_ExplicitHttpConfig_ProtocolConfig = 2
View Source
const HttpProtocolOptions_ExplicitHttpConfig_Http3ProtocolOptions_case case_HttpProtocolOptions_ExplicitHttpConfig_ProtocolConfig = 3
View Source
const HttpProtocolOptions_ExplicitHttpConfig_HttpProtocolOptions_case case_HttpProtocolOptions_ExplicitHttpConfig_ProtocolConfig = 1
View Source
const HttpProtocolOptions_ExplicitHttpConfig_ProtocolConfig_not_set_case case_HttpProtocolOptions_ExplicitHttpConfig_ProtocolConfig = 0
View Source
const HttpProtocolOptions_ExplicitHttpConfig_case case_HttpProtocolOptions_UpstreamProtocolOptions = 3
View Source
const HttpProtocolOptions_UpstreamProtocolOptions_not_set_case case_HttpProtocolOptions_UpstreamProtocolOptions = 0
View Source
const HttpProtocolOptions_UseDownstreamProtocolConfig_case case_HttpProtocolOptions_UpstreamProtocolOptions = 4

Variables

View Source
var File_envoy_extensions_upstreams_http_v3_http_protocol_options_proto protoreflect.FileDescriptor

Functions

This section is empty.

Types

type HttpProtocolOptions

type HttpProtocolOptions struct {

	// This contains options common across HTTP/1 and HTTP/2
	CommonHttpProtocolOptions *v3.HttpProtocolOptions `` /* 140-byte string literal not displayed */
	// This contains common protocol options which are only applied upstream.
	UpstreamHttpProtocolOptions *v3.UpstreamHttpProtocolOptions `` /* 146-byte string literal not displayed */
	// This controls the actual protocol to be used upstream.
	//
	// Types that are valid to be assigned to UpstreamProtocolOptions:
	//
	//	*HttpProtocolOptions_ExplicitHttpConfig_
	//	*HttpProtocolOptions_UseDownstreamProtocolConfig
	//	*HttpProtocolOptions_AutoConfig
	UpstreamProtocolOptions isHttpProtocolOptions_UpstreamProtocolOptions `protobuf_oneof:"upstream_protocol_options"`
	// .. note::
	//
	//	Upstream HTTP filters are currently in alpha.
	//
	// Optional HTTP filters for the upstream filter chain.
	//
	// These filters will be applied for all HTTP streams which flow through this
	// cluster. Unlike downstream filters, they will *not* be applied to terminated CONNECT requests.
	//
	// If using upstream filters, please be aware that local errors sent by
	// upstream filters will not trigger retries, and local errors sent by
	// upstream filters will count as a final response if hedging is configured.
	// [#extension-category: envoy.filters.http.upstream]
	HttpFilters []*v31.HttpFilter `protobuf:"bytes,6,rep,name=http_filters,json=httpFilters,proto3" json:"http_filters,omitempty"`
	// Configuration options for Unified Header Validation (UHV).
	// UHV is an extensible mechanism for checking validity of HTTP responses.
	//
	// [#comment:TODO(yanavlasov): Make it a link to the default header validator doc when it becomes visible.]
	// Leaving this field unspecified, selects the default header validator “envoy.http.header_validators.envoy_default“.
	//
	// [#not-implemented-hide:]
	// [#extension-category: envoy.http.header_validators]
	HeaderValidationConfig *v3.TypedExtensionConfig `` /* 129-byte string literal not displayed */
	// contains filtered or unexported fields
}

HttpProtocolOptions specifies Http upstream protocol options. This object is used in :ref:`typed_extension_protocol_options<envoy_v3_api_field_config.cluster.v3.Cluster.typed_extension_protocol_options>`, keyed by the name “envoy.extensions.upstreams.http.v3.HttpProtocolOptions“.

This controls what protocol(s) should be used for upstream and how said protocol(s) are configured.

This replaces the prior pattern of explicit protocol configuration directly in the cluster. So a configuration like this, explicitly configuring the use of HTTP/2 upstream:

.. code::

clusters:
  - name: some_service
    connect_timeout: 5s
    upstream_http_protocol_options:
      auto_sni: true
    common_http_protocol_options:
      idle_timeout: 1s
    http2_protocol_options:
      max_concurrent_streams: 100
     .... [further cluster config]

Would now look like this:

.. code::

clusters:
  - name: some_service
    connect_timeout: 5s
    typed_extension_protocol_options:
      envoy.extensions.upstreams.http.v3.HttpProtocolOptions:
        "@type": type.googleapis.com/envoy.extensions.upstreams.http.v3.HttpProtocolOptions
        upstream_http_protocol_options:
          auto_sni: true
        common_http_protocol_options:
          idle_timeout: 1s
        explicit_http_config:
          http2_protocol_options:
            max_concurrent_streams: 100
     .... [further cluster config]

[#next-free-field: 8]

func (*HttpProtocolOptions) ClearAutoConfig

func (x *HttpProtocolOptions) ClearAutoConfig()

func (*HttpProtocolOptions) ClearCommonHttpProtocolOptions

func (x *HttpProtocolOptions) ClearCommonHttpProtocolOptions()

func (*HttpProtocolOptions) ClearExplicitHttpConfig

func (x *HttpProtocolOptions) ClearExplicitHttpConfig()

func (*HttpProtocolOptions) ClearHeaderValidationConfig

func (x *HttpProtocolOptions) ClearHeaderValidationConfig()

func (*HttpProtocolOptions) ClearUpstreamHttpProtocolOptions

func (x *HttpProtocolOptions) ClearUpstreamHttpProtocolOptions()

func (*HttpProtocolOptions) ClearUpstreamProtocolOptions

func (x *HttpProtocolOptions) ClearUpstreamProtocolOptions()

func (*HttpProtocolOptions) ClearUseDownstreamProtocolConfig

func (x *HttpProtocolOptions) ClearUseDownstreamProtocolConfig()

func (*HttpProtocolOptions) GetAutoConfig

func (*HttpProtocolOptions) GetCommonHttpProtocolOptions

func (x *HttpProtocolOptions) GetCommonHttpProtocolOptions() *v3.HttpProtocolOptions

func (*HttpProtocolOptions) GetExplicitHttpConfig

func (x *HttpProtocolOptions) GetExplicitHttpConfig() *HttpProtocolOptions_ExplicitHttpConfig

func (*HttpProtocolOptions) GetHeaderValidationConfig

func (x *HttpProtocolOptions) GetHeaderValidationConfig() *v3.TypedExtensionConfig

func (*HttpProtocolOptions) GetHttpFilters

func (x *HttpProtocolOptions) GetHttpFilters() []*v31.HttpFilter

func (*HttpProtocolOptions) GetUpstreamHttpProtocolOptions

func (x *HttpProtocolOptions) GetUpstreamHttpProtocolOptions() *v3.UpstreamHttpProtocolOptions

func (*HttpProtocolOptions) GetUpstreamProtocolOptions

func (x *HttpProtocolOptions) GetUpstreamProtocolOptions() isHttpProtocolOptions_UpstreamProtocolOptions

func (*HttpProtocolOptions) GetUseDownstreamProtocolConfig

func (x *HttpProtocolOptions) GetUseDownstreamProtocolConfig() *HttpProtocolOptions_UseDownstreamHttpConfig

func (*HttpProtocolOptions) HasAutoConfig

func (x *HttpProtocolOptions) HasAutoConfig() bool

func (*HttpProtocolOptions) HasCommonHttpProtocolOptions

func (x *HttpProtocolOptions) HasCommonHttpProtocolOptions() bool

func (*HttpProtocolOptions) HasExplicitHttpConfig

func (x *HttpProtocolOptions) HasExplicitHttpConfig() bool

func (*HttpProtocolOptions) HasHeaderValidationConfig

func (x *HttpProtocolOptions) HasHeaderValidationConfig() bool

func (*HttpProtocolOptions) HasUpstreamHttpProtocolOptions

func (x *HttpProtocolOptions) HasUpstreamHttpProtocolOptions() bool

func (*HttpProtocolOptions) HasUpstreamProtocolOptions

func (x *HttpProtocolOptions) HasUpstreamProtocolOptions() bool

func (*HttpProtocolOptions) HasUseDownstreamProtocolConfig

func (x *HttpProtocolOptions) HasUseDownstreamProtocolConfig() bool

func (*HttpProtocolOptions) ProtoMessage

func (*HttpProtocolOptions) ProtoMessage()

func (*HttpProtocolOptions) ProtoReflect

func (x *HttpProtocolOptions) ProtoReflect() protoreflect.Message

func (*HttpProtocolOptions) Reset

func (x *HttpProtocolOptions) Reset()

func (*HttpProtocolOptions) SetAutoConfig

func (*HttpProtocolOptions) SetCommonHttpProtocolOptions

func (x *HttpProtocolOptions) SetCommonHttpProtocolOptions(v *v3.HttpProtocolOptions)

func (*HttpProtocolOptions) SetExplicitHttpConfig

func (x *HttpProtocolOptions) SetExplicitHttpConfig(v *HttpProtocolOptions_ExplicitHttpConfig)

func (*HttpProtocolOptions) SetHeaderValidationConfig

func (x *HttpProtocolOptions) SetHeaderValidationConfig(v *v3.TypedExtensionConfig)

func (*HttpProtocolOptions) SetHttpFilters

func (x *HttpProtocolOptions) SetHttpFilters(v []*v31.HttpFilter)

func (*HttpProtocolOptions) SetUpstreamHttpProtocolOptions

func (x *HttpProtocolOptions) SetUpstreamHttpProtocolOptions(v *v3.UpstreamHttpProtocolOptions)

func (*HttpProtocolOptions) SetUseDownstreamProtocolConfig

func (x *HttpProtocolOptions) SetUseDownstreamProtocolConfig(v *HttpProtocolOptions_UseDownstreamHttpConfig)

func (*HttpProtocolOptions) String

func (x *HttpProtocolOptions) String() string

func (*HttpProtocolOptions) WhichUpstreamProtocolOptions

func (x *HttpProtocolOptions) WhichUpstreamProtocolOptions() case_HttpProtocolOptions_UpstreamProtocolOptions

type HttpProtocolOptions_AutoConfig

type HttpProtocolOptions_AutoConfig struct {
	// This allows switching on protocol based on ALPN
	AutoConfig *HttpProtocolOptions_AutoHttpConfig `protobuf:"bytes,5,opt,name=auto_config,json=autoConfig,proto3,oneof"`
}

type HttpProtocolOptions_AutoHttpConfig

type HttpProtocolOptions_AutoHttpConfig struct {
	HttpProtocolOptions  *v3.Http1ProtocolOptions `protobuf:"bytes,1,opt,name=http_protocol_options,json=httpProtocolOptions,proto3" json:"http_protocol_options,omitempty"`
	Http2ProtocolOptions *v3.Http2ProtocolOptions `protobuf:"bytes,2,opt,name=http2_protocol_options,json=http2ProtocolOptions,proto3" json:"http2_protocol_options,omitempty"`
	// Unlike HTTP/1 and HTTP/2, HTTP/3 will not be configured unless it is
	// present, and (soon) only if there is an indication of server side
	// support.
	// See :ref:`here <arch_overview_http3_upstream>` for more information on
	// when HTTP/3 will be used, and when Envoy will fail over to TCP.
	//
	// .. warning::
	//
	//	QUIC upstream support is currently not ready for internet use.
	//	Please see :ref:`here <arch_overview_http3>` for details.
	Http3ProtocolOptions *v3.Http3ProtocolOptions `protobuf:"bytes,3,opt,name=http3_protocol_options,json=http3ProtocolOptions,proto3" json:"http3_protocol_options,omitempty"`
	// The presence of alternate protocols cache options causes the use of the
	// alternate protocols cache, which is responsible for parsing and caching
	// HTTP Alt-Svc headers. This enables the use of HTTP/3 for origins that
	// advertise supporting it.
	//
	// .. note::
	//
	//	This is required when HTTP/3 is enabled.
	AlternateProtocolsCacheOptions *v3.AlternateProtocolsCacheOptions `` /* 155-byte string literal not displayed */
	// contains filtered or unexported fields
}

If this is used, the cluster can use either HTTP/1 or HTTP/2, and will use whichever protocol is negotiated by ALPN with the upstream. Clusters configured with “AutoHttpConfig“ will use the highest available protocol; HTTP/2 if supported, otherwise HTTP/1. If the upstream does not support ALPN, “AutoHttpConfig“ will fail over to HTTP/1. This can only be used with transport sockets which support ALPN. Using a transport socket which does not support ALPN will result in configuration failure. The transport layer may be configured with custom ALPN, but the default ALPN for the cluster (or if custom ALPN fails) will be "h2,http/1.1".

func (*HttpProtocolOptions_AutoHttpConfig) ClearAlternateProtocolsCacheOptions

func (x *HttpProtocolOptions_AutoHttpConfig) ClearAlternateProtocolsCacheOptions()

func (*HttpProtocolOptions_AutoHttpConfig) ClearHttp2ProtocolOptions

func (x *HttpProtocolOptions_AutoHttpConfig) ClearHttp2ProtocolOptions()

func (*HttpProtocolOptions_AutoHttpConfig) ClearHttp3ProtocolOptions

func (x *HttpProtocolOptions_AutoHttpConfig) ClearHttp3ProtocolOptions()

func (*HttpProtocolOptions_AutoHttpConfig) ClearHttpProtocolOptions

func (x *HttpProtocolOptions_AutoHttpConfig) ClearHttpProtocolOptions()

func (*HttpProtocolOptions_AutoHttpConfig) GetAlternateProtocolsCacheOptions

func (x *HttpProtocolOptions_AutoHttpConfig) GetAlternateProtocolsCacheOptions() *v3.AlternateProtocolsCacheOptions

func (*HttpProtocolOptions_AutoHttpConfig) GetHttp2ProtocolOptions

func (x *HttpProtocolOptions_AutoHttpConfig) GetHttp2ProtocolOptions() *v3.Http2ProtocolOptions

func (*HttpProtocolOptions_AutoHttpConfig) GetHttp3ProtocolOptions

func (x *HttpProtocolOptions_AutoHttpConfig) GetHttp3ProtocolOptions() *v3.Http3ProtocolOptions

func (*HttpProtocolOptions_AutoHttpConfig) GetHttpProtocolOptions

func (x *HttpProtocolOptions_AutoHttpConfig) GetHttpProtocolOptions() *v3.Http1ProtocolOptions

func (*HttpProtocolOptions_AutoHttpConfig) HasAlternateProtocolsCacheOptions

func (x *HttpProtocolOptions_AutoHttpConfig) HasAlternateProtocolsCacheOptions() bool

func (*HttpProtocolOptions_AutoHttpConfig) HasHttp2ProtocolOptions

func (x *HttpProtocolOptions_AutoHttpConfig) HasHttp2ProtocolOptions() bool

func (*HttpProtocolOptions_AutoHttpConfig) HasHttp3ProtocolOptions

func (x *HttpProtocolOptions_AutoHttpConfig) HasHttp3ProtocolOptions() bool

func (*HttpProtocolOptions_AutoHttpConfig) HasHttpProtocolOptions

func (x *HttpProtocolOptions_AutoHttpConfig) HasHttpProtocolOptions() bool

func (*HttpProtocolOptions_AutoHttpConfig) ProtoMessage

func (*HttpProtocolOptions_AutoHttpConfig) ProtoMessage()

func (*HttpProtocolOptions_AutoHttpConfig) ProtoReflect

func (*HttpProtocolOptions_AutoHttpConfig) Reset

func (*HttpProtocolOptions_AutoHttpConfig) SetAlternateProtocolsCacheOptions

func (x *HttpProtocolOptions_AutoHttpConfig) SetAlternateProtocolsCacheOptions(v *v3.AlternateProtocolsCacheOptions)

func (*HttpProtocolOptions_AutoHttpConfig) SetHttp2ProtocolOptions

func (x *HttpProtocolOptions_AutoHttpConfig) SetHttp2ProtocolOptions(v *v3.Http2ProtocolOptions)

func (*HttpProtocolOptions_AutoHttpConfig) SetHttp3ProtocolOptions

func (x *HttpProtocolOptions_AutoHttpConfig) SetHttp3ProtocolOptions(v *v3.Http3ProtocolOptions)

func (*HttpProtocolOptions_AutoHttpConfig) SetHttpProtocolOptions

func (x *HttpProtocolOptions_AutoHttpConfig) SetHttpProtocolOptions(v *v3.Http1ProtocolOptions)

func (*HttpProtocolOptions_AutoHttpConfig) String

type HttpProtocolOptions_AutoHttpConfig_builder

type HttpProtocolOptions_AutoHttpConfig_builder struct {
	HttpProtocolOptions  *v3.Http1ProtocolOptions
	Http2ProtocolOptions *v3.Http2ProtocolOptions
	// Unlike HTTP/1 and HTTP/2, HTTP/3 will not be configured unless it is
	// present, and (soon) only if there is an indication of server side
	// support.
	// See :ref:`here <arch_overview_http3_upstream>` for more information on
	// when HTTP/3 will be used, and when Envoy will fail over to TCP.
	//
	// .. warning::
	//
	//	QUIC upstream support is currently not ready for internet use.
	//	Please see :ref:`here <arch_overview_http3>` for details.
	Http3ProtocolOptions *v3.Http3ProtocolOptions
	// The presence of alternate protocols cache options causes the use of the
	// alternate protocols cache, which is responsible for parsing and caching
	// HTTP Alt-Svc headers. This enables the use of HTTP/3 for origins that
	// advertise supporting it.
	//
	// .. note::
	//
	//	This is required when HTTP/3 is enabled.
	AlternateProtocolsCacheOptions *v3.AlternateProtocolsCacheOptions
	// contains filtered or unexported fields
}

func (HttpProtocolOptions_AutoHttpConfig_builder) Build

type HttpProtocolOptions_ExplicitHttpConfig

type HttpProtocolOptions_ExplicitHttpConfig struct {

	// Types that are valid to be assigned to ProtocolConfig:
	//
	//	*HttpProtocolOptions_ExplicitHttpConfig_HttpProtocolOptions
	//	*HttpProtocolOptions_ExplicitHttpConfig_Http2ProtocolOptions
	//	*HttpProtocolOptions_ExplicitHttpConfig_Http3ProtocolOptions
	ProtocolConfig isHttpProtocolOptions_ExplicitHttpConfig_ProtocolConfig `protobuf_oneof:"protocol_config"`
	// contains filtered or unexported fields
}

If this is used, the cluster will only operate on one of the possible upstream protocols. Note that HTTP/2 or above should generally be used for upstream gRPC clusters.

func (*HttpProtocolOptions_ExplicitHttpConfig) ClearHttp2ProtocolOptions

func (x *HttpProtocolOptions_ExplicitHttpConfig) ClearHttp2ProtocolOptions()

func (*HttpProtocolOptions_ExplicitHttpConfig) ClearHttp3ProtocolOptions

func (x *HttpProtocolOptions_ExplicitHttpConfig) ClearHttp3ProtocolOptions()

func (*HttpProtocolOptions_ExplicitHttpConfig) ClearHttpProtocolOptions

func (x *HttpProtocolOptions_ExplicitHttpConfig) ClearHttpProtocolOptions()

func (*HttpProtocolOptions_ExplicitHttpConfig) ClearProtocolConfig

func (x *HttpProtocolOptions_ExplicitHttpConfig) ClearProtocolConfig()

func (*HttpProtocolOptions_ExplicitHttpConfig) GetHttp2ProtocolOptions

func (x *HttpProtocolOptions_ExplicitHttpConfig) GetHttp2ProtocolOptions() *v3.Http2ProtocolOptions

func (*HttpProtocolOptions_ExplicitHttpConfig) GetHttp3ProtocolOptions

func (x *HttpProtocolOptions_ExplicitHttpConfig) GetHttp3ProtocolOptions() *v3.Http3ProtocolOptions

func (*HttpProtocolOptions_ExplicitHttpConfig) GetHttpProtocolOptions

func (x *HttpProtocolOptions_ExplicitHttpConfig) GetHttpProtocolOptions() *v3.Http1ProtocolOptions

func (*HttpProtocolOptions_ExplicitHttpConfig) GetProtocolConfig

func (x *HttpProtocolOptions_ExplicitHttpConfig) GetProtocolConfig() isHttpProtocolOptions_ExplicitHttpConfig_ProtocolConfig

func (*HttpProtocolOptions_ExplicitHttpConfig) HasHttp2ProtocolOptions

func (x *HttpProtocolOptions_ExplicitHttpConfig) HasHttp2ProtocolOptions() bool

func (*HttpProtocolOptions_ExplicitHttpConfig) HasHttp3ProtocolOptions

func (x *HttpProtocolOptions_ExplicitHttpConfig) HasHttp3ProtocolOptions() bool

func (*HttpProtocolOptions_ExplicitHttpConfig) HasHttpProtocolOptions

func (x *HttpProtocolOptions_ExplicitHttpConfig) HasHttpProtocolOptions() bool

func (*HttpProtocolOptions_ExplicitHttpConfig) HasProtocolConfig

func (x *HttpProtocolOptions_ExplicitHttpConfig) HasProtocolConfig() bool

func (*HttpProtocolOptions_ExplicitHttpConfig) ProtoMessage

func (*HttpProtocolOptions_ExplicitHttpConfig) ProtoReflect

func (*HttpProtocolOptions_ExplicitHttpConfig) Reset

func (*HttpProtocolOptions_ExplicitHttpConfig) SetHttp2ProtocolOptions

func (x *HttpProtocolOptions_ExplicitHttpConfig) SetHttp2ProtocolOptions(v *v3.Http2ProtocolOptions)

func (*HttpProtocolOptions_ExplicitHttpConfig) SetHttp3ProtocolOptions

func (x *HttpProtocolOptions_ExplicitHttpConfig) SetHttp3ProtocolOptions(v *v3.Http3ProtocolOptions)

func (*HttpProtocolOptions_ExplicitHttpConfig) SetHttpProtocolOptions

func (x *HttpProtocolOptions_ExplicitHttpConfig) SetHttpProtocolOptions(v *v3.Http1ProtocolOptions)

func (*HttpProtocolOptions_ExplicitHttpConfig) String

func (*HttpProtocolOptions_ExplicitHttpConfig) WhichProtocolConfig

func (x *HttpProtocolOptions_ExplicitHttpConfig) WhichProtocolConfig() case_HttpProtocolOptions_ExplicitHttpConfig_ProtocolConfig

type HttpProtocolOptions_ExplicitHttpConfig_

type HttpProtocolOptions_ExplicitHttpConfig_ struct {
	// To explicitly configure either HTTP/1 or HTTP/2 (but not both!) use “explicit_http_config“.
	// If the “explicit_http_config“ is empty, HTTP/1.1 is used.
	ExplicitHttpConfig *HttpProtocolOptions_ExplicitHttpConfig `protobuf:"bytes,3,opt,name=explicit_http_config,json=explicitHttpConfig,proto3,oneof"`
}

type HttpProtocolOptions_ExplicitHttpConfig_Http2ProtocolOptions

type HttpProtocolOptions_ExplicitHttpConfig_Http2ProtocolOptions struct {
	Http2ProtocolOptions *v3.Http2ProtocolOptions `protobuf:"bytes,2,opt,name=http2_protocol_options,json=http2ProtocolOptions,proto3,oneof"`
}

type HttpProtocolOptions_ExplicitHttpConfig_Http3ProtocolOptions

type HttpProtocolOptions_ExplicitHttpConfig_Http3ProtocolOptions struct {
	// .. warning::
	//
	//	QUIC upstream support is currently not ready for internet use.
	//	Please see :ref:`here <arch_overview_http3>` for details.
	Http3ProtocolOptions *v3.Http3ProtocolOptions `protobuf:"bytes,3,opt,name=http3_protocol_options,json=http3ProtocolOptions,proto3,oneof"`
}

type HttpProtocolOptions_ExplicitHttpConfig_HttpProtocolOptions

type HttpProtocolOptions_ExplicitHttpConfig_HttpProtocolOptions struct {
	HttpProtocolOptions *v3.Http1ProtocolOptions `protobuf:"bytes,1,opt,name=http_protocol_options,json=httpProtocolOptions,proto3,oneof"`
}

type HttpProtocolOptions_ExplicitHttpConfig_builder

type HttpProtocolOptions_ExplicitHttpConfig_builder struct {

	// Fields of oneof ProtocolConfig:
	HttpProtocolOptions  *v3.Http1ProtocolOptions
	Http2ProtocolOptions *v3.Http2ProtocolOptions
	// .. warning::
	//
	//	QUIC upstream support is currently not ready for internet use.
	//	Please see :ref:`here <arch_overview_http3>` for details.
	Http3ProtocolOptions *v3.Http3ProtocolOptions
	// contains filtered or unexported fields
}

func (HttpProtocolOptions_ExplicitHttpConfig_builder) Build

type HttpProtocolOptions_UseDownstreamHttpConfig

type HttpProtocolOptions_UseDownstreamHttpConfig struct {
	HttpProtocolOptions  *v3.Http1ProtocolOptions `protobuf:"bytes,1,opt,name=http_protocol_options,json=httpProtocolOptions,proto3" json:"http_protocol_options,omitempty"`
	Http2ProtocolOptions *v3.Http2ProtocolOptions `protobuf:"bytes,2,opt,name=http2_protocol_options,json=http2ProtocolOptions,proto3" json:"http2_protocol_options,omitempty"`
	// .. warning::
	//
	//	QUIC upstream support is currently not ready for internet use.
	//	Please see :ref:`here <arch_overview_http3>` for details.
	Http3ProtocolOptions *v3.Http3ProtocolOptions `protobuf:"bytes,3,opt,name=http3_protocol_options,json=http3ProtocolOptions,proto3" json:"http3_protocol_options,omitempty"`
	// contains filtered or unexported fields
}

If this is used, the cluster can use either of the configured protocols, and will use whichever protocol was used by the downstream connection.

If HTTP/3 is configured for downstream and not configured for upstream, HTTP/3 requests will fail over to HTTP/2.

func (*HttpProtocolOptions_UseDownstreamHttpConfig) ClearHttp2ProtocolOptions

func (x *HttpProtocolOptions_UseDownstreamHttpConfig) ClearHttp2ProtocolOptions()

func (*HttpProtocolOptions_UseDownstreamHttpConfig) ClearHttp3ProtocolOptions

func (x *HttpProtocolOptions_UseDownstreamHttpConfig) ClearHttp3ProtocolOptions()

func (*HttpProtocolOptions_UseDownstreamHttpConfig) ClearHttpProtocolOptions

func (x *HttpProtocolOptions_UseDownstreamHttpConfig) ClearHttpProtocolOptions()

func (*HttpProtocolOptions_UseDownstreamHttpConfig) GetHttp2ProtocolOptions

func (*HttpProtocolOptions_UseDownstreamHttpConfig) GetHttp3ProtocolOptions

func (*HttpProtocolOptions_UseDownstreamHttpConfig) GetHttpProtocolOptions

func (*HttpProtocolOptions_UseDownstreamHttpConfig) HasHttp2ProtocolOptions

func (x *HttpProtocolOptions_UseDownstreamHttpConfig) HasHttp2ProtocolOptions() bool

func (*HttpProtocolOptions_UseDownstreamHttpConfig) HasHttp3ProtocolOptions

func (x *HttpProtocolOptions_UseDownstreamHttpConfig) HasHttp3ProtocolOptions() bool

func (*HttpProtocolOptions_UseDownstreamHttpConfig) HasHttpProtocolOptions

func (x *HttpProtocolOptions_UseDownstreamHttpConfig) HasHttpProtocolOptions() bool

func (*HttpProtocolOptions_UseDownstreamHttpConfig) ProtoMessage

func (*HttpProtocolOptions_UseDownstreamHttpConfig) ProtoReflect

func (*HttpProtocolOptions_UseDownstreamHttpConfig) Reset

func (*HttpProtocolOptions_UseDownstreamHttpConfig) SetHttp2ProtocolOptions

func (*HttpProtocolOptions_UseDownstreamHttpConfig) SetHttp3ProtocolOptions

func (*HttpProtocolOptions_UseDownstreamHttpConfig) SetHttpProtocolOptions

func (*HttpProtocolOptions_UseDownstreamHttpConfig) String

type HttpProtocolOptions_UseDownstreamHttpConfig_builder

type HttpProtocolOptions_UseDownstreamHttpConfig_builder struct {
	HttpProtocolOptions  *v3.Http1ProtocolOptions
	Http2ProtocolOptions *v3.Http2ProtocolOptions
	// .. warning::
	//
	//	QUIC upstream support is currently not ready for internet use.
	//	Please see :ref:`here <arch_overview_http3>` for details.
	Http3ProtocolOptions *v3.Http3ProtocolOptions
	// contains filtered or unexported fields
}

func (HttpProtocolOptions_UseDownstreamHttpConfig_builder) Build

type HttpProtocolOptions_UseDownstreamProtocolConfig

type HttpProtocolOptions_UseDownstreamProtocolConfig struct {
	// This allows switching on protocol based on what protocol the downstream
	// connection used.
	UseDownstreamProtocolConfig *HttpProtocolOptions_UseDownstreamHttpConfig `protobuf:"bytes,4,opt,name=use_downstream_protocol_config,json=useDownstreamProtocolConfig,proto3,oneof"`
}

type HttpProtocolOptions_builder

type HttpProtocolOptions_builder struct {

	// This contains options common across HTTP/1 and HTTP/2
	CommonHttpProtocolOptions *v3.HttpProtocolOptions
	// This contains common protocol options which are only applied upstream.
	UpstreamHttpProtocolOptions *v3.UpstreamHttpProtocolOptions

	// Fields of oneof UpstreamProtocolOptions:
	// To explicitly configure either HTTP/1 or HTTP/2 (but not both!) use “explicit_http_config“.
	// If the “explicit_http_config“ is empty, HTTP/1.1 is used.
	ExplicitHttpConfig *HttpProtocolOptions_ExplicitHttpConfig
	// This allows switching on protocol based on what protocol the downstream
	// connection used.
	UseDownstreamProtocolConfig *HttpProtocolOptions_UseDownstreamHttpConfig
	// This allows switching on protocol based on ALPN
	AutoConfig *HttpProtocolOptions_AutoHttpConfig
	// -- end of UpstreamProtocolOptions
	// .. note::
	//
	//	Upstream HTTP filters are currently in alpha.
	//
	// Optional HTTP filters for the upstream filter chain.
	//
	// These filters will be applied for all HTTP streams which flow through this
	// cluster. Unlike downstream filters, they will *not* be applied to terminated CONNECT requests.
	//
	// If using upstream filters, please be aware that local errors sent by
	// upstream filters will not trigger retries, and local errors sent by
	// upstream filters will count as a final response if hedging is configured.
	// [#extension-category: envoy.filters.http.upstream]
	HttpFilters []*v31.HttpFilter
	// Configuration options for Unified Header Validation (UHV).
	// UHV is an extensible mechanism for checking validity of HTTP responses.
	//
	// [#comment:TODO(yanavlasov): Make it a link to the default header validator doc when it becomes visible.]
	// Leaving this field unspecified, selects the default header validator “envoy.http.header_validators.envoy_default“.
	//
	// [#not-implemented-hide:]
	// [#extension-category: envoy.http.header_validators]
	HeaderValidationConfig *v3.TypedExtensionConfig
	// contains filtered or unexported fields
}

func (HttpProtocolOptions_builder) Build

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL