From 673efbd94719143346577a98fb818468d9d08239 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Drzewiecki?= Date: Wed, 27 Sep 2023 12:11:30 +0200 Subject: [PATCH 1/7] adds target for convenient (re)building and (re)deployments --- Makefile | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/Makefile b/Makefile index c53e5231..cbe64444 100644 --- a/Makefile +++ b/Makefile @@ -129,6 +129,19 @@ deploy: manifests kustomize ## Deploy controller to the K8s cluster specified in undeploy: ## Undeploy controller from the K8s cluster specified in ~/.kube/config. Call with ignore-not-found=true to ignore resource not found errors during deletion. $(KUSTOMIZE) build config/default | $(KUBECTL) delete --ignore-not-found=$(ignore-not-found) -f - +.PHONY: k3d-import-img +k3d-import-img: + k3d image import $(IMG) -c im + +.PHONY: apply-sample-cr +apply-sample-cr: + kubectl apply -f config/samples/infrastructuremanager_v1_gardenercluster.yaml + +.PHONE: local-build-and-deploy +local-build-and-deploy: docker-build k3d-import-img deploy gardener-secret-deploy apply-sample-cr + +.PHONY: local-rebuild-and-redeploy +local-rebuild-and-redeploy: undeploy local-build-and-deploy: ##@ Build Dependencies ## Location to install dependencies to From 7f9e0b385b1b5a9fb0607ca62d472981bd25cea8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Drzewiecki?= Date: Wed, 27 Sep 2023 12:19:12 +0200 Subject: [PATCH 2/7] removes invalid colon --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index cbe64444..227f9fce 100644 --- a/Makefile +++ b/Makefile @@ -141,7 +141,7 @@ apply-sample-cr: local-build-and-deploy: docker-build k3d-import-img deploy gardener-secret-deploy apply-sample-cr .PHONY: local-rebuild-and-redeploy -local-rebuild-and-redeploy: undeploy local-build-and-deploy: +local-rebuild-and-redeploy: undeploy local-build-and-deploy ##@ Build Dependencies ## Location to install dependencies to From 177971c37b07f5a9011bddacd2ba9d3eb1579772 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Drzewiecki?= Date: Tue, 24 Oct 2023 12:09:29 +0200 Subject: [PATCH 3/7] fixes Makefile so it will work on current main --- Makefile | 5 +++-- config/manager/kustomization.yaml | 2 +- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/Makefile b/Makefile index 227f9fce..5bb4ebef 100644 --- a/Makefile +++ b/Makefile @@ -131,11 +131,12 @@ undeploy: ## Undeploy controller from the K8s cluster specified in ~/.kube/confi .PHONY: k3d-import-img k3d-import-img: - k3d image import $(IMG) -c im + k3d cluster create $(K3D_CLUSTER_NAME) + k3d image import $(IMG) -c $(K3D_CLUSTER_NAME) .PHONY: apply-sample-cr apply-sample-cr: - kubectl apply -f config/samples/infrastructuremanager_v1_gardenercluster.yaml + kubectl apply -f config/samples/clusterinventory_v1_gardenercluster.yaml .PHONE: local-build-and-deploy local-build-and-deploy: docker-build k3d-import-img deploy gardener-secret-deploy apply-sample-cr diff --git a/config/manager/kustomization.yaml b/config/manager/kustomization.yaml index 8af8ea33..4cde9b19 100644 --- a/config/manager/kustomization.yaml +++ b/config/manager/kustomization.yaml @@ -4,5 +4,5 @@ apiVersion: kustomize.config.k8s.io/v1beta1 kind: Kustomization images: - name: controller - newName: infrastructure-manager + newName: custom-infrastructure-manager newTag: 0.0.1 From c81f5a8958f34388b84636b483a220c257f2d72e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Drzewiecki?= Date: Tue, 24 Oct 2023 15:21:21 +0200 Subject: [PATCH 4/7] updates readme regarding manual cluster creation on k3d --- Makefile | 1 - README.md | 2 ++ 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/Makefile b/Makefile index 5bb4ebef..2d609e98 100644 --- a/Makefile +++ b/Makefile @@ -131,7 +131,6 @@ undeploy: ## Undeploy controller from the K8s cluster specified in ~/.kube/confi .PHONY: k3d-import-img k3d-import-img: - k3d cluster create $(K3D_CLUSTER_NAME) k3d image import $(IMG) -c $(K3D_CLUSTER_NAME) .PHONY: apply-sample-cr diff --git a/README.md b/README.md index bd52147a..c7f5df69 100644 --- a/README.md +++ b/README.md @@ -51,7 +51,9 @@ make docker-build k3d + ```bash + k3d cluster create $K3D_CLUSTER_NAME k3d image import $IMG -c $K3D_CLUSTER_NAME ``` From 5ba8bd360df0942017d131c24c5ad202b9cc39fd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Drzewiecki?= Date: Thu, 26 Oct 2023 12:41:06 +0200 Subject: [PATCH 5/7] conflicts resolution --- api/v1/gardenercluster_types.go | 28 +++++++++++++++++++ ...astructuremanager_v1_gardenercluster.yaml} | 2 +- .../controller/gardener_cluster_controller.go | 10 +++++++ 3 files changed, 39 insertions(+), 1 deletion(-) rename config/samples/{clusterinventory_v1_gardenercluster.yaml => infrastructuremanager_v1_gardenercluster.yaml} (91%) diff --git a/api/v1/gardenercluster_types.go b/api/v1/gardenercluster_types.go index a982c145..cd66c895 100644 --- a/api/v1/gardenercluster_types.go +++ b/api/v1/gardenercluster_types.go @@ -17,6 +17,7 @@ limitations under the License. package v1 import ( + "k8s.io/apimachinery/pkg/api/meta" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" ) @@ -73,6 +74,21 @@ const ( DeletingState State = "Deleting" ) +type ConditionReason string + +const ( + ConditionReasonSecretCreated State = "SecretCreated" + ConditionReasonSecretNotFound State = "SecretNotFound" + ConditionReasonGardenClusterNotRetrieved State = "GardenClusterNotRetrieved" + ConditionReasonGardenClusterNotFound State = "GardenClusterNotFound" +) + +type ConditionType string + +const ( + ConditionTypeUnknown State = "Unknown" +) + // GardenerClusterStatus defines the observed state of GardenerCluster type GardenerClusterStatus struct { // State signifies current state of Gardener Cluster. @@ -86,6 +102,18 @@ type GardenerClusterStatus struct { Conditions []metav1.Condition `json:"conditions,omitempty"` } +func (cluster *GardenerCluster) UpdateState(r State, s State, msg string) { + cluster.Status.State = s + condition := metav1.Condition{ + Type: string(ConditionTypeUnknown), + Status: "True", + LastTransitionTime: metav1.Now(), + Reason: string(r), + Message: msg, + } + meta.SetStatusCondition(&cluster.Status.Conditions, condition) +} + func init() { SchemeBuilder.Register(&GardenerCluster{}, &GardenerClusterList{}) } diff --git a/config/samples/clusterinventory_v1_gardenercluster.yaml b/config/samples/infrastructuremanager_v1_gardenercluster.yaml similarity index 91% rename from config/samples/clusterinventory_v1_gardenercluster.yaml rename to config/samples/infrastructuremanager_v1_gardenercluster.yaml index a699ef82..07a4b959 100644 --- a/config/samples/clusterinventory_v1_gardenercluster.yaml +++ b/config/samples/infrastructuremanager_v1_gardenercluster.yaml @@ -6,7 +6,7 @@ metadata: kyma-project.io/runtime-id: runtime-id kyma-project.io/broker-plan-id: plan-id kyma-project.io/broker-plan-name: plan-name - kyma-project.io/global-account-id: global-account-id + kyma-project.io/global-account-id: global-account-i kyma-project.io/subaccount-id: subAccount-id kyma-project.io/shoot-name: shoot-name kyma-project.io/region: region diff --git a/internal/controller/gardener_cluster_controller.go b/internal/controller/gardener_cluster_controller.go index e9b8c96f..1ed42bb7 100644 --- a/internal/controller/gardener_cluster_controller.go +++ b/internal/controller/gardener_cluster_controller.go @@ -80,7 +80,10 @@ func (r *GardenerClusterController) Reconcile(ctx context.Context, req ctrl.Requ err := r.Client.Get(ctx, req.NamespacedName, &cluster) if err != nil { + cluster.UpdateState(infrastructuremanagerv1.ErrorState, infrastructuremanagerv1.ConditionReasonGardenClusterNotRetrieved, "Couldn't retrieve the Garden Cluster CR") + if k8serrors.IsNotFound(err) { + cluster.UpdateState(infrastructuremanagerv1.DeletingState, infrastructuremanagerv1.ConditionReasonGardenClusterNotFound, "CR not found, secret will be deleted") err = r.deleteSecret(req.NamespacedName.Name) if err != nil { r.log.Error(err, "failed to delete secret") @@ -95,7 +98,10 @@ func (r *GardenerClusterController) Reconcile(ctx context.Context, req ctrl.Requ secret, err := r.getSecret(cluster.Spec.Shoot.Name) if err != nil { + r.log.Error(err, "could not get the Secret for "+cluster.Spec.Shoot.Name) + cluster.UpdateState(infrastructuremanagerv1.ErrorState, infrastructuremanagerv1.ConditionReasonSecretNotFound, "Secret not found, and will be created") if !k8serrors.IsNotFound(err) { + return ctrl.Result{ Requeue: true, RequeueAfter: defaultRequeuInSeconds, @@ -104,12 +110,16 @@ func (r *GardenerClusterController) Reconcile(ctx context.Context, req ctrl.Requ } if secret == nil { + r.log.Error(err, "Secret not found, and will be created") + cluster.UpdateState(infrastructuremanagerv1.ErrorState, infrastructuremanagerv1.ConditionReasonSecretNotFound, "Secret not found, and will be created") err = r.createSecret(ctx, cluster) if err != nil { return r.ResultWithoutRequeue(), err } + } + cluster.UpdateState(infrastructuremanagerv1.ConditionReasonSecretCreated, infrastructuremanagerv1.ReadyState, "GardenCluster is ready") return ctrl.Result{}, nil } From b828ef00c1a78b233aadc3238182ac75f566bda9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Drzewiecki?= Date: Thu, 26 Oct 2023 12:41:21 +0200 Subject: [PATCH 6/7] updates Makefile to use infrastructuremanager sample --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index 2d609e98..190daada 100644 --- a/Makefile +++ b/Makefile @@ -135,7 +135,7 @@ k3d-import-img: .PHONY: apply-sample-cr apply-sample-cr: - kubectl apply -f config/samples/clusterinventory_v1_gardenercluster.yaml + kubectl apply -f config/samples/infrastructuremanager_v1_gardenercluster.yaml .PHONE: local-build-and-deploy local-build-and-deploy: docker-build k3d-import-img deploy gardener-secret-deploy apply-sample-cr From 2b9f5a18ea3ded2fcdcb059bed5feb52dbdda635 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Drzewiecki?= Date: Mon, 30 Oct 2023 08:53:14 +0100 Subject: [PATCH 7/7] WiP configuration --- config/default/manager_gardener_secret_patch.yaml | 5 +++-- config/manager/kustomization.yaml | 4 ++-- .../infrastructuremanager_v1_gardenercluster.yaml | 10 +++++----- 3 files changed, 10 insertions(+), 9 deletions(-) diff --git a/config/default/manager_gardener_secret_patch.yaml b/config/default/manager_gardener_secret_patch.yaml index 4afb921f..f7c43419 100644 --- a/config/default/manager_gardener_secret_patch.yaml +++ b/config/default/manager_gardener_secret_patch.yaml @@ -17,10 +17,11 @@ spec: - name: manager command: - /manager + imagePullPolicy: Always args: - --gardener-kubeconfig-path=/gardener/credentials/kubeconfig - - --gardener-project-name=kyma-dev - - --kubeconfig-expiration-time=24h + - --gardener-project-name=frog-dev + - --kubeconfig-expiration-time=10m volumeMounts: - name: gardener-kubeconfig mountPath: /gardener/credentials diff --git a/config/manager/kustomization.yaml b/config/manager/kustomization.yaml index 4cde9b19..59955890 100644 --- a/config/manager/kustomization.yaml +++ b/config/manager/kustomization.yaml @@ -4,5 +4,5 @@ apiVersion: kustomize.config.k8s.io/v1beta1 kind: Kustomization images: - name: controller - newName: custom-infrastructure-manager - newTag: 0.0.1 + newName: europe-docker.pkg.dev/kyma-project/dev/infrastructure-manager + newTag: PR-49 diff --git a/config/samples/infrastructuremanager_v1_gardenercluster.yaml b/config/samples/infrastructuremanager_v1_gardenercluster.yaml index 07a4b959..b1aa8592 100644 --- a/config/samples/infrastructuremanager_v1_gardenercluster.yaml +++ b/config/samples/infrastructuremanager_v1_gardenercluster.yaml @@ -3,21 +3,21 @@ kind: GardenerCluster metadata: labels: kyma-project.io/instance-id: instance-id - kyma-project.io/runtime-id: runtime-id + kyma-project.io/runtime-id: md-id kyma-project.io/broker-plan-id: plan-id kyma-project.io/broker-plan-name: plan-name kyma-project.io/global-account-id: global-account-i kyma-project.io/subaccount-id: subAccount-id - kyma-project.io/shoot-name: shoot-name + kyma-project.io/shoot-name: md-im kyma-project.io/region: region operator.kyma-project.io/kyma-name: kymaName - name: runtime-id + name: md-id namespace: kcp-system spec: shoot: - name: shoot-name + name: md-im kubeconfig: secret: - name: kubeconfig-runtime-id + name: kubeconfig-md-im namespace: kcp-system key: "config"