From 657a6107e0c49277220c7618c5a0d2363440babb Mon Sep 17 00:00:00 2001 From: Tanuj Dwivedi Date: Tue, 10 Jan 2023 12:13:36 +0530 Subject: [PATCH] Adding optional field at key level when fetching values from configmap and secret Signed-off-by: Tanuj Dwivedi --- controllers/helmrelease_controller.go | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/controllers/helmrelease_controller.go b/controllers/helmrelease_controller.go index 8ec202acc..2df70de31 100644 --- a/controllers/helmrelease_controller.go +++ b/controllers/helmrelease_controller.go @@ -23,6 +23,7 @@ import ( "strings" "time" + "github.com/go-logr/logr" "github.com/hashicorp/go-retryablehttp" "helm.sh/helm/v3/pkg/chart" "helm.sh/helm/v3/pkg/chartutil" @@ -542,6 +543,10 @@ func (r *HelmReleaseReconciler) composeValues(ctx context.Context, hr v2.HelmRel return nil, fmt.Errorf("could not find %s '%s'", v.Kind, namespacedName) } if data, ok := resource.Data[v.GetValuesKey()]; !ok { + if v.Optional { + (logr.FromContext(ctx)).Info(fmt.Sprintf("could not find optional key %s in %s '%s'", v.GetValuesKey(), v.Kind, namespacedName)) + continue + } return nil, fmt.Errorf("missing key '%s' in %s '%s'", v.GetValuesKey(), v.Kind, namespacedName) } else { valuesData = []byte(data) @@ -575,6 +580,10 @@ func (r *HelmReleaseReconciler) composeValues(ctx context.Context, hr v2.HelmRel return nil, fmt.Errorf("could not find %s '%s'", v.Kind, namespacedName) } if data, ok := resource.Data[v.GetValuesKey()]; !ok { + if v.Optional { + (logr.FromContext(ctx)).Info(fmt.Sprintf("could not find optional key %s in %s '%s'", v.GetValuesKey(), v.Kind, namespacedName)) + continue + } return nil, fmt.Errorf("missing key '%s' in %s '%s'", v.GetValuesKey(), v.Kind, namespacedName) } else { valuesData = data