2022-11-16 18:41:33 +05:30
|
|
|
package admission
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
kyvernov1 "github.com/kyverno/kyverno/api/kyverno/v1"
|
|
|
|
admissionv1 "k8s.io/api/admission/v1"
|
2024-02-02 22:34:50 +05:30
|
|
|
"k8s.io/apimachinery/pkg/util/json"
|
2022-11-16 18:41:33 +05:30
|
|
|
)
|
|
|
|
|
|
|
|
func UnmarshalPolicy(kind string, raw []byte) (kyvernov1.PolicyInterface, error) {
|
|
|
|
if kind == "ClusterPolicy" {
|
|
|
|
var policy *kyvernov1.ClusterPolicy
|
|
|
|
if err := json.Unmarshal(raw, &policy); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return policy, nil
|
|
|
|
} else if kind == "Policy" {
|
|
|
|
var policy *kyvernov1.Policy
|
|
|
|
if err := json.Unmarshal(raw, &policy); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return policy, nil
|
|
|
|
}
|
|
|
|
return nil, fmt.Errorf("admission request does not contain a policy")
|
|
|
|
}
|
|
|
|
|
2023-04-04 07:11:18 +02:00
|
|
|
func GetPolicy(request admissionv1.AdmissionRequest) (kyvernov1.PolicyInterface, error) {
|
2022-11-16 18:41:33 +05:30
|
|
|
return UnmarshalPolicy(request.Kind.Kind, request.Object.Raw)
|
|
|
|
}
|
|
|
|
|
2023-04-04 07:11:18 +02:00
|
|
|
func GetPolicies(request admissionv1.AdmissionRequest) (kyvernov1.PolicyInterface, kyvernov1.PolicyInterface, error) {
|
2022-11-16 18:41:33 +05:30
|
|
|
policy, err := UnmarshalPolicy(request.Kind.Kind, request.Object.Raw)
|
|
|
|
if err != nil {
|
|
|
|
return policy, nil, err
|
|
|
|
}
|
|
|
|
if request.Operation == admissionv1.Update {
|
|
|
|
oldPolicy, err := UnmarshalPolicy(request.Kind.Kind, request.OldObject.Raw)
|
|
|
|
return policy, oldPolicy, err
|
|
|
|
}
|
|
|
|
return policy, nil, nil
|
|
|
|
}
|