From 44b336c2b6a3011dfb2286ef91135b197a11bbda Mon Sep 17 00:00:00 2001 From: Wahab Ali Date: Tue, 17 Dec 2024 09:59:40 -0500 Subject: [PATCH] Add labels to Cluster when deploying clusterTemplate --- api/v1alpha1/managedcluster_types.go | 37 +++++++++++++++++-- .../controller/managedcluster_controller.go | 34 ++++++----------- .../cluster/aws-eks/templates/cluster.yaml | 4 ++ templates/cluster/aws-eks/values.yaml | 2 + .../aws-hosted-cp/templates/cluster.yaml | 4 ++ templates/cluster/aws-hosted-cp/values.yaml | 2 + .../aws-standalone-cp/templates/cluster.yaml | 4 ++ .../cluster/aws-standalone-cp/values.yaml | 4 ++ .../azure-hosted-cp/templates/cluster.yaml | 4 ++ templates/cluster/azure-hosted-cp/values.yaml | 2 + .../templates/cluster.yaml | 4 ++ .../cluster/azure-standalone-cp/values.yaml | 2 + .../vsphere-hosted-cp/templates/cluster.yaml | 4 ++ .../cluster/vsphere-hosted-cp/values.yaml | 2 + .../templates/cluster.yaml | 4 ++ .../cluster/vsphere-standalone-cp/values.yaml | 2 + 16 files changed, 90 insertions(+), 25 deletions(-) diff --git a/api/v1alpha1/managedcluster_types.go b/api/v1alpha1/managedcluster_types.go index 404a6de15..2ac8f4638 100644 --- a/api/v1alpha1/managedcluster_types.go +++ b/api/v1alpha1/managedcluster_types.go @@ -15,6 +15,9 @@ package v1alpha1 import ( + "encoding/json" + "fmt" + apiextensionsv1 "k8s.io/apiextensions-apiserver/pkg/apis/apiextensions/v1" apimeta "k8s.io/apimachinery/pkg/api/meta" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" @@ -120,11 +123,39 @@ type ManagedCluster struct { Status ManagedClusterStatus `json:"status,omitempty"` } -func (in *ManagedCluster) HelmValues() (values map[string]any, err error) { +func (in *ManagedCluster) HelmValues() (map[string]any, error) { + var values map[string]any + if in.Spec.Config != nil { - err = yaml.Unmarshal(in.Spec.Config.Raw, &values) + if err := yaml.Unmarshal(in.Spec.Config.Raw, &values); err != nil { + return nil, fmt.Errorf("error unmarshalling helm values for clusterTemplate %s: %w", in.Spec.Template, err) + } } - return values, err + + return values, nil +} + +func (in *ManagedCluster) SetHelmValues(values map[string]any) error { + b, err := json.Marshal(values) + if err != nil { + return fmt.Errorf("error marshalling helm values for clusterTemplate %s: %w", in.Spec.Template, err) + } + + in.Spec.Config = &apiextensionsv1.JSON{Raw: b} + return nil +} + +func (in *ManagedCluster) AddHelmValues(fn func(map[string]any) error) error { + values, err := in.HelmValues() + if err != nil { + return err + } + + if err := fn(values); err != nil { + return err + } + + return in.SetHelmValues(values) } func (in *ManagedCluster) GetConditions() *[]metav1.Condition { diff --git a/internal/controller/managedcluster_controller.go b/internal/controller/managedcluster_controller.go index 3dcc43ade..292c318cc 100644 --- a/internal/controller/managedcluster_controller.go +++ b/internal/controller/managedcluster_controller.go @@ -16,7 +16,6 @@ package controller import ( "context" - "encoding/json" "errors" "fmt" "slices" @@ -31,7 +30,6 @@ import ( "helm.sh/helm/v3/pkg/action" "helm.sh/helm/v3/pkg/chart" corev1 "k8s.io/api/core/v1" - apiextensionsv1 "k8s.io/apiextensions-apiserver/pkg/apis/apiextensions/v1" apierrors "k8s.io/apimachinery/pkg/api/errors" apimeta "k8s.io/apimachinery/pkg/api/meta" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" @@ -297,13 +295,21 @@ func (r *ManagedClusterReconciler) updateCluster(ctx context.Context, mc *hmc.Ma return ctrl.Result{}, nil } - helmValues, err := setIdentityHelmValues(mc.Spec.Config, cred.Spec.IdentityRef) - if err != nil { - return ctrl.Result{}, fmt.Errorf("error setting identity values: %w", err) + if err := mc.AddHelmValues(func(values map[string]any) error { + values["clusterIdentity"] = cred.Spec.IdentityRef + + if _, ok := values["clusterLabels"]; !ok { + // Use the ManagedCluster's own labels if not defined. + values["clusterLabels"] = mc.GetObjectMeta().GetLabels() + } + + return nil + }); err != nil { + return ctrl.Result{}, err } hrReconcileOpts := helm.ReconcileHelmReleaseOpts{ - Values: helmValues, + Values: mc.Spec.Config, OwnerReference: &metav1.OwnerReference{ APIVersion: hmc.GroupVersion.String(), Kind: hmc.ManagedClusterKind, @@ -779,22 +785,6 @@ func (r *ManagedClusterReconciler) reconcileCredentialPropagation(ctx context.Co return nil } -func setIdentityHelmValues(values *apiextensionsv1.JSON, idRef *corev1.ObjectReference) (*apiextensionsv1.JSON, error) { - var valuesJSON map[string]any - err := json.Unmarshal(values.Raw, &valuesJSON) - if err != nil { - return nil, fmt.Errorf("error unmarshalling values: %w", err) - } - - valuesJSON["clusterIdentity"] = idRef - valuesRaw, err := json.Marshal(valuesJSON) - if err != nil { - return nil, fmt.Errorf("error marshalling values: %w", err) - } - - return &apiextensionsv1.JSON{Raw: valuesRaw}, nil -} - func (r *ManagedClusterReconciler) setAvailableUpgrades(ctx context.Context, managedCluster *hmc.ManagedCluster, template *hmc.ClusterTemplate) error { if template == nil { return nil diff --git a/templates/cluster/aws-eks/templates/cluster.yaml b/templates/cluster/aws-eks/templates/cluster.yaml index dca896de1..a4d01b97c 100644 --- a/templates/cluster/aws-eks/templates/cluster.yaml +++ b/templates/cluster/aws-eks/templates/cluster.yaml @@ -2,6 +2,10 @@ apiVersion: cluster.x-k8s.io/v1beta1 kind: Cluster metadata: name: {{ include "cluster.name" . }} + labels: + {{- with .Values.clusterLabels }} + {{- toYaml . | nindent 4 }} + {{- end }} spec: {{- with .Values.clusterNetwork }} clusterNetwork: diff --git a/templates/cluster/aws-eks/values.yaml b/templates/cluster/aws-eks/values.yaml index 188b7818b..48a35c029 100644 --- a/templates/cluster/aws-eks/values.yaml +++ b/templates/cluster/aws-eks/values.yaml @@ -9,6 +9,8 @@ clusterNetwork: cidrBlocks: - "10.96.0.0/12" +clusterLabels: + # EKS cluster parameters region: "" sshKeyName: "" diff --git a/templates/cluster/aws-hosted-cp/templates/cluster.yaml b/templates/cluster/aws-hosted-cp/templates/cluster.yaml index eaef59c58..49380369d 100644 --- a/templates/cluster/aws-hosted-cp/templates/cluster.yaml +++ b/templates/cluster/aws-hosted-cp/templates/cluster.yaml @@ -2,6 +2,10 @@ apiVersion: cluster.x-k8s.io/v1beta1 kind: Cluster metadata: name: {{ include "cluster.name" . }} + labels: + {{- with .Values.clusterLabels }} + {{- toYaml . | nindent 4 }} + {{- end }} spec: {{- with .Values.clusterNetwork }} clusterNetwork: diff --git a/templates/cluster/aws-hosted-cp/values.yaml b/templates/cluster/aws-hosted-cp/values.yaml index c018fe1fd..58a807be1 100644 --- a/templates/cluster/aws-hosted-cp/values.yaml +++ b/templates/cluster/aws-hosted-cp/values.yaml @@ -9,6 +9,8 @@ clusterNetwork: cidrBlocks: - "10.96.0.0/12" +clusterLabels: + # AWS cluster parameters vpcID: "" region: "" diff --git a/templates/cluster/aws-standalone-cp/templates/cluster.yaml b/templates/cluster/aws-standalone-cp/templates/cluster.yaml index cb3425af5..1edbf2049 100644 --- a/templates/cluster/aws-standalone-cp/templates/cluster.yaml +++ b/templates/cluster/aws-standalone-cp/templates/cluster.yaml @@ -2,6 +2,10 @@ apiVersion: cluster.x-k8s.io/v1beta1 kind: Cluster metadata: name: {{ include "cluster.name" . }} + labels: + {{- with .Values.clusterLabels }} + {{- toYaml . | nindent 4 }} + {{- end }} spec: {{- with .Values.clusterNetwork }} clusterNetwork: diff --git a/templates/cluster/aws-standalone-cp/values.yaml b/templates/cluster/aws-standalone-cp/values.yaml index 6f0a019db..7716baed6 100644 --- a/templates/cluster/aws-standalone-cp/values.yaml +++ b/templates/cluster/aws-standalone-cp/values.yaml @@ -10,6 +10,10 @@ clusterNetwork: cidrBlocks: - "10.96.0.0/12" +clusterLabels: +# env: dev3 +# region: region1 + # AWS cluster parameters region: "" sshKeyName: "" diff --git a/templates/cluster/azure-hosted-cp/templates/cluster.yaml b/templates/cluster/azure-hosted-cp/templates/cluster.yaml index 74bd07a54..1bc60236e 100644 --- a/templates/cluster/azure-hosted-cp/templates/cluster.yaml +++ b/templates/cluster/azure-hosted-cp/templates/cluster.yaml @@ -2,6 +2,10 @@ apiVersion: cluster.x-k8s.io/v1beta1 kind: Cluster metadata: name: {{ include "cluster.name" . }} + labels: + {{- with .Values.clusterLabels }} + {{- toYaml . | nindent 4 }} + {{- end }} spec: {{- with .Values.clusterNetwork }} clusterNetwork: diff --git a/templates/cluster/azure-hosted-cp/values.yaml b/templates/cluster/azure-hosted-cp/values.yaml index b4e1b81e6..1e748cf9d 100644 --- a/templates/cluster/azure-hosted-cp/values.yaml +++ b/templates/cluster/azure-hosted-cp/values.yaml @@ -10,6 +10,8 @@ clusterNetwork: cidrBlocks: - "10.96.0.0/12" +clusterLabels: + # Azure cluster parameters location: "" subscriptionID: "" diff --git a/templates/cluster/azure-standalone-cp/templates/cluster.yaml b/templates/cluster/azure-standalone-cp/templates/cluster.yaml index 2ce7581f7..6bb4fc956 100644 --- a/templates/cluster/azure-standalone-cp/templates/cluster.yaml +++ b/templates/cluster/azure-standalone-cp/templates/cluster.yaml @@ -2,6 +2,10 @@ apiVersion: cluster.x-k8s.io/v1beta1 kind: Cluster metadata: name: {{ include "cluster.name" . }} + labels: + {{- with .Values.clusterLabels }} + {{- toYaml . | nindent 4 }} + {{- end }} spec: {{- with .Values.clusterNetwork }} clusterNetwork: diff --git a/templates/cluster/azure-standalone-cp/values.yaml b/templates/cluster/azure-standalone-cp/values.yaml index bd7504aad..74b4eafc5 100644 --- a/templates/cluster/azure-standalone-cp/values.yaml +++ b/templates/cluster/azure-standalone-cp/values.yaml @@ -10,6 +10,8 @@ clusterNetwork: cidrBlocks: - "10.96.0.0/12" +clusterLabels: + # Azure cluster parameters location: "" subscriptionID: "" diff --git a/templates/cluster/vsphere-hosted-cp/templates/cluster.yaml b/templates/cluster/vsphere-hosted-cp/templates/cluster.yaml index 87c042604..b85007c1e 100644 --- a/templates/cluster/vsphere-hosted-cp/templates/cluster.yaml +++ b/templates/cluster/vsphere-hosted-cp/templates/cluster.yaml @@ -2,6 +2,10 @@ apiVersion: cluster.x-k8s.io/v1beta1 kind: Cluster metadata: name: {{ include "cluster.name" . }} + labels: + {{- with .Values.clusterLabels }} + {{- toYaml . | nindent 4 }} + {{- end }} spec: {{- with .Values.clusterNetwork }} clusterNetwork: diff --git a/templates/cluster/vsphere-hosted-cp/values.yaml b/templates/cluster/vsphere-hosted-cp/values.yaml index 187774dc8..2f20e08c6 100644 --- a/templates/cluster/vsphere-hosted-cp/values.yaml +++ b/templates/cluster/vsphere-hosted-cp/values.yaml @@ -10,6 +10,8 @@ clusterNetwork: cidrBlocks: - "10.96.0.0/12" +clusterLabels: + # vSphere cluster parameters clusterIdentity: name: "" diff --git a/templates/cluster/vsphere-standalone-cp/templates/cluster.yaml b/templates/cluster/vsphere-standalone-cp/templates/cluster.yaml index c2437c246..cd8ed32d7 100644 --- a/templates/cluster/vsphere-standalone-cp/templates/cluster.yaml +++ b/templates/cluster/vsphere-standalone-cp/templates/cluster.yaml @@ -2,6 +2,10 @@ apiVersion: cluster.x-k8s.io/v1beta1 kind: Cluster metadata: name: {{ include "cluster.name" . }} + labels: + {{- with .Values.clusterLabels }} + {{- toYaml . | nindent 4 }} + {{- end }} spec: {{- with .Values.clusterNetwork }} clusterNetwork: diff --git a/templates/cluster/vsphere-standalone-cp/values.yaml b/templates/cluster/vsphere-standalone-cp/values.yaml index eb64d7080..d92d63f05 100644 --- a/templates/cluster/vsphere-standalone-cp/values.yaml +++ b/templates/cluster/vsphere-standalone-cp/values.yaml @@ -10,6 +10,8 @@ clusterNetwork: cidrBlocks: - "10.96.0.0/12" +clusterLabels: + # vSphere cluster parameters clusterIdentity: name: ""