2022-04-13 18:15:04 +05:30
|
|
|
package common
|
2022-01-18 20:23:48 +05:30
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
2022-05-19 18:06:56 +02:00
|
|
|
kyvernov1 "github.com/kyverno/kyverno/api/kyverno/v1"
|
2022-05-17 13:12:43 +02:00
|
|
|
kyvernov1beta1 "github.com/kyverno/kyverno/api/kyverno/v1beta1"
|
2022-09-07 06:01:43 +02:00
|
|
|
"github.com/kyverno/kyverno/pkg/client/clientset/versioned"
|
2022-05-19 18:06:56 +02:00
|
|
|
kyvernov1beta1listers "github.com/kyverno/kyverno/pkg/client/listers/kyverno/v1beta1"
|
2023-11-06 16:07:13 +05:30
|
|
|
"github.com/kyverno/kyverno/pkg/clients/dclient"
|
2022-01-18 20:23:48 +05:30
|
|
|
"github.com/kyverno/kyverno/pkg/config"
|
2022-10-02 20:45:03 +01:00
|
|
|
"github.com/kyverno/kyverno/pkg/logging"
|
2023-03-27 16:44:12 +08:00
|
|
|
errors "github.com/pkg/errors"
|
2022-01-18 20:23:48 +05:30
|
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
2023-03-01 11:48:18 +08:00
|
|
|
"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
|
2022-01-18 20:23:48 +05:30
|
|
|
)
|
|
|
|
|
2023-03-27 16:44:12 +08:00
|
|
|
func UpdateStatus(client versioned.Interface, urLister kyvernov1beta1listers.UpdateRequestNamespaceLister, name string, state kyvernov1beta1.UpdateRequestState, message string, genResources []kyvernov1.ResourceSpec) (*kyvernov1beta1.UpdateRequest, error) {
|
|
|
|
var latest *kyvernov1beta1.UpdateRequest
|
|
|
|
ur, err := client.KyvernoV1beta1().UpdateRequests(config.KyvernoNamespace()).Get(context.TODO(), name, metav1.GetOptions{})
|
2022-05-19 18:06:56 +02:00
|
|
|
if err != nil {
|
2023-03-27 16:44:12 +08:00
|
|
|
return ur, errors.Wrapf(err, "failed to fetch update request")
|
|
|
|
}
|
|
|
|
latest = ur.DeepCopy()
|
|
|
|
latest.Status.State = state
|
|
|
|
latest.Status.Message = message
|
|
|
|
if genResources != nil {
|
|
|
|
latest.Status.GeneratedResources = genResources
|
2022-01-18 20:23:48 +05:30
|
|
|
}
|
2022-05-19 18:06:56 +02:00
|
|
|
|
2023-12-19 14:25:12 +08:00
|
|
|
if state == kyvernov1beta1.Failed {
|
|
|
|
if latest, err = retryOrDeleteOnFailure(client, latest, 3); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
}
|
2023-03-27 16:44:12 +08:00
|
|
|
new, err := client.KyvernoV1beta1().UpdateRequests(config.KyvernoNamespace()).UpdateStatus(context.TODO(), latest, metav1.UpdateOptions{})
|
2022-01-18 20:23:48 +05:30
|
|
|
if err != nil {
|
2023-03-27 16:44:12 +08:00
|
|
|
return ur, errors.Wrapf(err, "failed to update ur status to %s", string(state))
|
2022-01-18 20:23:48 +05:30
|
|
|
}
|
2023-03-27 16:44:12 +08:00
|
|
|
|
|
|
|
logging.V(3).Info("updated update request status", "name", name, "status", string(state), "state", new.Status.State)
|
|
|
|
return ur, nil
|
2022-01-18 20:23:48 +05:30
|
|
|
}
|
2023-02-22 18:49:09 +08:00
|
|
|
|
|
|
|
func PolicyKey(namespace, name string) string {
|
|
|
|
if namespace != "" {
|
|
|
|
return namespace + "/" + name
|
|
|
|
}
|
|
|
|
return name
|
|
|
|
}
|
2023-03-01 11:48:18 +08:00
|
|
|
|
|
|
|
func ResourceSpecFromUnstructured(obj unstructured.Unstructured) kyvernov1.ResourceSpec {
|
|
|
|
return kyvernov1.ResourceSpec{
|
|
|
|
APIVersion: obj.GetAPIVersion(),
|
|
|
|
Kind: obj.GetKind(),
|
|
|
|
Namespace: obj.GetNamespace(),
|
|
|
|
Name: obj.GetName(),
|
2023-11-06 16:07:13 +05:30
|
|
|
UID: obj.GetUID(),
|
2023-03-01 11:48:18 +08:00
|
|
|
}
|
|
|
|
}
|
2023-08-30 14:24:57 +02:00
|
|
|
|
2023-12-19 14:25:12 +08:00
|
|
|
func retryOrDeleteOnFailure(kyvernoClient versioned.Interface, ur *kyvernov1beta1.UpdateRequest, limit int) (latest *kyvernov1beta1.UpdateRequest, err error) {
|
|
|
|
if ur.Status.RetryCount > limit {
|
2023-08-30 14:24:57 +02:00
|
|
|
err = kyvernoClient.KyvernoV1beta1().UpdateRequests(config.KyvernoNamespace()).Delete(context.TODO(), ur.GetName(), metav1.DeleteOptions{})
|
|
|
|
if err != nil {
|
2023-12-19 14:25:12 +08:00
|
|
|
return nil, errors.Wrapf(err, "exceeds retry limit, failed to delete the UR: %s, retry: %v, resourceVersion: %s", ur.Name, ur.Status.RetryCount, ur.GetResourceVersion())
|
2023-08-30 14:24:57 +02:00
|
|
|
}
|
|
|
|
} else {
|
2023-12-19 14:25:12 +08:00
|
|
|
ur.Status.RetryCount++
|
2023-08-30 14:24:57 +02:00
|
|
|
}
|
2023-12-19 14:25:12 +08:00
|
|
|
|
|
|
|
return ur, nil
|
2023-08-30 14:24:57 +02:00
|
|
|
}
|
2023-11-06 16:07:13 +05:30
|
|
|
|
|
|
|
func FindDownstream(client dclient.Interface, apiVersion, kind string, labels map[string]string) (*unstructured.UnstructuredList, error) {
|
|
|
|
selector := &metav1.LabelSelector{MatchLabels: labels}
|
|
|
|
return client.ListResource(context.TODO(), apiVersion, kind, "", selector)
|
|
|
|
}
|