2020-01-07 10:33:28 -08:00
|
|
|
package cleanup
|
|
|
|
|
|
|
|
import (
|
2020-03-17 16:25:34 -07:00
|
|
|
"github.com/go-logr/logr"
|
2022-05-17 13:12:43 +02:00
|
|
|
kyvernov1beta1 "github.com/kyverno/kyverno/api/kyverno/v1beta1"
|
2022-05-18 06:02:31 +02:00
|
|
|
"github.com/kyverno/kyverno/pkg/dclient"
|
2020-02-10 12:44:20 -08:00
|
|
|
apierrors "k8s.io/apimachinery/pkg/api/errors"
|
2020-01-07 10:33:28 -08:00
|
|
|
)
|
|
|
|
|
2022-05-17 13:12:43 +02:00
|
|
|
func ownerResourceExists(log logr.Logger, client dclient.Interface, ur kyvernov1beta1.UpdateRequest) bool {
|
2022-04-29 19:05:49 +08:00
|
|
|
_, err := client.GetResource("", ur.Spec.Resource.Kind, ur.Spec.Resource.Namespace, ur.Spec.Resource.Name)
|
2020-02-10 12:44:20 -08:00
|
|
|
// trigger resources has been deleted
|
|
|
|
if apierrors.IsNotFound(err) {
|
2020-01-07 10:33:28 -08:00
|
|
|
return false
|
|
|
|
}
|
2020-02-10 12:44:20 -08:00
|
|
|
if err != nil {
|
2022-04-29 19:05:49 +08:00
|
|
|
log.Error(err, "failed to get resource", "genKind", ur.Spec.Resource.Kind, "genNamespace", ur.Spec.Resource.Namespace, "genName", ur.Spec.Resource.Name)
|
2020-02-10 12:44:20 -08:00
|
|
|
}
|
2020-12-22 11:07:31 -08:00
|
|
|
// if there was an error while querying the resources we don't delete the generated resources
|
2020-02-10 12:44:20 -08:00
|
|
|
// but expect the deletion in next reconciliation loop
|
2020-01-07 10:33:28 -08:00
|
|
|
return true
|
|
|
|
}
|
2020-01-07 15:13:57 -08:00
|
|
|
|
2022-05-17 13:12:43 +02:00
|
|
|
func deleteGeneratedResources(log logr.Logger, client dclient.Interface, ur kyvernov1beta1.UpdateRequest) error {
|
2022-04-29 19:05:49 +08:00
|
|
|
for _, genResource := range ur.Status.GeneratedResources {
|
2020-08-07 09:47:33 +05:30
|
|
|
err := client.DeleteResource("", genResource.Kind, genResource.Namespace, genResource.Name, false)
|
2020-11-20 14:14:59 -08:00
|
|
|
if err != nil && !apierrors.IsNotFound(err) {
|
2020-01-07 15:13:57 -08:00
|
|
|
return err
|
|
|
|
}
|
2020-01-24 12:05:53 -08:00
|
|
|
|
2022-04-29 19:05:49 +08:00
|
|
|
log.V(3).Info("generated resource deleted", "genKind", ur.Spec.Resource.Kind, "genNamespace", ur.Spec.Resource.Namespace, "genName", ur.Spec.Resource.Name)
|
2020-01-07 15:13:57 -08:00
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|