linkerd2/policy-controller/k8s/index
Alex Leong 393c22553b
Add support for consumer routes (#11118)
The [xRoute Binding KEP](https://gateway-api.sigs.k8s.io/geps/gep-1426/#namespace-boundaries) states that HttpRoutes may be created in either the namespace of their parent Service (producer routes) or in the namespace of the client initiating requests to the service (consumer routes).  Linkerd currently only indexes producer routes and ignores consumer routes.

We add support for consumer routes by changing the way that HttpRoutes are indexed.  We now index each route by the namespace of its parent service instead of by the namespace of the HttpRoute resource.  We then further subdivide the `ServiceRoutes` struct to have a watch per-client-namespace instead of just a single watch.  This is because clients from different namespaces will have a different view of the routes for a service.

When an HttpRoute is updated, if it is a producer route, we apply that HttpRoute to watches for all of the client namespaces.  If the route was a consumer route, then we only apply the HttpRoute to watches for that consumer namespace.

We also add API tests for consumer and producer routes.

A few noteworthy changes:
* Because the namespace of the client factors into the lookup, we had to change the discovery target to a type which includes the client namespace.
* Because a service may have routes from different namespaces, the route metadata now needs to track group, kind, name, AND namespace instead of just using the namespace of the service.  This means that many uses of the `GroupKindName` type are replaced with a `GroupKindNamespaceName` type.

Signed-off-by: Alex Leong <alex@buoyant.io>
2023-07-25 14:23:28 -07:00
..
src Add support for consumer routes (#11118) 2023-07-25 14:23:28 -07:00
Cargo.toml Policy controller watches gateway-api HttpRoutes (#11042) 2023-07-03 15:48:49 -07:00