From d3922874f07172c28ccf7e6666d0e19d5e1b377d Mon Sep 17 00:00:00 2001 From: cmoulliard Date: Fri, 8 Nov 2024 17:33:30 +0100 Subject: [PATCH] Move the current time function. Generate the missing field. #441 Signed-off-by: cmoulliard --- pkg/controllers/localbuild/argo.go | 11 ++++++----- .../resources/idpbuilder.cnoe.io_localbuilds.yaml | 2 ++ 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/pkg/controllers/localbuild/argo.go b/pkg/controllers/localbuild/argo.go index 3aec07aa..79017914 100644 --- a/pkg/controllers/localbuild/argo.go +++ b/pkg/controllers/localbuild/argo.go @@ -79,19 +79,18 @@ func (r *LocalbuildReconciler) ReconcileArgo(ctx context.Context, req ctrl.Reque if err != nil { return ctrl.Result{}, fmt.Errorf("Error hashing password: %w", err) } - passwordMtime := time.Now().Format(time.RFC3339) // Prepare the patch for the Secret's `stringData` field patchData := map[string]interface{}{ "stringData": map[string]string{ "admin.password": string(hashedPassword), - "admin.passwordMtime": passwordMtime, + "admin.passwordMtime": time.Now().Format(time.RFC3339), }, } // Convert patch data to JSON patchBytes, err := json.Marshal(patchData) if err != nil { - return ctrl.Result{}, fmt.Errorf("Error marshalling patch data:", err) + return ctrl.Result{}, fmt.Errorf("Error marshalling patch data: %w", err) } kubeClient, err := k8s.GetKubeClient() @@ -109,7 +108,7 @@ func (r *LocalbuildReconciler) ReconcileArgo(ctx context.Context, req ctrl.Reque // Patching the argocd-secret with the hashed password err = kubeClient.Patch(ctx, &s, client.RawPatch(types.StrategicMergePatchType, patchBytes)) if err != nil { - return ctrl.Result{}, fmt.Errorf("Error patching the Secret:", err) + return ctrl.Result{}, fmt.Errorf("Error patching the Secret: %w", err) } adminSecret := v1.Secret{ @@ -129,7 +128,9 @@ func (r *LocalbuildReconciler) ReconcileArgo(ctx context.Context, req ctrl.Reque // Re-creating the initial admin password secret: argocd-initial-admin-secret as used with "idpbuilder get secrets -p argocd" err = kubeClient.Create(ctx, &adminSecret) if err != nil { - return ctrl.Result{}, fmt.Errorf("Error creating the initial admin secret:", err) + return ctrl.Result{}, fmt.Errorf("Error creating the initial admin secret: %w", err) + } else { + return ctrl.Result{}, nil } } diff --git a/pkg/controllers/resources/idpbuilder.cnoe.io_localbuilds.yaml b/pkg/controllers/resources/idpbuilder.cnoe.io_localbuilds.yaml index ab98210f..ba9e7ab1 100644 --- a/pkg/controllers/resources/idpbuilder.cnoe.io_localbuilds.yaml +++ b/pkg/controllers/resources/idpbuilder.cnoe.io_localbuilds.yaml @@ -41,6 +41,8 @@ spec: description: BuildCustomizationSpec fields cannot change once a cluster is created properties: + devMode: + type: boolean host: type: string ingressHost: