2022-12-15 09:34:44 +01:00
|
|
|
package admission
|
|
|
|
|
|
|
|
import (
|
2024-06-24 23:36:55 +07:00
|
|
|
kyvernov2 "github.com/kyverno/kyverno/api/kyverno/v2"
|
2022-12-15 09:34:44 +01:00
|
|
|
admissionv1 "k8s.io/api/admission/v1"
|
2024-02-02 22:34:50 +05:30
|
|
|
"k8s.io/apimachinery/pkg/util/json"
|
2022-12-15 09:34:44 +01:00
|
|
|
)
|
|
|
|
|
2024-06-24 23:36:55 +07:00
|
|
|
func UnmarshalPolicyException(raw []byte) (*kyvernov2.PolicyException, error) {
|
|
|
|
var exception *kyvernov2.PolicyException
|
2022-12-15 09:34:44 +01:00
|
|
|
if err := json.Unmarshal(raw, &exception); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return exception, nil
|
|
|
|
}
|
|
|
|
|
2024-06-24 23:36:55 +07:00
|
|
|
func GetPolicyExceptions(request admissionv1.AdmissionRequest) (*kyvernov2.PolicyException, *kyvernov2.PolicyException, error) {
|
|
|
|
var empty *kyvernov2.PolicyException
|
2022-12-15 09:34:44 +01:00
|
|
|
exception, err := UnmarshalPolicyException(request.Object.Raw)
|
|
|
|
if err != nil {
|
|
|
|
return exception, empty, err
|
|
|
|
}
|
|
|
|
if request.Operation == admissionv1.Update {
|
|
|
|
old, err := UnmarshalPolicyException(request.OldObject.Raw)
|
|
|
|
return exception, old, err
|
|
|
|
}
|
|
|
|
return exception, empty, nil
|
|
|
|
}
|