mirror of
https://github.com/kyverno/kyverno.git
synced 2024-12-14 11:57:48 +00:00
1e30aacbd9
Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>
82 lines
2.2 KiB
Go
82 lines
2.2 KiB
Go
package metrics
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
kyvernov1 "github.com/kyverno/kyverno/api/kyverno/v1"
|
|
engineapi "github.com/kyverno/kyverno/pkg/engine/api"
|
|
datautils "github.com/kyverno/kyverno/pkg/utils/data"
|
|
)
|
|
|
|
func ParsePolicyValidationMode(validationFailureAction kyvernov1.ValidationFailureAction) (PolicyValidationMode, error) {
|
|
if validationFailureAction.Enforce() {
|
|
return Enforce, nil
|
|
}
|
|
return Audit, nil
|
|
}
|
|
|
|
func ParsePolicyBackgroundMode(policy kyvernov1.PolicyInterface) PolicyBackgroundMode {
|
|
if policy.BackgroundProcessingEnabled() {
|
|
return BackgroundTrue
|
|
}
|
|
return BackgroundFalse
|
|
}
|
|
|
|
func ParseRuleType(rule kyvernov1.Rule) RuleType {
|
|
if !datautils.DeepEqual(rule.Validation, kyvernov1.Validation{}) {
|
|
return Validate
|
|
}
|
|
if !datautils.DeepEqual(rule.Mutation, kyvernov1.Mutation{}) {
|
|
return Mutate
|
|
}
|
|
if !datautils.DeepEqual(rule.Generation, kyvernov1.Generation{}) {
|
|
return Generate
|
|
}
|
|
if len(rule.VerifyImages) > 0 {
|
|
return ImageVerify
|
|
}
|
|
return EmptyRuleType
|
|
}
|
|
|
|
func ParseResourceRequestOperation(requestOperationStr string) (ResourceRequestOperation, error) {
|
|
switch requestOperationStr {
|
|
case "CREATE":
|
|
return ResourceCreated, nil
|
|
case "UPDATE":
|
|
return ResourceUpdated, nil
|
|
case "DELETE":
|
|
return ResourceDeleted, nil
|
|
case "CONNECT":
|
|
return ResourceConnected, nil
|
|
default:
|
|
return "", fmt.Errorf("unknown request operation made by resource: %s. Allowed requests: 'CREATE', 'UPDATE', 'DELETE', 'CONNECT'", requestOperationStr)
|
|
}
|
|
}
|
|
|
|
func ParseRuleTypeFromEngineRuleResponse(rule engineapi.RuleResponse) RuleType {
|
|
switch rule.Type {
|
|
case "Validation":
|
|
return Validate
|
|
case "Mutation":
|
|
return Mutate
|
|
case "Generation":
|
|
return Generate
|
|
case "ImageVerify":
|
|
return ImageVerify
|
|
default:
|
|
return EmptyRuleType
|
|
}
|
|
}
|
|
|
|
func GetPolicyInfos(policy kyvernov1.PolicyInterface) (string, string, PolicyType, PolicyBackgroundMode, PolicyValidationMode, error) {
|
|
name := policy.GetName()
|
|
namespace := ""
|
|
policyType := Cluster
|
|
if policy.IsNamespaced() {
|
|
namespace = policy.GetNamespace()
|
|
policyType = Namespaced
|
|
}
|
|
backgroundMode := ParsePolicyBackgroundMode(policy)
|
|
validationMode, err := ParsePolicyValidationMode(policy.GetSpec().ValidationFailureAction)
|
|
return name, namespace, policyType, backgroundMode, validationMode, err
|
|
}
|