consul/agent/xds
Freddy 00b5b0a0a2
Update filter chain creation for sidecar/ingress listeners (#11245)
The duo of `makeUpstreamFilterChainForDiscoveryChain` and `makeListenerForDiscoveryChain` were really hard to reason about, and led to concealing a bug in their branching logic. There were several issues here:

- They tried to accomplish too much: determining filter name, cluster name, and whether RDS should be used. 
- They embedded logic to handle significantly different kinds of upstream listeners (passthrough, prepared query, typical services, and catch-all)
- They needed to coalesce different data sources (Upstream and CompiledDiscoveryChain)

Rather than handling all of those tasks inside of these functions, this PR pulls out the RDS/clusterName/filterName logic.

This refactor also fixed a bug with the handling of [UpstreamDefaults](https://www.consul.io/docs/connect/config-entries/service-defaults#defaults). These defaults get stored as UpstreamConfig in the proxy snapshot with a DestinationName of "*", since they apply to all upstreams. However, this wildcard destination name must not be used when creating the name of the associated upstream cluster. The coalescing logic in the original functions here was in some situations creating clusters with a `*.` prefix, which is not a valid destination.
2021-11-09 14:43:51 -07:00
..
proxysupport
testdata Update filter chain creation for sidecar/ingress listeners (#11245) 2021-11-09 14:43:51 -07:00
clusters.go Store GatewayKey in proxycfg snapshot for re-use 2021-11-01 13:58:53 -06:00
clusters_test.go
config.go
config_test.go
delta.go
delta_test.go acl: remove id and revision from Policy constructors 2021-11-05 15:45:08 -04:00
endpoints.go xds: prefer fed state gateway definitions if they're fresher (#11522) 2021-11-09 16:45:36 +00:00
endpoints_test.go xds: prefer fed state gateway definitions if they're fresher (#11522) 2021-11-09 16:45:36 +00:00
envoy_versioning.go
envoy_versioning_test.go
failover_math.go
failover_math_test.go
golden_test.go
listeners.go Update filter chain creation for sidecar/ingress listeners (#11245) 2021-11-09 14:43:51 -07:00
listeners_ingress.go Update filter chain creation for sidecar/ingress listeners (#11245) 2021-11-09 14:43:51 -07:00
listeners_test.go Update filter chain creation for sidecar/ingress listeners (#11245) 2021-11-09 14:43:51 -07:00
naming.go
net_fallback.go
net_linux.go
protocol_trace.go
rbac.go
rbac_test.go
resources.go
response.go
routes.go
routes_test.go
server.go
server_oss.go
testing.go
xds.go
xds_protocol_helpers_test.go
z_xds_packages.go
z_xds_packages_test.go