From 1bee2e95a4f709c793a9aed587f0f195deb7ad63 Mon Sep 17 00:00:00 2001 From: Rewant Soni Date: Mon, 2 Dec 2024 14:57:07 +0530 Subject: [PATCH] controllers: deploy omap sidecar only when required Signed-off-by: Rewant Soni --- api/v1alpha1/storageclient_types.go | 2 + ...client-operator.clusterserviceversion.yaml | 2 +- .../ocs.openshift.io_storageclients.yaml | 2 + .../ocs.openshift.io_storageclients.yaml | 2 + .../operatorconfigmap_controller.go | 47 +++++++++++++++++-- .../api/v1alpha1/storageclient_types.go | 2 + 6 files changed, 51 insertions(+), 6 deletions(-) diff --git a/api/v1alpha1/storageclient_types.go b/api/v1alpha1/storageclient_types.go index 897b2a13..bd68c47d 100644 --- a/api/v1alpha1/storageclient_types.go +++ b/api/v1alpha1/storageclient_types.go @@ -52,6 +52,8 @@ type StorageClientStatus struct { InMaintenanceMode bool `json:"inMaintenanceMode,omitempty"` + GenerateOMapInfo bool `json:"generateOMapInfo,omitempty"` + // ConsumerID will hold the identity of this cluster inside the attached provider cluster ConsumerID string `json:"id,omitempty"` } diff --git a/bundle/manifests/ocs-client-operator.clusterserviceversion.yaml b/bundle/manifests/ocs-client-operator.clusterserviceversion.yaml index c58b1255..d9aa7110 100644 --- a/bundle/manifests/ocs-client-operator.clusterserviceversion.yaml +++ b/bundle/manifests/ocs-client-operator.clusterserviceversion.yaml @@ -7,7 +7,7 @@ metadata: categories: Storage console.openshift.io/plugins: '["odf-client-console"]' containerImage: quay.io/ocs-dev/ocs-client-operator:latest - createdAt: "2024-11-27T03:54:42Z" + createdAt: "2024-12-02T09:16:34Z" description: OpenShift Data Foundation client operator enables consumption of storage services from a remote centralized OpenShift Data Foundation provider cluster. diff --git a/bundle/manifests/ocs.openshift.io_storageclients.yaml b/bundle/manifests/ocs.openshift.io_storageclients.yaml index de346ec3..a22f7f93 100644 --- a/bundle/manifests/ocs.openshift.io_storageclients.yaml +++ b/bundle/manifests/ocs.openshift.io_storageclients.yaml @@ -61,6 +61,8 @@ spec: status: description: StorageClientStatus defines the observed state of StorageClient properties: + generateOMapInfo: + type: boolean id: description: ConsumerID will hold the identity of this cluster inside the attached provider cluster diff --git a/config/crd/bases/ocs.openshift.io_storageclients.yaml b/config/crd/bases/ocs.openshift.io_storageclients.yaml index ef813739..afa4a64c 100644 --- a/config/crd/bases/ocs.openshift.io_storageclients.yaml +++ b/config/crd/bases/ocs.openshift.io_storageclients.yaml @@ -61,6 +61,8 @@ spec: status: description: StorageClientStatus defines the observed state of StorageClient properties: + generateOMapInfo: + type: boolean id: description: ConsumerID will hold the identity of this cluster inside the attached provider cluster diff --git a/internal/controller/operatorconfigmap_controller.go b/internal/controller/operatorconfigmap_controller.go index 6b7ceea2..7dcc0f22 100644 --- a/internal/controller/operatorconfigmap_controller.go +++ b/internal/controller/operatorconfigmap_controller.go @@ -50,6 +50,7 @@ import ( "sigs.k8s.io/controller-runtime/pkg/builder" "sigs.k8s.io/controller-runtime/pkg/client" "sigs.k8s.io/controller-runtime/pkg/controller/controllerutil" + "sigs.k8s.io/controller-runtime/pkg/event" "sigs.k8s.io/controller-runtime/pkg/handler" "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" @@ -151,6 +152,17 @@ func (c *OperatorConfigMapReconciler) SetupWithManager(mgr ctrl.Manager) error { ), ) + generateOMapInfoChangedPredicate := predicate.Funcs{ + UpdateFunc: func(e event.UpdateEvent) bool { + if e.ObjectOld == nil || e.ObjectNew == nil { + return false + } + oldObj := e.ObjectOld.(*v1alpha1.StorageClient) + newObj := e.ObjectNew.(*v1alpha1.StorageClient) + return oldObj.Status.GenerateOMapInfo != newObj.Status.GenerateOMapInfo + }, + } + generationChangePredicate := predicate.GenerationChangedPredicate{} bldr := ctrl.NewControllerManagedBy(mgr). For(&corev1.ConfigMap{}, configMapPredicates). @@ -174,7 +186,16 @@ func (c *OperatorConfigMapReconciler) SetupWithManager(mgr ctrl.Manager) error { ). Watches(&opv1a1.Subscription{}, enqueueConfigMapRequest, subscriptionPredicates). Watches(&admrv1.ValidatingWebhookConfiguration{}, enqueueConfigMapRequest, webhookPredicates). - Watches(&v1alpha1.StorageClient{}, enqueueConfigMapRequest, builder.WithPredicates(predicate.AnnotationChangedPredicate{})) + Watches( + &v1alpha1.StorageClient{}, + enqueueConfigMapRequest, + builder.WithPredicates( + predicate.Or( + predicate.AnnotationChangedPredicate{}, + generateOMapInfoChangedPredicate, + ), + ), + ) return bldr.Complete(c) } @@ -356,6 +377,11 @@ func (c *OperatorConfigMapReconciler) reconcileDelegatedCSI() error { return fmt.Errorf("failed to reconcile csi operator config: %v", err) } + shouldGenerateRBDOmapInfo, err := c.shouldGenerateRBDOmapInfo() + if err != nil { + return fmt.Errorf("failed to retrive information to generateOMapInfo: %v", err) + } + // ceph rbd driver config rbdDriver := &csiopv1a1.Driver{} rbdDriver.Name = templates.RBDDriverName @@ -365,7 +391,7 @@ func (c *OperatorConfigMapReconciler) reconcileDelegatedCSI() error { if err := c.own(rbdDriver); err != nil { return fmt.Errorf("failed to own csi rbd driver: %v", err) } - rbdDriver.Spec.GenerateOMapInfo = ptr.To(c.shouldGenerateRBDOmapInfo()) + rbdDriver.Spec.GenerateOMapInfo = ptr.To(shouldGenerateRBDOmapInfo) return nil }); err != nil { return fmt.Errorf("failed to reconcile rbd driver: %v", err) @@ -532,9 +558,20 @@ func (c *OperatorConfigMapReconciler) getNoobaaSubManagementConfig() bool { return val } -func (c *OperatorConfigMapReconciler) shouldGenerateRBDOmapInfo() bool { - valAsString := strings.ToLower(c.operatorConfigMap.Data[generateRbdOMapInfoKey]) - return valAsString == strconv.FormatBool(true) +func (c *OperatorConfigMapReconciler) shouldGenerateRBDOmapInfo() (bool, error) { + + storageClients := &v1alpha1.StorageClientList{} + if err := c.list(storageClients); err != nil { + return false, err + } + + for idx := range storageClients.Items { + if storageClients.Items[idx].Status.GenerateOMapInfo { + return true, nil + } + + } + return false, nil } func (c *OperatorConfigMapReconciler) get(obj client.Object, opts ...client.GetOption) error { diff --git a/vendor/github.com/red-hat-storage/ocs-client-operator/api/v1alpha1/storageclient_types.go b/vendor/github.com/red-hat-storage/ocs-client-operator/api/v1alpha1/storageclient_types.go index 897b2a13..bd68c47d 100644 --- a/vendor/github.com/red-hat-storage/ocs-client-operator/api/v1alpha1/storageclient_types.go +++ b/vendor/github.com/red-hat-storage/ocs-client-operator/api/v1alpha1/storageclient_types.go @@ -52,6 +52,8 @@ type StorageClientStatus struct { InMaintenanceMode bool `json:"inMaintenanceMode,omitempty"` + GenerateOMapInfo bool `json:"generateOMapInfo,omitempty"` + // ConsumerID will hold the identity of this cluster inside the attached provider cluster ConsumerID string `json:"id,omitempty"` }