Skip to content

Commit

Permalink
Merge pull request #266 from kaden-l-nelson/patch/finalizer
Browse files Browse the repository at this point in the history
Add a finalizer to the ImagePolicy and ImageRepository resources
  • Loading branch information
stefanprodan authored Jun 24, 2022
2 parents 5ab6137 + 518a846 commit 5c1b128
Show file tree
Hide file tree
Showing 4 changed files with 44 additions and 0 deletions.
1 change: 1 addition & 0 deletions api/v1beta1/imagepolicy_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ import (
)

const ImagePolicyKind = "ImagePolicy"
const ImagePolicyFinalizer = "finalizers.fluxcd.io"

// ImagePolicySpec defines the parameters for calculating the
// ImagePolicy
Expand Down
1 change: 1 addition & 0 deletions api/v1beta1/imagerepository_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ import (
)

const ImageRepositoryKind = "ImageRepository"
const ImageRepositoryFinalizer = "finalizers.fluxcd.io"

// ImageRepositorySpec defines the parameters for scanning an image
// repository, e.g., `fluxcd/flux`.
Expand Down
21 changes: 21 additions & 0 deletions controllers/imagepolicy_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ import (
ctrl "sigs.k8s.io/controller-runtime"
"sigs.k8s.io/controller-runtime/pkg/client"
"sigs.k8s.io/controller-runtime/pkg/controller"
"sigs.k8s.io/controller-runtime/pkg/controller/controllerutil"
"sigs.k8s.io/controller-runtime/pkg/handler"
"sigs.k8s.io/controller-runtime/pkg/reconcile"
"sigs.k8s.io/controller-runtime/pkg/source"
Expand Down Expand Up @@ -89,6 +90,26 @@ func (r *ImagePolicyReconciler) Reconcile(ctx context.Context, req ctrl.Request)
}
defer r.recordReadinessMetric(ctx, &pol)

// Add our finalizer if it does not exist.
if !controllerutil.ContainsFinalizer(&pol, imagev1.ImagePolicyFinalizer) {
patch := client.MergeFrom(pol.DeepCopy())
controllerutil.AddFinalizer(&pol, imagev1.ImagePolicyFinalizer)
if err := r.Patch(ctx, &pol, patch); err != nil {
log.Error(err, "unable to register finalizer")
return ctrl.Result{}, err
}
}

// If the object is under deletion, record the readiness, and remove our finalizer.
if !pol.ObjectMeta.DeletionTimestamp.IsZero() {
r.recordReadinessMetric(ctx, &pol)
controllerutil.RemoveFinalizer(&pol, imagev1.ImagePolicyFinalizer)
if err := r.Update(ctx, &pol); err != nil {
return ctrl.Result{}, err
}
return ctrl.Result{}, nil
}

var repo imagev1.ImageRepository
repoNamespacedName := types.NamespacedName{
Namespace: pol.Namespace,
Expand Down
21 changes: 21 additions & 0 deletions controllers/imagerepository_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ import (
ctrl "sigs.k8s.io/controller-runtime"
"sigs.k8s.io/controller-runtime/pkg/client"
"sigs.k8s.io/controller-runtime/pkg/controller"
"sigs.k8s.io/controller-runtime/pkg/controller/controllerutil"
"sigs.k8s.io/controller-runtime/pkg/predicate"

"github.com/Azure/azure-sdk-for-go/sdk/azcore/arm"
Expand Down Expand Up @@ -128,6 +129,26 @@ func (r *ImageRepositoryReconciler) Reconcile(ctx context.Context, req ctrl.Requ

log := ctrl.LoggerFrom(ctx)

// Add our finalizer if it does not exist.
if !controllerutil.ContainsFinalizer(&imageRepo, imagev1.ImageRepositoryFinalizer) {
patch := client.MergeFrom(imageRepo.DeepCopy())
controllerutil.AddFinalizer(&imageRepo, imagev1.ImageRepositoryFinalizer)
if err := r.Patch(ctx, &imageRepo, patch); err != nil {
log.Error(err, "unable to register finalizer")
return ctrl.Result{}, err
}
}

// If the object is under deletion, record the readiness, and remove our finalizer.
if !imageRepo.ObjectMeta.DeletionTimestamp.IsZero() {
r.recordReadinessMetric(ctx, &imageRepo)
controllerutil.RemoveFinalizer(&imageRepo, imagev1.ImageRepositoryFinalizer)
if err := r.Update(ctx, &imageRepo); err != nil {
return ctrl.Result{}, err
}
return ctrl.Result{}, nil
}

if imageRepo.Spec.Suspend {
msg := "ImageRepository is suspended, skipping reconciliation"
imagev1.SetImageRepositoryReadiness(
Expand Down

0 comments on commit 5c1b128

Please sign in to comment.