From 82aaf714590ff7268035452f6f44a9c8400f20d3 Mon Sep 17 00:00:00 2001 From: Danil Grigorev Date: Wed, 17 Apr 2024 23:29:16 +0200 Subject: [PATCH] Refactor --- .../controllers/kubeadmconfig_controller.go | 6 +- controllers/external/tracker.go | 4 +- controllers/remote/cluster_cache_tracker.go | 2 +- .../internal/controllers/controller.go | 2 +- .../clusterresourceset_controller.go | 2 +- .../clusterresourcesetbinding_controller.go | 2 +- .../controllers/machinepool_controller.go | 4 +- exp/util/util.go | 2 +- go.mod | 2 +- go.sum | 4 +- .../controllers/cluster/cluster_controller.go | 2 +- .../clusterclass/clusterclass_controller.go | 2 +- .../controllers/machine/machine_controller.go | 12 ++-- .../machinedeployment_controller.go | 4 +- .../machinehealthcheck_controller.go | 6 +- .../machineset/machineset_controller.go | 4 +- .../topology/cluster/cluster_controller.go | 11 +-- .../machinedeployment_controller.go | 2 +- .../machineset/machineset_controller.go | 2 +- test/go.mod | 2 +- test/go.sum | 4 +- .../dockermachinepool_controller.go | 6 +- .../controllers/dockercluster_controller.go | 2 +- .../controllers/dockermachine_controller.go | 6 +- .../controllers/inmemorycluster_controller.go | 2 +- .../controllers/inmemorymachine_controller.go | 6 +- util/predicates/cluster_predicates.go | 69 ++++++++++--------- util/predicates/generic_predicates.go | 16 ++--- util/util.go | 10 +-- 29 files changed, 101 insertions(+), 97 deletions(-) diff --git a/bootstrap/kubeadm/internal/controllers/kubeadmconfig_controller.go b/bootstrap/kubeadm/internal/controllers/kubeadmconfig_controller.go index f6bc296a91c5..2ba578c21205 100644 --- a/bootstrap/kubeadm/internal/controllers/kubeadmconfig_controller.go +++ b/bootstrap/kubeadm/internal/controllers/kubeadmconfig_controller.go @@ -115,21 +115,21 @@ func (r *KubeadmConfigReconciler) SetupWithManager(ctx context.Context, mgr ctrl WithOptions(options). Add(builder.Watches(mgr, &clusterv1.Machine{}, - handler.EnqueueRequestsFromObjectMap(r.MachineToBootstrapMapFunc), + handler.EnqueueRequestsFromTypedMapFunc(r.MachineToBootstrapMapFunc), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Machine{}), )) if feature.Gates.Enabled(feature.MachinePool) { b = b.Add(builder.Watches(mgr, &expv1.MachinePool{}, - handler.EnqueueRequestsFromObjectMap(r.MachinePoolToBootstrapMapFunc), + handler.EnqueueRequestsFromTypedMapFunc(r.MachinePoolToBootstrapMapFunc), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &expv1.MachinePool{}), )) } b = b.Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(r.ClusterToKubeadmConfigs), + handler.EnqueueRequestsFromTypedMapFunc(r.ClusterToKubeadmConfigs), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), predicates.ClusterUnpausedAndInfrastructureReady(ctrl.LoggerFrom(ctx)), )) diff --git a/controllers/external/tracker.go b/controllers/external/tracker.go index 850b877fae61..6d46e1e7c6cf 100644 --- a/controllers/external/tracker.go +++ b/controllers/external/tracker.go @@ -54,12 +54,14 @@ func (o *ObjectTracker) Watch(log logr.Logger, obj client.Object, handler handle return nil } + var c client.Object u := &unstructured.Unstructured{} u.SetGroupVersionKind(gvk) + c = u log.Info(fmt.Sprintf("Adding watch on external object %q", gvk.String())) err := o.Controller.Watch( - source.Kind(o.Cache, u).Prepare(handler, append(p, predicates.ResourceNotPaused(log, obj))...), + source.Kind(o.Cache, c, handler, append(p, predicates.ResourceNotPaused(log, obj))...), ) if err != nil { o.m.Delete(key) diff --git a/controllers/remote/cluster_cache_tracker.go b/controllers/remote/cluster_cache_tracker.go index 5060729ce1a4..4759ed3d9791 100644 --- a/controllers/remote/cluster_cache_tracker.go +++ b/controllers/remote/cluster_cache_tracker.go @@ -585,7 +585,7 @@ func (t *ClusterCacheTracker) Watch(ctx context.Context, input WatchInput) error } // Need to create the watch - if err := input.Watcher.Watch(source.Kind(accessor.cache, input.Kind), input.EventHandler, input.Predicates...); err != nil { + if err := input.Watcher.Watch(source.Kind(accessor.cache, input.Kind, nil), input.EventHandler, input.Predicates...); err != nil { return errors.Wrapf(err, "failed to add %s watch on cluster %s: failed to create watch", input.Kind, klog.KRef(input.Cluster.Namespace, input.Cluster.Name)) } diff --git a/controlplane/kubeadm/internal/controllers/controller.go b/controlplane/kubeadm/internal/controllers/controller.go index 5b66c49ccb3f..d5bd844efae0 100644 --- a/controlplane/kubeadm/internal/controllers/controller.go +++ b/controlplane/kubeadm/internal/controllers/controller.go @@ -103,7 +103,7 @@ func (r *KubeadmControlPlaneReconciler) SetupWithManager(ctx context.Context, mg WithOptions(options). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(r.ClusterToKubeadmControlPlane), + handler.EnqueueRequestsFromTypedMapFunc(r.ClusterToKubeadmControlPlane), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), predicates.ClusterUnpausedAndInfrastructureReady(ctrl.LoggerFrom(ctx)), )).Build(r) diff --git a/exp/addons/internal/controllers/clusterresourceset_controller.go b/exp/addons/internal/controllers/clusterresourceset_controller.go index 7e944fbd655b..e4bc331ba6b8 100644 --- a/exp/addons/internal/controllers/clusterresourceset_controller.go +++ b/exp/addons/internal/controllers/clusterresourceset_controller.go @@ -71,7 +71,7 @@ func (r *ClusterResourceSetReconciler) SetupWithManager(ctx context.Context, mgr )). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(r.clusterToClusterResourceSet), + handler.EnqueueRequestsFromTypedMapFunc(r.clusterToClusterResourceSet), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), )). WatchesMetadata( diff --git a/exp/addons/internal/controllers/clusterresourcesetbinding_controller.go b/exp/addons/internal/controllers/clusterresourcesetbinding_controller.go index 3bbfde969657..a85937ab6b99 100644 --- a/exp/addons/internal/controllers/clusterresourcesetbinding_controller.go +++ b/exp/addons/internal/controllers/clusterresourcesetbinding_controller.go @@ -53,7 +53,7 @@ func (r *ClusterResourceSetBindingReconciler) SetupWithManager(ctx context.Conte For(&addonsv1.ClusterResourceSetBinding{}). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(r.clusterToClusterResourceSetBinding), + handler.EnqueueRequestsFromTypedMapFunc(r.clusterToClusterResourceSetBinding), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), )). WithOptions(options). diff --git a/exp/internal/controllers/machinepool_controller.go b/exp/internal/controllers/machinepool_controller.go index 9db7630a89d3..f5ed045d4633 100644 --- a/exp/internal/controllers/machinepool_controller.go +++ b/exp/internal/controllers/machinepool_controller.go @@ -93,7 +93,7 @@ func (r *MachinePoolReconciler) SetupWithManager(ctx context.Context, mgr ctrl.M WithOptions(options). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(clusterToMachinePools), + handler.EnqueueRequestsFromTypedMapFunc(clusterToMachinePools), // TODO: should this wait for Cluster.Status.InfrastructureReady similar to Infra Machine resources? predicates.ClusterUnpaused(ctrl.LoggerFrom(ctx)), predicates.ResourceHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), @@ -333,7 +333,7 @@ func (r *MachinePoolReconciler) watchClusterNodes(ctx context.Context, cluster * Cluster: util.ObjectKey(cluster), Watcher: &controller.ControllerAdapter{Controller: r.controller}, Kind: &corev1.Node{}, - EventHandler: handler.EnqueueRequestsFromObjectMapFunc(r.nodeToMachinePool), + EventHandler: handler.EnqueueRequestsFromMapFunc(r.nodeToMachinePool), }) } diff --git a/exp/util/util.go b/exp/util/util.go index 0f82a919163c..a7d451c87a90 100644 --- a/exp/util/util.go +++ b/exp/util/util.go @@ -89,7 +89,7 @@ func GetMachinePoolByLabels(ctx context.Context, c client.Client, namespace stri // MachinePoolToInfrastructureMapFunc returns a handler.MapFunc that watches for // MachinePool events and returns reconciliation requests for an infrastructure provider object. -func MachinePoolToInfrastructureMapFunc(gvk schema.GroupVersionKind, log logr.Logger) handler.ObjectMapFunc[*expv1.MachinePool] { +func MachinePoolToInfrastructureMapFunc(gvk schema.GroupVersionKind, log logr.Logger) handler.TypedMapFunc[*expv1.MachinePool] { log = log.WithValues("machine-pool-to-infra-map-func", gvk.String()) return func(_ context.Context, m *expv1.MachinePool) []reconcile.Request { log := log.WithValues("MachinePool", klog.KObj(m)) diff --git a/go.mod b/go.mod index d433675bd120..4b35efd5366a 100644 --- a/go.mod +++ b/go.mod @@ -2,7 +2,7 @@ module sigs.k8s.io/cluster-api go 1.22.0 -replace sigs.k8s.io/controller-runtime => github.com/Danil-Grigorev/controller-runtime v0.6.1-0.20240417125124-8984b3049571 +replace sigs.k8s.io/controller-runtime => github.com/Danil-Grigorev/controller-runtime v0.6.1-0.20240417201603-e18909c2932e require ( github.com/MakeNowJust/heredoc v1.0.0 diff --git a/go.sum b/go.sum index ff206e0a630b..00851c4468ee 100644 --- a/go.sum +++ b/go.sum @@ -20,8 +20,8 @@ github.com/Azure/go-ansiterm v0.0.0-20210617225240-d185dfc1b5a1 h1:UQHMgLO+TxOEl github.com/Azure/go-ansiterm v0.0.0-20210617225240-d185dfc1b5a1/go.mod h1:xomTg63KZ2rFqZQzSB4Vz2SUXa1BpHTVz9L5PTmPC4E= github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo= -github.com/Danil-Grigorev/controller-runtime v0.6.1-0.20240417125124-8984b3049571 h1:a1Oaf+Zk1mbhUP0wVULBOLZ+b4MXLW6g/2kadPQg5yw= -github.com/Danil-Grigorev/controller-runtime v0.6.1-0.20240417125124-8984b3049571/go.mod h1:TLM3OvUJgcqHVBLVRlNylmfbOlOukMLFHtc6jo3EtIQ= +github.com/Danil-Grigorev/controller-runtime v0.6.1-0.20240417201603-e18909c2932e h1:hEGMiTp7lLNM666lIVpXzlyjkTpAMV+iYcnofBNKAYk= +github.com/Danil-Grigorev/controller-runtime v0.6.1-0.20240417201603-e18909c2932e/go.mod h1:TLM3OvUJgcqHVBLVRlNylmfbOlOukMLFHtc6jo3EtIQ= github.com/MakeNowJust/heredoc v1.0.0 h1:cXCdzVdstXyiTqTvfqk9SDHpKNjxuom+DOlyEeQ4pzQ= github.com/MakeNowJust/heredoc v1.0.0/go.mod h1:mG5amYoWBHf8vpLOuehzbGGw0EHxpZZ6lCpQ4fNJ8LE= github.com/Masterminds/goutils v1.1.1 h1:5nUrii3FMTL5diU80unEVvNevw1nH4+ZV4DSLVJLSYI= diff --git a/internal/controllers/cluster/cluster_controller.go b/internal/controllers/cluster/cluster_controller.go index f756e0a8b66e..795cee1720a1 100644 --- a/internal/controllers/cluster/cluster_controller.go +++ b/internal/controllers/cluster/cluster_controller.go @@ -81,7 +81,7 @@ func (r *Reconciler) SetupWithManager(ctx context.Context, mgr ctrl.Manager, opt Add(builder.For(mgr, &clusterv1.Cluster{}, predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}))). Add(builder.Watches(mgr, &clusterv1.Machine{}, - handler.EnqueueRequestsFromObjectMap(r.controlPlaneMachineToCluster), + handler.EnqueueRequestsFromTypedMapFunc(r.controlPlaneMachineToCluster), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Machine{}), )). WithOptions(options). diff --git a/internal/controllers/clusterclass/clusterclass_controller.go b/internal/controllers/clusterclass/clusterclass_controller.go index a62f72ba04d4..3a47d64a38ee 100644 --- a/internal/controllers/clusterclass/clusterclass_controller.go +++ b/internal/controllers/clusterclass/clusterclass_controller.go @@ -77,7 +77,7 @@ func (r *Reconciler) SetupWithManager(ctx context.Context, mgr ctrl.Manager, opt Named("clusterclass"). WithOptions(options). Add(builder.Watches(mgr, &runtimev1.ExtensionConfig{}, - handler.EnqueueRequestsFromObjectMap(r.extensionConfigToClusterClass), + handler.EnqueueRequestsFromTypedMapFunc(r.extensionConfigToClusterClass), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &runtimev1.ExtensionConfig{}))). Complete(r) diff --git a/internal/controllers/machine/machine_controller.go b/internal/controllers/machine/machine_controller.go index 032695071354..f3b0ba08194a 100644 --- a/internal/controllers/machine/machine_controller.go +++ b/internal/controllers/machine/machine_controller.go @@ -119,10 +119,10 @@ func (r *Reconciler) SetupWithManager(ctx context.Context, mgr ctrl.Manager, opt WithOptions(options). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(clusterToMachines), + handler.EnqueueRequestsFromTypedMapFunc(clusterToMachines), // TODO: should this wait for Cluster.Status.InfrastructureReady similar to Infra Machine resources? - predicate.Any( - predicate.Any( + predicate.Or( + predicate.Or( predicates.ClusterUnpaused(ctrl.LoggerFrom(ctx)), predicates.ClusterControlPlaneInitialized(ctrl.LoggerFrom(ctx)), ), @@ -132,12 +132,12 @@ func (r *Reconciler) SetupWithManager(ctx context.Context, mgr ctrl.Manager, opt )). Add(builder.Watches(mgr, &clusterv1.MachineSet{}, - handler.EnqueueRequestsFromObjectMap(msToMachines), + handler.EnqueueRequestsFromTypedMapFunc(msToMachines), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.MachineSet{}), )). Add(builder.Watches(mgr, &clusterv1.MachineDeployment{}, - handler.EnqueueRequestsFromObjectMap(mdToMachines), + handler.EnqueueRequestsFromTypedMapFunc(mdToMachines), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.MachineDeployment{}), )). Build(r) @@ -861,7 +861,7 @@ func (r *Reconciler) watchClusterNodes(ctx context.Context, cluster *clusterv1.C Cluster: util.ObjectKey(cluster), Watcher: &controller.ControllerAdapter{Controller: r.controller}, Kind: &corev1.Node{}, - EventHandler: handler.EnqueueRequestsFromObjectMapFunc(r.nodeToMachine), + EventHandler: handler.EnqueueRequestsFromTypedMapFuncFunc(r.nodeToMachine), }) } diff --git a/internal/controllers/machinedeployment/machinedeployment_controller.go b/internal/controllers/machinedeployment/machinedeployment_controller.go index 1c95f5c9ef11..95fbd90e5fb2 100644 --- a/internal/controllers/machinedeployment/machinedeployment_controller.go +++ b/internal/controllers/machinedeployment/machinedeployment_controller.go @@ -88,13 +88,13 @@ func (r *Reconciler) SetupWithManager(ctx context.Context, mgr ctrl.Manager, opt // Watches enqueues MachineDeployment for corresponding MachineSet resources, if no managed controller reference (owner) exists. Add(builder.Watches(mgr, &clusterv1.MachineSet{}, - handler.EnqueueRequestsFromObjectMap(r.MachineSetToDeployments), + handler.EnqueueRequestsFromTypedMapFunc(r.MachineSetToDeployments), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.MachineSet{})), ). WithOptions(options). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(clusterToMachineDeployments), + handler.EnqueueRequestsFromTypedMapFunc(clusterToMachineDeployments), // TODO: should this wait for Cluster.Status.InfrastructureReady similar to Infra Machine resources? predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), )).Complete(r) diff --git a/internal/controllers/machinehealthcheck/machinehealthcheck_controller.go b/internal/controllers/machinehealthcheck/machinehealthcheck_controller.go index 95767a506fd2..9c0b356341fa 100644 --- a/internal/controllers/machinehealthcheck/machinehealthcheck_controller.go +++ b/internal/controllers/machinehealthcheck/machinehealthcheck_controller.go @@ -91,13 +91,13 @@ func (r *Reconciler) SetupWithManager(ctx context.Context, mgr ctrl.Manager, opt predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.MachineHealthCheck{}))). Add(builder.Watches(mgr, &clusterv1.Machine{}, - handler.EnqueueRequestsFromObjectMap(r.machineToMachineHealthCheck), + handler.EnqueueRequestsFromTypedMapFunc(r.machineToMachineHealthCheck), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Machine{}), )). WithOptions(options). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(r.clusterToMachineHealthCheck), + handler.EnqueueRequestsFromTypedMapFunc(r.clusterToMachineHealthCheck), // TODO: should this wait for Cluster.Status.InfrastructureReady similar to Infra Machine resources? predicates.ClusterUnpaused(ctrl.LoggerFrom(ctx)), predicates.ResourceHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), @@ -517,7 +517,7 @@ func (r *Reconciler) watchClusterNodes(ctx context.Context, cluster *clusterv1.C Cluster: util.ObjectKey(cluster), Watcher: &controller.ControllerAdapter{Controller: r.controller}, Kind: &corev1.Node{}, - EventHandler: handler.EnqueueRequestsFromObjectMapFunc(r.nodeToMachineHealthCheck), + EventHandler: handler.EnqueueRequestsFromTypedMapFunc(r.nodeToMachineHealthCheck), }) } diff --git a/internal/controllers/machineset/machineset_controller.go b/internal/controllers/machineset/machineset_controller.go index ca2dd9c8bff4..f092d3339619 100644 --- a/internal/controllers/machineset/machineset_controller.go +++ b/internal/controllers/machineset/machineset_controller.go @@ -103,13 +103,13 @@ func (r *Reconciler) SetupWithManager(ctx context.Context, mgr ctrl.Manager, opt // Watches enqueues MachineSet for corresponding Machine resources, if no managed controller reference (owner) exists. Add(builder.Watches(mgr, &clusterv1.Machine{}, - handler.EnqueueRequestsFromObjectMap(r.MachineToMachineSets), + handler.EnqueueRequestsFromTypedMapFunc(r.MachineToMachineSets), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Machine{}), )). WithOptions(options). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(clusterToMachineSets), + handler.EnqueueRequestsFromTypedMapFunc(clusterToMachineSets), // TODO: should this wait for Cluster.Status.InfrastructureReady similar to Infra Machine resources? predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), )).Complete(r) diff --git a/internal/controllers/topology/cluster/cluster_controller.go b/internal/controllers/topology/cluster/cluster_controller.go index a006239266e4..99c34117d111 100644 --- a/internal/controllers/topology/cluster/cluster_controller.go +++ b/internal/controllers/topology/cluster/cluster_controller.go @@ -22,6 +22,7 @@ import ( "github.com/pkg/errors" apierrors "k8s.io/apimachinery/pkg/api/errors" + "k8s.io/apimachinery/pkg/apis/meta/v1/unstructured" "k8s.io/apimachinery/pkg/types" kerrors "k8s.io/apimachinery/pkg/util/errors" "k8s.io/client-go/tools/record" @@ -99,19 +100,19 @@ func (r *Reconciler) SetupWithManager(ctx context.Context, mgr ctrl.Manager, opt Named("topology/cluster"). Add(builder.Watches(mgr, &clusterv1.ClusterClass{}, - handler.EnqueueRequestsFromObjectMap(r.clusterClassToCluster), + handler.EnqueueRequestsFromTypedMapFunc(r.clusterClassToCluster), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.ClusterClass{}), )). Add(builder.Watches(mgr, &clusterv1.MachineDeployment{}, - handler.EnqueueRequestsFromObjectMap(r.machineDeploymentToCluster), + handler.EnqueueRequestsFromTypedMapFunc(r.machineDeploymentToCluster), // Only trigger Cluster reconciliation if the MachineDeployment is topology owned. predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.MachineDeployment{}), predicates.ResourceIsTopologyOwned(ctrl.LoggerFrom(ctx), &clusterv1.MachineDeployment{}), )). Add(builder.Watches(mgr, &expv1.MachinePool{}, - handler.EnqueueRequestsFromObjectMap(r.machinePoolToCluster), + handler.EnqueueRequestsFromTypedMapFunc(r.machinePoolToCluster), // Only trigger Cluster reconciliation if the MachinePool is topology owned. predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &expv1.MachinePool{}), predicates.ResourceIsTopologyOwned(ctrl.LoggerFrom(ctx), &expv1.MachinePool{}), @@ -305,9 +306,9 @@ func (r *Reconciler) setupDynamicWatches(ctx context.Context, s *scope.Scope) er } if s.Current.ControlPlane.Object != nil { if err := r.externalTracker.Watch(ctrl.LoggerFrom(ctx), s.Current.ControlPlane.Object, - handler.EnqueueRequestForOwner(r.Client.Scheme(), r.Client.RESTMapper(), &clusterv1.Cluster{}), + handler.TypedEnqueueRequestForOwner[*unstructured.Unstructured](r.Client.Scheme(), r.Client.RESTMapper(), &clusterv1.Cluster{}), // Only trigger Cluster reconciliation if the ControlPlane is topology owned. - predicates.ResourceIsTopologyOwned(ctrl.LoggerFrom(ctx), &clusterv1.Cluster{})); err != nil { + predicates.ResourceIsTopologyOwned(ctrl.LoggerFrom(ctx), &unstructured.Unstructured{})); err != nil { return errors.Wrap(err, "error watching ControlPlane CR") } } diff --git a/internal/controllers/topology/machinedeployment/machinedeployment_controller.go b/internal/controllers/topology/machinedeployment/machinedeployment_controller.go index 2f8a9372742e..3762f48b1b9c 100644 --- a/internal/controllers/topology/machinedeployment/machinedeployment_controller.go +++ b/internal/controllers/topology/machinedeployment/machinedeployment_controller.go @@ -71,7 +71,7 @@ func (r *Reconciler) SetupWithManager(ctx context.Context, mgr ctrl.Manager, opt WithOptions(options). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(clusterToMachineDeployments), + handler.EnqueueRequestsFromTypedMapFunc(clusterToMachineDeployments), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), predicates.ClusterHasTopology(ctrl.LoggerFrom(ctx)), )). diff --git a/internal/controllers/topology/machineset/machineset_controller.go b/internal/controllers/topology/machineset/machineset_controller.go index ff5a6630760b..d9ce06aaf3f3 100644 --- a/internal/controllers/topology/machineset/machineset_controller.go +++ b/internal/controllers/topology/machineset/machineset_controller.go @@ -73,7 +73,7 @@ func (r *Reconciler) SetupWithManager(ctx context.Context, mgr ctrl.Manager, opt WithOptions(options). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(clusterToMachineSets), + handler.EnqueueRequestsFromTypedMapFunc(clusterToMachineSets), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), predicates.ClusterUnpaused(ctrl.LoggerFrom(ctx)), predicates.ClusterHasTopology(ctrl.LoggerFrom(ctx)), diff --git a/test/go.mod b/test/go.mod index fd6665cd0aa1..16ce880dc7f7 100644 --- a/test/go.mod +++ b/test/go.mod @@ -4,7 +4,7 @@ go 1.22.0 replace sigs.k8s.io/cluster-api => ../ -replace sigs.k8s.io/controller-runtime => github.com/Danil-Grigorev/controller-runtime v0.6.1-0.20240417125124-8984b3049571 +replace sigs.k8s.io/controller-runtime => github.com/Danil-Grigorev/controller-runtime v0.6.1-0.20240417201603-e18909c2932e require ( github.com/blang/semver/v4 v4.0.0 diff --git a/test/go.sum b/test/go.sum index 547ad02476cd..25d853432d75 100644 --- a/test/go.sum +++ b/test/go.sum @@ -9,8 +9,8 @@ github.com/Azure/go-ansiterm v0.0.0-20210617225240-d185dfc1b5a1/go.mod h1:xomTg6 github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= github.com/BurntSushi/toml v1.0.0 h1:dtDWrepsVPfW9H/4y7dDgFc2MBUSeJhlaDtK13CxFlU= github.com/BurntSushi/toml v1.0.0/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ= -github.com/Danil-Grigorev/controller-runtime v0.6.1-0.20240417125124-8984b3049571 h1:a1Oaf+Zk1mbhUP0wVULBOLZ+b4MXLW6g/2kadPQg5yw= -github.com/Danil-Grigorev/controller-runtime v0.6.1-0.20240417125124-8984b3049571/go.mod h1:TLM3OvUJgcqHVBLVRlNylmfbOlOukMLFHtc6jo3EtIQ= +github.com/Danil-Grigorev/controller-runtime v0.6.1-0.20240417201603-e18909c2932e h1:hEGMiTp7lLNM666lIVpXzlyjkTpAMV+iYcnofBNKAYk= +github.com/Danil-Grigorev/controller-runtime v0.6.1-0.20240417201603-e18909c2932e/go.mod h1:TLM3OvUJgcqHVBLVRlNylmfbOlOukMLFHtc6jo3EtIQ= github.com/MakeNowJust/heredoc v1.0.0 h1:cXCdzVdstXyiTqTvfqk9SDHpKNjxuom+DOlyEeQ4pzQ= github.com/MakeNowJust/heredoc v1.0.0/go.mod h1:mG5amYoWBHf8vpLOuehzbGGw0EHxpZZ6lCpQ4fNJ8LE= github.com/Masterminds/goutils v1.1.1 h1:5nUrii3FMTL5diU80unEVvNevw1nH4+ZV4DSLVJLSYI= diff --git a/test/infrastructure/docker/exp/internal/controllers/dockermachinepool_controller.go b/test/infrastructure/docker/exp/internal/controllers/dockermachinepool_controller.go index 2f351563f043..529acd799ec7 100644 --- a/test/infrastructure/docker/exp/internal/controllers/dockermachinepool_controller.go +++ b/test/infrastructure/docker/exp/internal/controllers/dockermachinepool_controller.go @@ -179,18 +179,18 @@ func (r *DockerMachinePoolReconciler) SetupWithManager(ctx context.Context, mgr WithOptions(options). Add(builder.Watches(mgr, &expv1.MachinePool{}, - handler.EnqueueRequestsFromObjectMap(utilexp.MachinePoolToInfrastructureMapFunc( + handler.EnqueueRequestsFromTypedMapFunc(utilexp.MachinePoolToInfrastructureMapFunc( infraexpv1.GroupVersion.WithKind("DockerMachinePool"), ctrl.LoggerFrom(ctx))), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &expv1.MachinePool{}), )). Add(builder.Watches(mgr, &infrav1.DockerMachine{}, - handler.EnqueueRequestsFromObjectMap(dockerMachineToDockerMachinePool), + handler.EnqueueRequestsFromTypedMapFunc(dockerMachineToDockerMachinePool), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &infrav1.DockerMachine{}), )). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(clusterToDockerMachinePools), + handler.EnqueueRequestsFromTypedMapFunc(clusterToDockerMachinePools), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), predicates.ClusterUnpausedAndInfrastructureReady(ctrl.LoggerFrom(ctx)), )).Build(r) diff --git a/test/infrastructure/docker/internal/controllers/dockercluster_controller.go b/test/infrastructure/docker/internal/controllers/dockercluster_controller.go index 21b5251c2861..85b26d084aaf 100644 --- a/test/infrastructure/docker/internal/controllers/dockercluster_controller.go +++ b/test/infrastructure/docker/internal/controllers/dockercluster_controller.go @@ -206,7 +206,7 @@ func (r *DockerClusterReconciler) SetupWithManager(ctx context.Context, mgr ctrl WithOptions(options). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(util.ClusterToInfrastructureMapFunc(ctx, infrav1.GroupVersion.WithKind("DockerCluster"), mgr.GetClient(), &infrav1.DockerCluster{})), + handler.EnqueueRequestsFromTypedMapFunc(util.ClusterToInfrastructureMapFunc(ctx, infrav1.GroupVersion.WithKind("DockerCluster"), mgr.GetClient(), &infrav1.DockerCluster{})), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), predicates.ClusterUnpaused(ctrl.LoggerFrom(ctx)), )).Complete(r) diff --git a/test/infrastructure/docker/internal/controllers/dockermachine_controller.go b/test/infrastructure/docker/internal/controllers/dockermachine_controller.go index 18fe38ca3754..fd32d1cc0cf8 100644 --- a/test/infrastructure/docker/internal/controllers/dockermachine_controller.go +++ b/test/infrastructure/docker/internal/controllers/dockermachine_controller.go @@ -491,17 +491,17 @@ func (r *DockerMachineReconciler) SetupWithManager(ctx context.Context, mgr ctrl WithOptions(options). Add(builder.Watches(mgr, &clusterv1.Machine{}, - handler.EnqueueRequestsFromObjectMap(util.MachineToInfrastructureMapFunc(infrav1.GroupVersion.WithKind("DockerMachine"))), + handler.EnqueueRequestsFromTypedMapFunc(util.MachineToInfrastructureMapFunc(infrav1.GroupVersion.WithKind("DockerMachine"))), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Machine{}), )). Add(builder.Watches(mgr, &infrav1.DockerCluster{}, - handler.EnqueueRequestsFromObjectMap(r.DockerClusterToDockerMachines), + handler.EnqueueRequestsFromTypedMapFunc(r.DockerClusterToDockerMachines), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &infrav1.DockerCluster{}), )). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(clusterToDockerMachines), + handler.EnqueueRequestsFromTypedMapFunc(clusterToDockerMachines), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), predicates.ClusterUnpausedAndInfrastructureReady(ctrl.LoggerFrom(ctx)), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), diff --git a/test/infrastructure/inmemory/internal/controllers/inmemorycluster_controller.go b/test/infrastructure/inmemory/internal/controllers/inmemorycluster_controller.go index 307c3fb5e52e..0ade0be138a9 100644 --- a/test/infrastructure/inmemory/internal/controllers/inmemorycluster_controller.go +++ b/test/infrastructure/inmemory/internal/controllers/inmemorycluster_controller.go @@ -215,7 +215,7 @@ func (r *InMemoryClusterReconciler) SetupWithManager(ctx context.Context, mgr ct WithOptions(options). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(util.ClusterToInfrastructureMapFunc(ctx, infrav1.GroupVersion.WithKind("InMemoryCluster"), mgr.GetClient(), &infrav1.InMemoryCluster{})), + handler.EnqueueRequestsFromTypedMapFunc(util.ClusterToInfrastructureMapFunc(ctx, infrav1.GroupVersion.WithKind("InMemoryCluster"), mgr.GetClient(), &infrav1.InMemoryCluster{})), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), predicates.ClusterUnpaused(ctrl.LoggerFrom(ctx)), )).Complete(r) diff --git a/test/infrastructure/inmemory/internal/controllers/inmemorymachine_controller.go b/test/infrastructure/inmemory/internal/controllers/inmemorymachine_controller.go index 491734c9bb20..612011d37603 100644 --- a/test/infrastructure/inmemory/internal/controllers/inmemorymachine_controller.go +++ b/test/infrastructure/inmemory/internal/controllers/inmemorymachine_controller.go @@ -1151,17 +1151,17 @@ func (r *InMemoryMachineReconciler) SetupWithManager(ctx context.Context, mgr ct WithOptions(options). Add(builder.Watches(mgr, &clusterv1.Machine{}, - handler.EnqueueRequestsFromObjectMap(util.MachineToInfrastructureMapFunc(infrav1.GroupVersion.WithKind("InMemoryMachine"))), + handler.EnqueueRequestsFromTypedMapFunc(util.MachineToInfrastructureMapFunc(infrav1.GroupVersion.WithKind("InMemoryMachine"))), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Machine{}), )). Add(builder.Watches(mgr, &infrav1.InMemoryCluster{}, - handler.EnqueueRequestsFromObjectMap(r.InMemoryClusterToInMemoryMachines), + handler.EnqueueRequestsFromTypedMapFunc(r.InMemoryClusterToInMemoryMachines), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &infrav1.InMemoryCluster{}), )). Add(builder.Watches(mgr, &clusterv1.Cluster{}, - handler.EnqueueRequestsFromObjectMap(clusterToInMemoryMachines), + handler.EnqueueRequestsFromTypedMapFunc(clusterToInMemoryMachines), predicates.ResourceNotPausedAndHasFilterLabel(ctrl.LoggerFrom(ctx), r.WatchFilterValue, &clusterv1.Cluster{}), predicates.ClusterUnpausedAndInfrastructureReady(ctrl.LoggerFrom(ctx)), )).Complete(r) diff --git a/util/predicates/cluster_predicates.go b/util/predicates/cluster_predicates.go index 06fd4fa7329a..06bfdc3481df 100644 --- a/util/predicates/cluster_predicates.go +++ b/util/predicates/cluster_predicates.go @@ -20,6 +20,7 @@ package predicates import ( "github.com/go-logr/logr" "k8s.io/klog/v2" + "sigs.k8s.io/controller-runtime/pkg/event" "sigs.k8s.io/controller-runtime/pkg/predicate" clusterv1 "sigs.k8s.io/cluster-api/api/v1beta1" @@ -28,14 +29,14 @@ import ( // ClusterCreateInfraReady returns a predicate that returns true for a create event when a cluster has Status.InfrastructureReady set as true // it also returns true if the resource provided is not a Cluster to allow for use with controller-runtime NewControllerManagedBy. -func ClusterCreateInfraReady(logger logr.Logger) predicate.ObjectFuncs[*clusterv1.Cluster] { - return predicate.ObjectFuncs[*clusterv1.Cluster]{ - CreateFunc: func(c *clusterv1.Cluster) bool { +func ClusterCreateInfraReady(logger logr.Logger) predicate.TypedFuncs[*clusterv1.Cluster] { + return predicate.TypedFuncs[*clusterv1.Cluster]{ + CreateFunc: func(c event.TypedCreateEvent[*clusterv1.Cluster]) bool { log := logger.WithValues("predicate", "ClusterCreateInfraReady", "eventType", "create") - log = log.WithValues("Cluster", klog.KObj(c)) + log = log.WithValues("Cluster", klog.KObj(c.Object)) // Only need to trigger a reconcile if the Cluster.Status.InfrastructureReady is true - if c.Status.InfrastructureReady { + if c.Object.Status.InfrastructureReady { log.V(6).Info("Cluster infrastructure is ready, allowing further processing") return true } @@ -48,14 +49,14 @@ func ClusterCreateInfraReady(logger logr.Logger) predicate.ObjectFuncs[*clusterv // ClusterCreateNotPaused returns a predicate that returns true for a create event when a cluster has Spec.Paused set as false // it also returns true if the resource provided is not a Cluster to allow for use with controller-runtime NewControllerManagedBy. -func ClusterCreateNotPaused(logger logr.Logger) predicate.ObjectFuncs[*clusterv1.Cluster] { - return predicate.ObjectFuncs[*clusterv1.Cluster]{ - CreateFunc: func(c *clusterv1.Cluster) bool { +func ClusterCreateNotPaused(logger logr.Logger) predicate.TypedFuncs[*clusterv1.Cluster] { + return predicate.TypedFuncs[*clusterv1.Cluster]{ + CreateFunc: func(c event.TypedCreateEvent[*clusterv1.Cluster]) bool { log := logger.WithValues("predicate", "ClusterCreateNotPaused", "eventType", "create") - log = log.WithValues("Cluster", klog.KObj(c)) + log = log.WithValues("Cluster", klog.KObj(c.Object)) // Only need to trigger a reconcile if the Cluster.Spec.Paused is false - if !c.Spec.Paused { + if !c.Object.Spec.Paused { log.V(6).Info("Cluster is not paused, allowing further processing") return true } @@ -68,13 +69,13 @@ func ClusterCreateNotPaused(logger logr.Logger) predicate.ObjectFuncs[*clusterv1 // ClusterUpdateInfraReady returns a predicate that returns true for an update event when a cluster has Status.InfrastructureReady changed from false to true // it also returns true if the resource provided is not a Cluster to allow for use with controller-runtime NewControllerManagedBy. -func ClusterUpdateInfraReady(logger logr.Logger) predicate.ObjectFuncs[*clusterv1.Cluster] { - return predicate.ObjectFuncs[*clusterv1.Cluster]{ - UpdateFunc: func(oldCluster, newCluster *clusterv1.Cluster) bool { +func ClusterUpdateInfraReady(logger logr.Logger) predicate.TypedFuncs[*clusterv1.Cluster] { + return predicate.TypedFuncs[*clusterv1.Cluster]{ + UpdateFunc: func(u event.TypedUpdateEvent[*clusterv1.Cluster]) bool { log := logger.WithValues("predicate", "ClusterUpdateInfraReady", "eventType", "update") - log = log.WithValues("Cluster", klog.KObj(oldCluster)) + log = log.WithValues("Cluster", klog.KObj(u.ObjectOld)) - if !oldCluster.Status.InfrastructureReady && newCluster.Status.InfrastructureReady { + if !u.ObjectOld.Status.InfrastructureReady && u.ObjectNew.Status.InfrastructureReady { log.V(6).Info("Cluster infrastructure became ready, allowing further processing") return true } @@ -87,13 +88,13 @@ func ClusterUpdateInfraReady(logger logr.Logger) predicate.ObjectFuncs[*clusterv // ClusterUpdateUnpaused returns a predicate that returns true for an update event when a cluster has Spec.Paused changed from true to false // it also returns true if the resource provided is not a Cluster to allow for use with controller-runtime NewControllerManagedBy. -func ClusterUpdateUnpaused(logger logr.Logger) predicate.ObjectFuncs[*clusterv1.Cluster] { - return predicate.ObjectFuncs[*clusterv1.Cluster]{ - UpdateFunc: func(oldCluster, newCluster *clusterv1.Cluster) bool { +func ClusterUpdateUnpaused(logger logr.Logger) predicate.TypedFuncs[*clusterv1.Cluster] { + return predicate.TypedFuncs[*clusterv1.Cluster]{ + UpdateFunc: func(u event.TypedUpdateEvent[*clusterv1.Cluster]) bool { log := logger.WithValues("predicate", "ClusterUpdateUnpaused", "eventType", "update") - log = log.WithValues("Cluster", klog.KObj(oldCluster)) + log = log.WithValues("Cluster", klog.KObj(u.ObjectOld)) - if oldCluster.Spec.Paused && !newCluster.Spec.Paused { + if u.ObjectOld.Spec.Paused && !u.ObjectNew.Spec.Paused { log.V(4).Info("Cluster was unpaused, allowing further processing") return true } @@ -117,11 +118,11 @@ func ClusterUpdateUnpaused(logger logr.Logger) predicate.ObjectFuncs[*clusterv1. // handler.EnqueueRequestsFromMapFunc(clusterToMachines) // predicates.ClusterUnpaused(r.Log), // ) -func ClusterUnpaused(logger logr.Logger) predicate.ObjectPredicate[*clusterv1.Cluster] { +func ClusterUnpaused(logger logr.Logger) predicate.TypedPredicate[*clusterv1.Cluster] { log := logger.WithValues("predicate", "ClusterUnpaused") // Use any to ensure we process either create or update events we care about - return predicate.Any(ClusterCreateNotPaused(log), ClusterUpdateUnpaused(log)) + return predicate.Or(ClusterCreateNotPaused(log), ClusterUpdateUnpaused(log)) } // ClusterControlPlaneInitialized returns a Predicate that returns true on Update events @@ -133,14 +134,14 @@ func ClusterUnpaused(logger logr.Logger) predicate.ObjectPredicate[*clusterv1.Cl // handler.EnqueueRequestsFromMapFunc(clusterToMachines) // predicates.ClusterControlPlaneInitialized(r.Log), // ) -func ClusterControlPlaneInitialized(logger logr.Logger) predicate.ObjectPredicate[*clusterv1.Cluster] { - return predicate.ObjectFuncs[*clusterv1.Cluster]{ - UpdateFunc: func(oldCluster, newCluster *clusterv1.Cluster) bool { +func ClusterControlPlaneInitialized(logger logr.Logger) predicate.TypedPredicate[*clusterv1.Cluster] { + return predicate.TypedFuncs[*clusterv1.Cluster]{ + UpdateFunc: func(u event.TypedUpdateEvent[*clusterv1.Cluster]) bool { log := logger.WithValues("predicate", "ClusterControlPlaneInitialized", "eventType", "update") - log = log.WithValues("Cluster", klog.KObj(oldCluster)) + log = log.WithValues("Cluster", klog.KObj(u.ObjectOld)) - if !conditions.IsTrue(oldCluster, clusterv1.ControlPlaneInitializedCondition) && - conditions.IsTrue(newCluster, clusterv1.ControlPlaneInitializedCondition) { + if !conditions.IsTrue(u.ObjectOld, clusterv1.ControlPlaneInitializedCondition) && + conditions.IsTrue(u.ObjectNew, clusterv1.ControlPlaneInitializedCondition) { log.V(6).Info("Cluster ControlPlaneInitialized was set, allow further processing") return true } @@ -163,23 +164,23 @@ func ClusterControlPlaneInitialized(logger logr.Logger) predicate.ObjectPredicat // handler.EnqueueRequestsFromMapFunc(clusterToMachines) // predicates.ClusterUnpausedAndInfrastructureReady(r.Log), // ) -func ClusterUnpausedAndInfrastructureReady(logger logr.Logger) predicate.ObjectPredicate[*clusterv1.Cluster] { +func ClusterUnpausedAndInfrastructureReady(logger logr.Logger) predicate.TypedPredicate[*clusterv1.Cluster] { log := logger.WithValues("predicate", "ClusterUnpausedAndInfrastructureReady") // Only continue processing create events if both not paused and infrastructure is ready - createPredicates := predicate.All(ClusterCreateNotPaused(log), ClusterCreateInfraReady(log)) + createPredicates := predicate.And(ClusterCreateNotPaused(log), ClusterCreateInfraReady(log)) // Process update events if either Cluster is unpaused or infrastructure becomes ready - updatePredicates := predicate.Any(ClusterUpdateUnpaused(log), ClusterUpdateInfraReady(log)) + updatePredicates := predicate.And(ClusterUpdateUnpaused(log), ClusterUpdateInfraReady(log)) // Use any to ensure we process either create or update events we care about - return predicate.Any(createPredicates, updatePredicates) + return predicate.Or(createPredicates, updatePredicates) } // ClusterHasTopology returns a Predicate that returns true when cluster.Spec.Topology // is NOT nil and false otherwise. -func ClusterHasTopology(logger logr.Logger) predicate.ObjectPredicate[*clusterv1.Cluster] { - return predicate.NewObjectPredicateFuncs(processIfTopologyManaged(logger.WithValues("predicate", "ClusterHasTopology"))) +func ClusterHasTopology(logger logr.Logger) predicate.TypedPredicate[*clusterv1.Cluster] { + return predicate.NewTypedPredicateFuncs(processIfTopologyManaged(logger.WithValues("predicate", "ClusterHasTopology"))) } func processIfTopologyManaged(logger logr.Logger) func(*clusterv1.Cluster) bool { diff --git a/util/predicates/generic_predicates.go b/util/predicates/generic_predicates.go index 121db8112940..c25a641279ad 100644 --- a/util/predicates/generic_predicates.go +++ b/util/predicates/generic_predicates.go @@ -130,8 +130,8 @@ func Any(logger logr.Logger, predicates ...predicate.Funcs) predicate.Funcs { // ResourceHasFilterLabel returns a predicate that returns true only if the provided resource contains // a label with the WatchLabel key and the configured label value exactly. -func ResourceHasFilterLabel[T client.Object](logger logr.Logger, labelValue string, _ T) predicate.ObjectFuncs[T] { - return predicate.NewObjectPredicateFuncs(processIfLabelMatch[T](logger.WithValues("predicate", "ResourceHasFilterLabel"), labelValue)) +func ResourceHasFilterLabel[T client.Object](logger logr.Logger, labelValue string, _ T) predicate.TypedPredicate[T] { + return predicate.NewTypedPredicateFuncs(processIfLabelMatch[T](logger.WithValues("predicate", "ResourceHasFilterLabel"), labelValue)) } // ResourceNotPaused returns a Predicate that returns true only if the provided resource does not contain the @@ -148,14 +148,14 @@ func ResourceHasFilterLabel[T client.Object](logger logr.Logger, labelValue stri // Build(r) // return err // } -func ResourceNotPaused[T client.Object](logger logr.Logger, _ T) predicate.ObjectFuncs[T] { - return predicate.NewObjectPredicateFuncs(processIfNotPaused[T](logger.WithValues("predicate", "ResourceNotPaused"))) +func ResourceNotPaused[T client.Object](logger logr.Logger, _ T) predicate.TypedPredicate[T] { + return predicate.NewTypedPredicateFuncs(processIfNotPaused[T](logger.WithValues("predicate", "ResourceNotPaused"))) } // ResourceNotPausedAndHasFilterLabel returns a predicate that returns true only if the // ResourceNotPaused and ResourceHasFilterLabel predicates return true. -func ResourceNotPausedAndHasFilterLabel[T client.Object](logger logr.Logger, labelValue string, o T) predicate.ObjectPredicate[T] { - return predicate.All(ResourceNotPaused(logger, o), ResourceHasFilterLabel(logger, labelValue, o)) +func ResourceNotPausedAndHasFilterLabel[T client.Object](logger logr.Logger, labelValue string, o T) predicate.TypedPredicate[T] { + return predicate.And(ResourceNotPaused(logger, o), ResourceHasFilterLabel(logger, labelValue, o)) } func processIfNotPaused[T client.Object](logger logr.Logger) func(T) bool { @@ -223,8 +223,8 @@ func processIfNotExternallyManaged(logger logr.Logger, obj client.Object) bool { // ResourceIsTopologyOwned returns a predicate that returns true only if the resource has // the `topology.cluster.x-k8s.io/owned` label. -func ResourceIsTopologyOwned[T client.Object](logger logr.Logger, _ T) predicate.ObjectFuncs[T] { - return predicate.NewObjectPredicateFuncs(processIfTopologyOwned[T](logger.WithValues("predicate", "ResourceIsTopologyOwned"))) +func ResourceIsTopologyOwned[T client.Object](logger logr.Logger, _ T) predicate.TypedPredicate[T] { + return predicate.NewTypedPredicateFuncs(processIfTopologyOwned[T](logger.WithValues("predicate", "ResourceIsTopologyOwned"))) } func processIfTopologyOwned[T client.Object](logger logr.Logger) func(T) bool { diff --git a/util/util.go b/util/util.go index a274e1fd36d1..38af938086be 100644 --- a/util/util.go +++ b/util/util.go @@ -197,7 +197,7 @@ func ObjectKey(object metav1.Object) client.ObjectKey { // ClusterToInfrastructureMapFunc returns a handler.ToRequestsFunc that watches for // Cluster events and returns reconciliation requests for an infrastructure provider object. -func ClusterToInfrastructureMapFunc(ctx context.Context, gvk schema.GroupVersionKind, c client.Client, providerCluster client.Object) handler.ObjectMapFunc[*clusterv1.Cluster] { +func ClusterToInfrastructureMapFunc(ctx context.Context, gvk schema.GroupVersionKind, c client.Client, providerCluster client.Object) handler.TypedMapFunc[*clusterv1.Cluster] { log := ctrl.LoggerFrom(ctx) return func(ctx context.Context, cluster *clusterv1.Cluster) []reconcile.Request { // Return early if the InfrastructureRef is nil. @@ -260,7 +260,7 @@ func GetMachineByName(ctx context.Context, c client.Client, namespace, name stri // MachineToInfrastructureMapFunc returns a handler.ToRequestsFunc that watches for // Machine events and returns reconciliation requests for an infrastructure provider object. -func MachineToInfrastructureMapFunc(gvk schema.GroupVersionKind) handler.ObjectMapFunc[*clusterv1.Machine] { +func MachineToInfrastructureMapFunc(gvk schema.GroupVersionKind) handler.TypedMapFunc[*clusterv1.Machine] { return func(_ context.Context, m *clusterv1.Machine) []reconcile.Request { gk := gvk.GroupKind() // Return early if the GroupKind doesn't match what we expect. @@ -463,7 +463,7 @@ func (k KubeAwareAPIVersions) Less(i, j int) bool { // Note: This function uses the passed in typed ObjectList and thus with the default client configuration all list calls // will be cached. // NB: The objects are required to have `clusterv1.ClusterNameLabel` applied. -func ClusterToTypedObjectsMapper(c client.Client, ro client.ObjectList, scheme *runtime.Scheme) (handler.ObjectMapFunc[*clusterv1.Cluster], error) { +func ClusterToTypedObjectsMapper(c client.Client, ro client.ObjectList, scheme *runtime.Scheme) (handler.TypedMapFunc[*clusterv1.Cluster], error) { gvk, err := apiutil.GVKForObject(ro, scheme) if err != nil { return nil, err @@ -522,7 +522,7 @@ func ClusterToTypedObjectsMapper(c client.Client, ro client.ObjectList, scheme * // MachineDeploymentToObjectsMapper returns a mapper function that gets a machinedeployment // and lists all objects for the object passed in and returns a list of requests. // NB: The objects are required to have `clusterv1.MachineDeploymentNameLabel` applied. -func MachineDeploymentToObjectsMapper(c client.Client, ro client.ObjectList, scheme *runtime.Scheme) (handler.ObjectMapFunc[*clusterv1.MachineDeployment], error) { +func MachineDeploymentToObjectsMapper(c client.Client, ro client.ObjectList, scheme *runtime.Scheme) (handler.TypedMapFunc[*clusterv1.MachineDeployment], error) { gvk, err := apiutil.GVKForObject(ro, scheme) if err != nil { return nil, err @@ -581,7 +581,7 @@ func MachineDeploymentToObjectsMapper(c client.Client, ro client.ObjectList, sch // MachineSetToObjectsMapper returns a mapper function that gets a machineset // and lists all objects for the object passed in and returns a list of requests. // NB: The objects are required to have `clusterv1.MachineSetNameLabel` applied. -func MachineSetToObjectsMapper(c client.Client, ro client.ObjectList, scheme *runtime.Scheme) (handler.ObjectMapFunc[*clusterv1.MachineSet], error) { +func MachineSetToObjectsMapper(c client.Client, ro client.ObjectList, scheme *runtime.Scheme) (handler.TypedMapFunc[*clusterv1.MachineSet], error) { gvk, err := apiutil.GVKForObject(ro, scheme) if err != nil { return nil, err