Skip to content

Commit

Permalink
feat(httproute): add ReferenceGrant watch
Browse files Browse the repository at this point in the history
  • Loading branch information
pmalek committed Mar 20, 2023
1 parent 2244c59 commit ac5a4d7
Showing 1 changed file with 58 additions and 0 deletions.
58 changes: 58 additions & 0 deletions internal/controllers/gateway/httproute_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,16 @@ func (r *HTTPRouteReconciler) SetupWithManager(mgr ctrl.Manager) error {
return err
}

if r.EnableReferenceGrant {
if err := c.Watch(
&source.Kind{Type: &gatewayv1beta1.ReferenceGrant{}},
handler.EnqueueRequestsFromMapFunc(r.listReferenceGrantsForHTTPRoute),
predicate.NewPredicateFuncs(referenceGrantHasHTTPRouteFrom),
); err != nil {
return err
}
}

// because of the additional burden of having to manage reference data-plane
// configurations for HTTPRoute objects in the underlying Kong Gateway, we
// simply reconcile ALL HTTPRoute objects. This allows us to drop the backend
Expand All @@ -102,6 +112,54 @@ func (r *HTTPRouteReconciler) SetupWithManager(mgr ctrl.Manager) error {
// HTTPRoute Controller - Event Handlers
// -----------------------------------------------------------------------------

// listReferenceGrantsForHTTPRoute is a watch predicate which finds all HTTPRoutes
// mentioned in a From clause for a ReferenceGrant.
func (r *HTTPRouteReconciler) listReferenceGrantsForHTTPRoute(obj client.Object) []reconcile.Request {
grant, ok := obj.(*gatewayv1beta1.ReferenceGrant)
if !ok {
r.Log.Error(
fmt.Errorf("unexpected object type"),
"referencegrant watch predicate received unexpected object type",
"expected", "*gatewayv1beta1.ReferenceGrant", "found", reflect.TypeOf(obj),
)
return nil
}
httproutes := &gatewayv1beta1.HTTPRouteList{}
if err := r.Client.List(context.Background(), httproutes); err != nil {
r.Log.Error(err, "failed to list httproutes in watch", "referencegrant", grant.Name)
return nil
}
recs := []reconcile.Request{}
for _, gateway := range httproutes.Items {
for _, from := range grant.Spec.From {
if string(from.Namespace) == gateway.Namespace &&
from.Kind == gatewayv1beta1.Kind("HTTPRoute") &&
from.Group == gatewayv1beta1.Group("gateway.networking.k8s.io") {
recs = append(recs, reconcile.Request{
NamespacedName: types.NamespacedName{
Namespace: gateway.Namespace,
Name: gateway.Name,
},
})
}
}
}
return recs
}

func referenceGrantHasHTTPRouteFrom(obj client.Object) bool {
grant, ok := obj.(*gatewayv1beta1.ReferenceGrant)
if !ok {
return false
}
for _, from := range grant.Spec.From {
if from.Kind == "HTTPRoute" && from.Group == "gateway.networking.k8s.io" {
return true
}
}
return false
}

// listHTTPRoutesForGatewayClass is a controller-runtime event.Handler which
// produces a list of HTTPRoutes which were bound to a Gateway which is or was
// bound to this GatewayClass. This implementation effectively does a map-reduce
Expand Down

0 comments on commit ac5a4d7

Please sign in to comment.