From 5fe3ef2af6351f41f888e857e109495d8503ccd5 Mon Sep 17 00:00:00 2001 From: Paul Laffitte Date: Tue, 30 Jul 2024 15:14:50 +0200 Subject: [PATCH] fix: expired cachedimages with pull errors were not deleted --- .../controller/kuik/cachedimage_controller.go | 35 +++++++++---------- 1 file changed, 17 insertions(+), 18 deletions(-) diff --git a/internal/controller/kuik/cachedimage_controller.go b/internal/controller/kuik/cachedimage_controller.go index 3f82cf9d..39767040 100644 --- a/internal/controller/kuik/cachedimage_controller.go +++ b/internal/controller/kuik/cachedimage_controller.go @@ -107,7 +107,6 @@ func (r *CachedImageReconciler) Reconcile(ctx context.Context, req ctrl.Request) repository.Spec.Name = repositoryName return nil }) - if err != nil { return ctrl.Result{}, err } @@ -219,6 +218,23 @@ func (r *CachedImageReconciler) Reconcile(ctx context.Context, req ctrl.Request) return ctrl.Result{}, err } + // Delete expired CachedImage and schedule deletion for expiring ones + if !expiresAt.IsZero() { + if time.Now().After(expiresAt.Time) { + log.Info("cachedimage expired, deleting it", "now", time.Now(), "expiresAt", expiresAt) + r.Recorder.Eventf(&cachedImage, "Normal", "Expiring", "Image %s has expired, deleting it", cachedImage.Spec.SourceImage) + err := r.Delete(ctx, &cachedImage) + if err != nil { + r.Recorder.Eventf(&cachedImage, "Warning", "ExpiringFailed", "Image %s could not expire: %s", cachedImage.Spec.SourceImage, err) + return ctrl.Result{}, err + } + r.Recorder.Eventf(&cachedImage, "Normal", "Expired", "Image %s successfully expired", cachedImage.Spec.SourceImage) + return ctrl.Result{}, nil + } else { + return ctrl.Result{RequeueAfter: time.Until(expiresAt.Time)}, nil + } + } + // Adding image to registry putImageInCache := true if isCached && !forceUpdate { @@ -247,23 +263,6 @@ func (r *CachedImageReconciler) Reconcile(ctx context.Context, req ctrl.Request) return ctrl.Result{}, err } - // Delete expired CachedImage and schedule deletion for expiring ones - if !expiresAt.IsZero() { - if time.Now().After(expiresAt.Time) { - log.Info("cachedimage expired, deleting it", "now", time.Now(), "expiresAt", expiresAt) - r.Recorder.Eventf(&cachedImage, "Normal", "Expiring", "Image %s has expired, deleting it", cachedImage.Spec.SourceImage) - err := r.Delete(ctx, &cachedImage) - if err != nil { - r.Recorder.Eventf(&cachedImage, "Warning", "ExpiringFailed", "Image %s could not expire: %s", cachedImage.Spec.SourceImage, err) - return ctrl.Result{}, err - } - r.Recorder.Eventf(&cachedImage, "Normal", "Expired", "Image %s successfully expired", cachedImage.Spec.SourceImage) - return ctrl.Result{}, nil - } else { - return ctrl.Result{RequeueAfter: time.Until(expiresAt.Time)}, nil - } - } - log.Info("cachedimage reconciled") return ctrl.Result{}, nil }