Documentation ¶
Overview ¶
Package listener is a generated protocol buffer package.
It is generated from these files:
envoy/api/v2/listener/listener.proto
It has these top-level messages:
Filter FilterChainMatch FilterChain ListenerFilter
Index ¶
- Variables
- type Filter
- func (*Filter) Descriptor() ([]byte, []int)
- func (this *Filter) Equal(that interface{}) bool
- func (m *Filter) GetConfig() *google_protobuf.Struct
- func (m *Filter) GetDeprecatedV1() *Filter_DeprecatedV1
- func (m *Filter) GetName() string
- func (m *Filter) Marshal() (dAtA []byte, err error)
- func (m *Filter) MarshalTo(dAtA []byte) (int, error)
- func (*Filter) ProtoMessage()
- func (m *Filter) Reset()
- func (m *Filter) Size() (n int)
- func (m *Filter) String() string
- func (m *Filter) Unmarshal(dAtA []byte) error
- func (m *Filter) Validate() error
- type FilterChain
- func (*FilterChain) Descriptor() ([]byte, []int)
- func (this *FilterChain) Equal(that interface{}) bool
- func (m *FilterChain) GetFilterChainMatch() *FilterChainMatch
- func (m *FilterChain) GetFilters() []Filter
- func (m *FilterChain) GetMetadata() *envoy_api_v2_core.Metadata
- func (m *FilterChain) GetTlsContext() *envoy_api_v2_auth.DownstreamTlsContext
- func (m *FilterChain) GetTransportSocket() *envoy_api_v2_core.TransportSocket
- func (m *FilterChain) GetUseProxyProto() *google_protobuf1.BoolValue
- func (m *FilterChain) Marshal() (dAtA []byte, err error)
- func (m *FilterChain) MarshalTo(dAtA []byte) (int, error)
- func (*FilterChain) ProtoMessage()
- func (m *FilterChain) Reset()
- func (m *FilterChain) Size() (n int)
- func (m *FilterChain) String() string
- func (m *FilterChain) Unmarshal(dAtA []byte) error
- func (m *FilterChain) Validate() error
- type FilterChainMatch
- func (*FilterChainMatch) Descriptor() ([]byte, []int)
- func (this *FilterChainMatch) Equal(that interface{}) bool
- func (m *FilterChainMatch) GetAddressSuffix() string
- func (m *FilterChainMatch) GetApplicationProtocols() []string
- func (m *FilterChainMatch) GetDestinationPort() *google_protobuf1.UInt32Value
- func (m *FilterChainMatch) GetPrefixRanges() []*envoy_api_v2_core1.CidrRange
- func (m *FilterChainMatch) GetServerNames() []string
- func (m *FilterChainMatch) GetSourcePorts() []*google_protobuf1.UInt32Value
- func (m *FilterChainMatch) GetSourcePrefixRanges() []*envoy_api_v2_core1.CidrRange
- func (m *FilterChainMatch) GetSuffixLen() *google_protobuf1.UInt32Value
- func (m *FilterChainMatch) GetTransportProtocol() string
- func (m *FilterChainMatch) Marshal() (dAtA []byte, err error)
- func (m *FilterChainMatch) MarshalTo(dAtA []byte) (int, error)
- func (*FilterChainMatch) ProtoMessage()
- func (m *FilterChainMatch) Reset()
- func (m *FilterChainMatch) Size() (n int)
- func (m *FilterChainMatch) String() string
- func (m *FilterChainMatch) Unmarshal(dAtA []byte) error
- func (m *FilterChainMatch) Validate() error
- type FilterChainMatchValidationError
- type FilterChainValidationError
- type FilterValidationError
- type Filter_DeprecatedV1
- func (*Filter_DeprecatedV1) Descriptor() ([]byte, []int)
- func (this *Filter_DeprecatedV1) Equal(that interface{}) bool
- func (m *Filter_DeprecatedV1) GetType() string
- func (m *Filter_DeprecatedV1) Marshal() (dAtA []byte, err error)
- func (m *Filter_DeprecatedV1) MarshalTo(dAtA []byte) (int, error)
- func (*Filter_DeprecatedV1) ProtoMessage()
- func (m *Filter_DeprecatedV1) Reset()
- func (m *Filter_DeprecatedV1) Size() (n int)
- func (m *Filter_DeprecatedV1) String() string
- func (m *Filter_DeprecatedV1) Unmarshal(dAtA []byte) error
- func (m *Filter_DeprecatedV1) Validate() error
- type Filter_DeprecatedV1ValidationError
- type ListenerFilter
- func (*ListenerFilter) Descriptor() ([]byte, []int)
- func (this *ListenerFilter) Equal(that interface{}) bool
- func (m *ListenerFilter) GetConfig() *google_protobuf.Struct
- func (m *ListenerFilter) GetName() string
- func (m *ListenerFilter) Marshal() (dAtA []byte, err error)
- func (m *ListenerFilter) MarshalTo(dAtA []byte) (int, error)
- func (*ListenerFilter) ProtoMessage()
- func (m *ListenerFilter) Reset()
- func (m *ListenerFilter) Size() (n int)
- func (m *ListenerFilter) String() string
- func (m *ListenerFilter) Unmarshal(dAtA []byte) error
- func (m *ListenerFilter) Validate() error
- type ListenerFilterValidationError
Constants ¶
This section is empty.
Variables ¶
var ( ErrInvalidLengthListener = fmt.Errorf("proto: negative length found during unmarshaling") ErrIntOverflowListener = fmt.Errorf("proto: integer overflow") )
Functions ¶
This section is empty.
Types ¶
type Filter ¶
type Filter struct { // The name of the filter to instantiate. The name must match a supported // filter. The built-in filters are: // // [#comment:TODO(mattklein123): Auto generate the following list] // * :ref:`envoy.client_ssl_auth<config_network_filters_client_ssl_auth>` // * :ref:`envoy.echo <config_network_filters_echo>` // * :ref:`envoy.http_connection_manager <config_http_conn_man>` // * :ref:`envoy.mongo_proxy <config_network_filters_mongo_proxy>` // * :ref:`envoy.ratelimit <config_network_filters_rate_limit>` // * :ref:`envoy.redis_proxy <config_network_filters_redis_proxy>` // * :ref:`envoy.tcp_proxy <config_network_filters_tcp_proxy>` Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` // Filter specific configuration which depends on the filter being // instantiated. See the supported filters for further documentation. Config *google_protobuf.Struct `protobuf:"bytes,2,opt,name=config" json:"config,omitempty"` // [#not-implemented-hide:] DeprecatedV1 *Filter_DeprecatedV1 `protobuf:"bytes,3,opt,name=deprecated_v1,json=deprecatedV1" json:"deprecated_v1,omitempty"` }
func (*Filter) Descriptor ¶
func (*Filter) GetConfig ¶
func (m *Filter) GetConfig() *google_protobuf.Struct
func (*Filter) GetDeprecatedV1 ¶
func (m *Filter) GetDeprecatedV1() *Filter_DeprecatedV1
func (*Filter) ProtoMessage ¶
func (*Filter) ProtoMessage()
type FilterChain ¶
type FilterChain struct { // The criteria to use when matching a connection to this filter chain. FilterChainMatch *FilterChainMatch `protobuf:"bytes,1,opt,name=filter_chain_match,json=filterChainMatch" json:"filter_chain_match,omitempty"` // The TLS context for this filter chain. TlsContext *envoy_api_v2_auth.DownstreamTlsContext `protobuf:"bytes,2,opt,name=tls_context,json=tlsContext" json:"tls_context,omitempty"` // A list of individual network filters that make up the filter chain for // connections established with the listener. Order matters as the filters are // processed sequentially as connection events happen. Note: If the filter // list is empty, the connection will close by default. Filters []Filter `protobuf:"bytes,3,rep,name=filters" json:"filters"` // Whether the listener should expect a PROXY protocol V1 header on new // connections. If this option is enabled, the listener will assume that that // remote address of the connection is the one specified in the header. Some // load balancers including the AWS ELB support this option. If the option is // absent or set to false, Envoy will use the physical peer address of the // connection as the remote address. UseProxyProto *google_protobuf1.BoolValue `protobuf:"bytes,4,opt,name=use_proxy_proto,json=useProxyProto" json:"use_proxy_proto,omitempty"` // [#not-implemented-hide:] filter chain metadata. Metadata *envoy_api_v2_core.Metadata `protobuf:"bytes,5,opt,name=metadata" json:"metadata,omitempty"` // See :ref:`base.TransportSocket<envoy_api_msg_core.TransportSocket>` description. TransportSocket *envoy_api_v2_core.TransportSocket `protobuf:"bytes,6,opt,name=transport_socket,json=transportSocket" json:"transport_socket,omitempty"` }
A filter chain wraps a set of match criteria, an option TLS context, a set of filters, and various other parameters.
func (*FilterChain) Descriptor ¶
func (*FilterChain) Descriptor() ([]byte, []int)
func (*FilterChain) Equal ¶
func (this *FilterChain) Equal(that interface{}) bool
func (*FilterChain) GetFilterChainMatch ¶
func (m *FilterChain) GetFilterChainMatch() *FilterChainMatch
func (*FilterChain) GetFilters ¶
func (m *FilterChain) GetFilters() []Filter
func (*FilterChain) GetMetadata ¶
func (m *FilterChain) GetMetadata() *envoy_api_v2_core.Metadata
func (*FilterChain) GetTlsContext ¶
func (m *FilterChain) GetTlsContext() *envoy_api_v2_auth.DownstreamTlsContext
func (*FilterChain) GetTransportSocket ¶
func (m *FilterChain) GetTransportSocket() *envoy_api_v2_core.TransportSocket
func (*FilterChain) GetUseProxyProto ¶
func (m *FilterChain) GetUseProxyProto() *google_protobuf1.BoolValue
func (*FilterChain) Marshal ¶
func (m *FilterChain) Marshal() (dAtA []byte, err error)
func (*FilterChain) ProtoMessage ¶
func (*FilterChain) ProtoMessage()
func (*FilterChain) Reset ¶
func (m *FilterChain) Reset()
func (*FilterChain) Size ¶
func (m *FilterChain) Size() (n int)
func (*FilterChain) String ¶
func (m *FilterChain) String() string
func (*FilterChain) Unmarshal ¶
func (m *FilterChain) Unmarshal(dAtA []byte) error
func (*FilterChain) Validate ¶
func (m *FilterChain) Validate() error
Validate checks the field values on FilterChain with the rules defined in the proto definition for this message. If any rules are violated, an error is returned.
type FilterChainMatch ¶
type FilterChainMatch struct { // Optional destination port to consider when use_original_dst is set on the // listener in determining a filter chain match. DestinationPort *google_protobuf1.UInt32Value `protobuf:"bytes,8,opt,name=destination_port,json=destinationPort" json:"destination_port,omitempty"` // If non-empty, an IP address and prefix length to match addresses when the // listener is bound to 0.0.0.0/:: or when use_original_dst is specified. PrefixRanges []*envoy_api_v2_core1.CidrRange `protobuf:"bytes,3,rep,name=prefix_ranges,json=prefixRanges" json:"prefix_ranges,omitempty"` // If non-empty, an IP address and suffix length to match addresses when the // listener is bound to 0.0.0.0/:: or when use_original_dst is specified. // [#not-implemented-hide:] AddressSuffix string `protobuf:"bytes,4,opt,name=address_suffix,json=addressSuffix,proto3" json:"address_suffix,omitempty"` // [#not-implemented-hide:] SuffixLen *google_protobuf1.UInt32Value `protobuf:"bytes,5,opt,name=suffix_len,json=suffixLen" json:"suffix_len,omitempty"` // The criteria is satisfied if the source IP address of the downstream // connection is contained in at least one of the specified subnets. If the // parameter is not specified or the list is empty, the source IP address is // ignored. // [#not-implemented-hide:] SourcePrefixRanges []*envoy_api_v2_core1.CidrRange `protobuf:"bytes,6,rep,name=source_prefix_ranges,json=sourcePrefixRanges" json:"source_prefix_ranges,omitempty"` // The criteria is satisfied if the source port of the downstream connection // is contained in at least one of the specified ports. If the parameter is // not specified, the source port is ignored. // [#not-implemented-hide:] SourcePorts []*google_protobuf1.UInt32Value `protobuf:"bytes,7,rep,name=source_ports,json=sourcePorts" json:"source_ports,omitempty"` // If non-empty, a list of server names (e.g. SNI for TLS protocol) to consider when determining // a filter chain match. Those values will be compared against the server names of a new // connection, when detected by one of the listener filters. // // The server name will be matched against all wildcard domains, i.e. “www.example.com“ // will be first matched against “www.example.com“, then “*.example.com“, then “*.com“. // // Note that partial wildcards are not supported, and values like “*w.example.com“ are invalid. // // .. attention:: // // See the :ref:`FAQ entry <faq_how_to_setup_sni>` on how to configure SNI for more // information. ServerNames []string `protobuf:"bytes,11,rep,name=server_names,json=serverNames" json:"server_names,omitempty"` // If non-empty, a transport protocol to consider when determining a filter chain match. // This value will be compared against the transport protocol of a new connection, when // it's detected by one of the listener filters. // // Suggested values include: // // * “raw_buffer“ - default, used when no transport protocol is detected, // * “tls“ - set by :ref:`envoy.listener.tls_inspector <config_listener_filters_tls_inspector>` // when TLS protocol is detected. TransportProtocol string `protobuf:"bytes,9,opt,name=transport_protocol,json=transportProtocol,proto3" json:"transport_protocol,omitempty"` // If non-empty, a list of application protocols (e.g. ALPN for TLS protocol) to consider when // determining a filter chain match. Those values will be compared against the application // protocols of a new connection, when detected by one of the listener filters. // // Suggested values include: // // * “http/1.1“ - set by :ref:`envoy.listener.tls_inspector // <config_listener_filters_tls_inspector>`, // * “h2“ - set by :ref:`envoy.listener.tls_inspector <config_listener_filters_tls_inspector>` // // .. attention:: // // Currently, only :ref:`TLS Inspector <config_listener_filters_tls_inspector>` provides // application protocol detection based on the requested // `ALPN <https://en.wikipedia.org/wiki/Application-Layer_Protocol_Negotiation>`_ values. // // However, the use of ALPN is pretty much limited to the HTTP/2 traffic on the Internet, // and matching on values other than “h2“ is going to lead to a lot of false negatives, // unless all connecting clients are known to use ALPN. ApplicationProtocols []string `protobuf:"bytes,10,rep,name=application_protocols,json=applicationProtocols" json:"application_protocols,omitempty"` }
Specifies the match criteria for selecting a specific filter chain for a listener.
In order for a filter chain to be selected, *ALL* of its criteria must be fulfilled by the incoming connection, properties of which are set by the networking stack and/or listener filters.
The following order applies:
1. Destination port. 2. Destination IP address. 3. Server name (e.g. SNI for TLS protocol), 4. Transport protocol. 5. Application protocols (e.g. ALPN for TLS protocol).
For criterias that allow ranges or wildcards, the most specific value in any of the configured filter chains that matches the incoming connection is going to be used (e.g. for SNI “www.example.com“ the most specific match would be “www.example.com“, then “*.example.com“, then “*.com“, then any filter chain without “server_names“ requirements).
[#comment: Implemented rules are kept in the preference order, with deprecated fields listed at the end, because that's how we want to list them in the docs.
[#comment:TODO(PiotrSikora): Add support for configurable precedence of the rules]
func (*FilterChainMatch) Descriptor ¶
func (*FilterChainMatch) Descriptor() ([]byte, []int)
func (*FilterChainMatch) Equal ¶
func (this *FilterChainMatch) Equal(that interface{}) bool
func (*FilterChainMatch) GetAddressSuffix ¶
func (m *FilterChainMatch) GetAddressSuffix() string
func (*FilterChainMatch) GetApplicationProtocols ¶
func (m *FilterChainMatch) GetApplicationProtocols() []string
func (*FilterChainMatch) GetDestinationPort ¶
func (m *FilterChainMatch) GetDestinationPort() *google_protobuf1.UInt32Value
func (*FilterChainMatch) GetPrefixRanges ¶
func (m *FilterChainMatch) GetPrefixRanges() []*envoy_api_v2_core1.CidrRange
func (*FilterChainMatch) GetServerNames ¶
func (m *FilterChainMatch) GetServerNames() []string
func (*FilterChainMatch) GetSourcePorts ¶
func (m *FilterChainMatch) GetSourcePorts() []*google_protobuf1.UInt32Value
func (*FilterChainMatch) GetSourcePrefixRanges ¶
func (m *FilterChainMatch) GetSourcePrefixRanges() []*envoy_api_v2_core1.CidrRange
func (*FilterChainMatch) GetSuffixLen ¶
func (m *FilterChainMatch) GetSuffixLen() *google_protobuf1.UInt32Value
func (*FilterChainMatch) GetTransportProtocol ¶
func (m *FilterChainMatch) GetTransportProtocol() string
func (*FilterChainMatch) Marshal ¶
func (m *FilterChainMatch) Marshal() (dAtA []byte, err error)
func (*FilterChainMatch) ProtoMessage ¶
func (*FilterChainMatch) ProtoMessage()
func (*FilterChainMatch) Reset ¶
func (m *FilterChainMatch) Reset()
func (*FilterChainMatch) Size ¶
func (m *FilterChainMatch) Size() (n int)
func (*FilterChainMatch) String ¶
func (m *FilterChainMatch) String() string
func (*FilterChainMatch) Unmarshal ¶
func (m *FilterChainMatch) Unmarshal(dAtA []byte) error
func (*FilterChainMatch) Validate ¶
func (m *FilterChainMatch) Validate() error
Validate checks the field values on FilterChainMatch with the rules defined in the proto definition for this message. If any rules are violated, an error is returned.
type FilterChainMatchValidationError ¶
FilterChainMatchValidationError is the validation error returned by FilterChainMatch.Validate if the designated constraints aren't met.
func (FilterChainMatchValidationError) Error ¶
func (e FilterChainMatchValidationError) Error() string
Error satisfies the builtin error interface
type FilterChainValidationError ¶
FilterChainValidationError is the validation error returned by FilterChain.Validate if the designated constraints aren't met.
func (FilterChainValidationError) Error ¶
func (e FilterChainValidationError) Error() string
Error satisfies the builtin error interface
type FilterValidationError ¶
FilterValidationError is the validation error returned by Filter.Validate if the designated constraints aren't met.
func (FilterValidationError) Error ¶
func (e FilterValidationError) Error() string
Error satisfies the builtin error interface
type Filter_DeprecatedV1 ¶
type Filter_DeprecatedV1 struct {
Type string `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"`
}
[#not-implemented-hide:]
func (*Filter_DeprecatedV1) Descriptor ¶
func (*Filter_DeprecatedV1) Descriptor() ([]byte, []int)
func (*Filter_DeprecatedV1) Equal ¶
func (this *Filter_DeprecatedV1) Equal(that interface{}) bool
func (*Filter_DeprecatedV1) GetType ¶
func (m *Filter_DeprecatedV1) GetType() string
func (*Filter_DeprecatedV1) Marshal ¶
func (m *Filter_DeprecatedV1) Marshal() (dAtA []byte, err error)
func (*Filter_DeprecatedV1) MarshalTo ¶
func (m *Filter_DeprecatedV1) MarshalTo(dAtA []byte) (int, error)
func (*Filter_DeprecatedV1) ProtoMessage ¶
func (*Filter_DeprecatedV1) ProtoMessage()
func (*Filter_DeprecatedV1) Reset ¶
func (m *Filter_DeprecatedV1) Reset()
func (*Filter_DeprecatedV1) Size ¶
func (m *Filter_DeprecatedV1) Size() (n int)
func (*Filter_DeprecatedV1) String ¶
func (m *Filter_DeprecatedV1) String() string
func (*Filter_DeprecatedV1) Unmarshal ¶
func (m *Filter_DeprecatedV1) Unmarshal(dAtA []byte) error
func (*Filter_DeprecatedV1) Validate ¶
func (m *Filter_DeprecatedV1) Validate() error
Validate checks the field values on Filter_DeprecatedV1 with the rules defined in the proto definition for this message. If any rules are violated, an error is returned.
type Filter_DeprecatedV1ValidationError ¶
Filter_DeprecatedV1ValidationError is the validation error returned by Filter_DeprecatedV1.Validate if the designated constraints aren't met.
func (Filter_DeprecatedV1ValidationError) Error ¶
func (e Filter_DeprecatedV1ValidationError) Error() string
Error satisfies the builtin error interface
type ListenerFilter ¶
type ListenerFilter struct { // The name of the filter to instantiate. The name must match a supported // filter. The built-in filters are: // // [#comment:TODO(mattklein123): Auto generate the following list] // * :ref:`envoy.listener.original_dst <config_listener_filters_original_dst>` // * :ref:`envoy.listener.tls_inspector <config_listener_filters_tls_inspector>` Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` // Filter specific configuration which depends on the filter being // instantiated. See the supported filters for further documentation. Config *google_protobuf.Struct `protobuf:"bytes,2,opt,name=config" json:"config,omitempty"` }
func (*ListenerFilter) Descriptor ¶
func (*ListenerFilter) Descriptor() ([]byte, []int)
func (*ListenerFilter) Equal ¶
func (this *ListenerFilter) Equal(that interface{}) bool
func (*ListenerFilter) GetConfig ¶
func (m *ListenerFilter) GetConfig() *google_protobuf.Struct
func (*ListenerFilter) GetName ¶
func (m *ListenerFilter) GetName() string
func (*ListenerFilter) Marshal ¶
func (m *ListenerFilter) Marshal() (dAtA []byte, err error)
func (*ListenerFilter) ProtoMessage ¶
func (*ListenerFilter) ProtoMessage()
func (*ListenerFilter) Reset ¶
func (m *ListenerFilter) Reset()
func (*ListenerFilter) Size ¶
func (m *ListenerFilter) Size() (n int)
func (*ListenerFilter) String ¶
func (m *ListenerFilter) String() string
func (*ListenerFilter) Unmarshal ¶
func (m *ListenerFilter) Unmarshal(dAtA []byte) error
func (*ListenerFilter) Validate ¶
func (m *ListenerFilter) Validate() error
Validate checks the field values on ListenerFilter with the rules defined in the proto definition for this message. If any rules are violated, an error is returned.
type ListenerFilterValidationError ¶
ListenerFilterValidationError is the validation error returned by ListenerFilter.Validate if the designated constraints aren't met.
func (ListenerFilterValidationError) Error ¶
func (e ListenerFilterValidationError) Error() string
Error satisfies the builtin error interface