From 157e33e61f47569e9448de07e6e59f7cb07ffa89 Mon Sep 17 00:00:00 2001 From: "Charel Baum (external expert on behalf of DB Netz AG)" Date: Wed, 18 Oct 2023 11:16:20 +0200 Subject: [PATCH] fix(kafka/cluster): clusterpolicy update + delete Signed-off-by: Charel Baum (external expert on behalf of DB Netz AG) (cherry picked from commit 3c3b18cb3fa99243eb90f34b37184234c42e1357) --- apis/kafka/generator-config.yaml | 6 ++++++ apis/kafka/v1alpha1/zz_cluster.go | 2 ++ apis/kafka/v1alpha1/zz_generated.deepcopy.go | 5 +++++ .../crds/kafka.aws.crossplane.io_clusters.yaml | 3 +++ pkg/controller/kafka/cluster/setup.go | 16 +++++++++++----- 5 files changed, 27 insertions(+), 5 deletions(-) diff --git a/apis/kafka/generator-config.yaml b/apis/kafka/generator-config.yaml index 872b02a445..135ea4c592 100644 --- a/apis/kafka/generator-config.yaml +++ b/apis/kafka/generator-config.yaml @@ -18,3 +18,9 @@ resources: errors: 404: code: NotFoundException + fields: + ClusterPolicyVersion: + is_read_only: true + from: + operation: GetClusterPolicy + path: CurrentVersion diff --git a/apis/kafka/v1alpha1/zz_cluster.go b/apis/kafka/v1alpha1/zz_cluster.go index c63ae90c00..1e5dadb786 100644 --- a/apis/kafka/v1alpha1/zz_cluster.go +++ b/apis/kafka/v1alpha1/zz_cluster.go @@ -66,6 +66,8 @@ type ClusterSpec struct { type ClusterObservation struct { // The Amazon Resource Name (ARN) of the cluster. ClusterARN *string `json:"clusterARN,omitempty"` + // Cluster policy version. + ClusterPolicyVersion *string `json:"clusterPolicyVersion,omitempty"` // The state of the cluster. The possible states are ACTIVE, CREATING, DELETING, // FAILED, HEALING, MAINTENANCE, REBOOTING_BROKER, and UPDATING. State *string `json:"state,omitempty"` diff --git a/apis/kafka/v1alpha1/zz_generated.deepcopy.go b/apis/kafka/v1alpha1/zz_generated.deepcopy.go index 116b89ca3a..ff510ee16c 100644 --- a/apis/kafka/v1alpha1/zz_generated.deepcopy.go +++ b/apis/kafka/v1alpha1/zz_generated.deepcopy.go @@ -506,6 +506,11 @@ func (in *ClusterObservation) DeepCopyInto(out *ClusterObservation) { *out = new(string) **out = **in } + if in.ClusterPolicyVersion != nil { + in, out := &in.ClusterPolicyVersion, &out.ClusterPolicyVersion + *out = new(string) + **out = **in + } if in.State != nil { in, out := &in.State, &out.State *out = new(string) diff --git a/package/crds/kafka.aws.crossplane.io_clusters.yaml b/package/crds/kafka.aws.crossplane.io_clusters.yaml index cc46b89b69..10c19afe6b 100644 --- a/package/crds/kafka.aws.crossplane.io_clusters.yaml +++ b/package/crds/kafka.aws.crossplane.io_clusters.yaml @@ -1295,6 +1295,9 @@ spec: clusterARN: description: The Amazon Resource Name (ARN) of the cluster. type: string + clusterPolicyVersion: + description: Cluster policy version. + type: string state: description: The state of the cluster. The possible states are ACTIVE, CREATING, DELETING, FAILED, HEALING, MAINTENANCE, REBOOTING_BROKER, diff --git a/pkg/controller/kafka/cluster/setup.go b/pkg/controller/kafka/cluster/setup.go index 5eef641d8e..80bfce0da7 100644 --- a/pkg/controller/kafka/cluster/setup.go +++ b/pkg/controller/kafka/cluster/setup.go @@ -375,7 +375,7 @@ func (u *hooks) getClusterPolicyState(ctx context.Context, wanted *svcapitypes.C }) if IsNotFound(err) { if wanted.Spec.ForProvider.ClusterPolicy == nil { - return subResourceOK, "spec.forProvider.clusterPolicy", nil + return subResourceOK, "", nil } return subResourceNeedsUpdate, "spec.forProvider.clusterPolicy", nil } @@ -383,11 +383,16 @@ func (u *hooks) getClusterPolicyState(ctx context.Context, wanted *svcapitypes.C return subResourceOK, "", errors.Wrap(err, errGetClusterPolicy) } + // write clusterPolicy currentVersion into status to be used in potential update and to be visible for user + wanted.Status.AtProvider.ClusterPolicyVersion = res.CurrentVersion + if res.Policy == nil { if wanted.Spec.ForProvider.ClusterPolicy == nil { - return subResourceNeedsDeletion, "spec.forProvider.clusterPolicy", nil + return subResourceOK, "", nil } - return subResourceOK, "spec.forProvider.clusterPolicy", nil + return subResourceNeedsUpdate, "spec.forProvider.clusterPolicy", nil + } else if wanted.Spec.ForProvider.ClusterPolicy == nil { + return subResourceNeedsDeletion, "spec.forProvider.clusterPolicy", nil } currentPolicy, err := policy.ParsePolicyString(*res.Policy) @@ -990,8 +995,9 @@ func (u *hooks) update(ctx context.Context, mg resource.Managed) (managed.Extern return managed.ExternalUpdate{}, errors.Wrap(err, errMarshalClusterPolicy) } _, err = u.client.PutClusterPolicyWithContext(ctx, &svcsdk.PutClusterPolicyInput{ - ClusterArn: ¤tARN, - Policy: policyRaw, + ClusterArn: ¤tARN, + CurrentVersion: cr.Status.AtProvider.ClusterPolicyVersion, + Policy: policyRaw, }) if err != nil { return managed.ExternalUpdate{}, errors.Wrap(err, errPutClusterPolicy)