From a4d86d168e2594fc5fc173caac26baf6d2155280 Mon Sep 17 00:00:00 2001 From: Yann Brillouet Date: Tue, 13 Jun 2023 16:52:05 +0200 Subject: [PATCH 1/2] Prefactor: extract central CR reconciliation to dedicated function in fleetshard central reconciler --- .../pkg/central/reconciler/reconciler.go | 81 +++++++++++-------- 1 file changed, 46 insertions(+), 35 deletions(-) diff --git a/fleetshard/pkg/central/reconciler/reconciler.go b/fleetshard/pkg/central/reconciler/reconciler.go index 8674c00845..d01827c3fb 100644 --- a/fleetshard/pkg/central/reconciler/reconciler.go +++ b/fleetshard/pkg/central/reconciler/reconciler.go @@ -291,41 +291,8 @@ func (r *CentralReconciler) Reconcile(ctx context.Context, remoteCentral private } } - centralExists := true - existingCentral := v1alpha1.Central{} - err = r.client.Get(ctx, ctrlClient.ObjectKey{Namespace: remoteCentralNamespace, Name: remoteCentralName}, &existingCentral) - if err != nil { - if !apiErrors.IsNotFound(err) { - return nil, errors.Wrapf(err, "unable to check the existence of central %s/%s", central.GetNamespace(), central.GetName()) - } - centralExists = false - } - - if !centralExists { - if central.GetAnnotations() == nil { - central.Annotations = map[string]string{} - } - if err := util.IncrementCentralRevision(central); err != nil { - return nil, errors.Wrap(err, "incrementing central's revision") - } - - glog.Infof("Creating central %s/%s", central.GetNamespace(), central.GetName()) - if err := r.client.Create(ctx, central); err != nil { - return nil, errors.Wrapf(err, "creating new central %s/%s", remoteCentralNamespace, remoteCentralName) - } - glog.Infof("Central %s/%s created", central.GetNamespace(), central.GetName()) - } else { - glog.Infof("Update central %s/%s", central.GetNamespace(), central.GetName()) - existingCentral.Spec = central.Spec - - if err := util.IncrementCentralRevision(&existingCentral); err != nil { - return nil, errors.Wrap(err, "incrementing central's revision") - } - existingCentral.Spec = *central.Spec.DeepCopy() - - if err := r.client.Update(ctx, &existingCentral); err != nil { - return nil, errors.Wrapf(err, "updating central %s/%s", central.GetNamespace(), central.GetName()) - } + if err = r.reconcileCentral(ctx, remoteCentral, central); err != nil { + return nil, err } centralTLSSecretFound := true // pragma: allowlist secret @@ -369,6 +336,50 @@ func (r *CentralReconciler) Reconcile(ctx context.Context, remoteCentral private return status, nil } +func (r *CentralReconciler) reconcileCentral(ctx context.Context, remoteCentral private.ManagedCentral, central *v1alpha1.Central) error { + remoteCentralName := remoteCentral.Metadata.Name + remoteCentralNamespace := remoteCentral.Metadata.Namespace + + centralExists := true + existingCentral := v1alpha1.Central{} + err := r.client.Get(ctx, ctrlClient.ObjectKey{Namespace: remoteCentralNamespace, Name: remoteCentralName}, &existingCentral) + if err != nil { + if !apiErrors.IsNotFound(err) { + return errors.Wrapf(err, "unable to check the existence of central %s/%s", central.GetNamespace(), central.GetName()) + } + centralExists = false + } + + if !centralExists { + if central.GetAnnotations() == nil { + central.Annotations = map[string]string{} + } + if err := util.IncrementCentralRevision(central); err != nil { + return errors.Wrap(err, "incrementing central's revision") + } + + glog.Infof("Creating central %s/%s", central.GetNamespace(), central.GetName()) + if err := r.client.Create(ctx, central); err != nil { + return errors.Wrapf(err, "creating new central %s/%s", remoteCentralNamespace, remoteCentralName) + } + glog.Infof("Central %s/%s created", central.GetNamespace(), central.GetName()) + } else { + glog.Infof("Update central %s/%s", central.GetNamespace(), central.GetName()) + existingCentral.Spec = central.Spec + + if err := util.IncrementCentralRevision(&existingCentral); err != nil { + return errors.Wrap(err, "incrementing central's revision") + } + existingCentral.Spec = *central.Spec.DeepCopy() + + if err := r.client.Update(ctx, &existingCentral); err != nil { + return errors.Wrapf(err, "updating central %s/%s", central.GetNamespace(), central.GetName()) + } + } + + return nil +} + func (r *CentralReconciler) reconcileAuthProvider(ctx context.Context, remoteCentral *private.ManagedCentral) error { // Skip auth provider initialisation if: // 1. Auth provider is already created From 4b2a7c7cd3670db3d077425e08bd470415d9f692 Mon Sep 17 00:00:00 2001 From: Yann Brillouet Date: Tue, 13 Jun 2023 16:53:21 +0200 Subject: [PATCH 2/2] Pass remoteCentral by pointer --- fleetshard/pkg/central/reconciler/reconciler.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/fleetshard/pkg/central/reconciler/reconciler.go b/fleetshard/pkg/central/reconciler/reconciler.go index d01827c3fb..4adc342866 100644 --- a/fleetshard/pkg/central/reconciler/reconciler.go +++ b/fleetshard/pkg/central/reconciler/reconciler.go @@ -291,7 +291,7 @@ func (r *CentralReconciler) Reconcile(ctx context.Context, remoteCentral private } } - if err = r.reconcileCentral(ctx, remoteCentral, central); err != nil { + if err = r.reconcileCentral(ctx, &remoteCentral, central); err != nil { return nil, err } @@ -336,7 +336,7 @@ func (r *CentralReconciler) Reconcile(ctx context.Context, remoteCentral private return status, nil } -func (r *CentralReconciler) reconcileCentral(ctx context.Context, remoteCentral private.ManagedCentral, central *v1alpha1.Central) error { +func (r *CentralReconciler) reconcileCentral(ctx context.Context, remoteCentral *private.ManagedCentral, central *v1alpha1.Central) error { remoteCentralName := remoteCentral.Metadata.Name remoteCentralNamespace := remoteCentral.Metadata.Namespace