2019-08-23 18:34:23 -07:00
|
|
|
package policy
|
|
|
|
|
2022-05-09 12:43:11 +05:30
|
|
|
import (
|
2022-05-17 13:12:43 +02:00
|
|
|
kyvernov1 "github.com/kyverno/kyverno/api/kyverno/v1"
|
2024-08-29 16:09:30 +03:00
|
|
|
"github.com/kyverno/kyverno/ext/wildcard"
|
2022-05-09 12:43:11 +05:30
|
|
|
"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
|
|
|
|
)
|
2020-06-25 09:52:27 -07:00
|
|
|
|
2024-05-20 19:40:53 +07:00
|
|
|
func resourceMatches(match kyvernov1.ResourceDescription, res unstructured.Unstructured, isNamespacedPolicy bool) bool {
|
2024-08-29 16:09:30 +03:00
|
|
|
if match.Name != "" && !wildcard.Match(match.Name, res.GetName()) {
|
2024-05-20 19:40:53 +07:00
|
|
|
return false
|
2022-05-09 12:43:11 +05:30
|
|
|
}
|
2024-08-29 16:09:30 +03:00
|
|
|
|
|
|
|
if len(match.Names) > 0 {
|
|
|
|
isMatch := false
|
|
|
|
for _, name := range match.Names {
|
|
|
|
if wildcard.Match(name, res.GetName()) {
|
|
|
|
isMatch = true
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if !isMatch {
|
|
|
|
return false
|
|
|
|
}
|
2022-05-09 12:43:11 +05:30
|
|
|
}
|
2024-08-29 16:09:30 +03:00
|
|
|
|
2024-05-20 19:40:53 +07:00
|
|
|
if !isNamespacedPolicy && len(match.Namespaces) > 0 && !contains(match.Namespaces, res.GetNamespace()) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return true
|
2022-05-09 12:43:11 +05:30
|
|
|
}
|
|
|
|
|
2024-05-20 19:40:53 +07:00
|
|
|
func contains(slice []string, item string) bool {
|
|
|
|
for _, s := range slice {
|
|
|
|
if s == item {
|
|
|
|
return true
|
|
|
|
}
|
2022-05-09 12:43:11 +05:30
|
|
|
}
|
2024-05-20 19:40:53 +07:00
|
|
|
return false
|
2022-05-09 12:43:11 +05:30
|
|
|
}
|
2023-06-14 21:52:27 +08:00
|
|
|
|
|
|
|
func castPolicy(p interface{}) kyvernov1.PolicyInterface {
|
|
|
|
var policy kyvernov1.PolicyInterface
|
|
|
|
switch obj := p.(type) {
|
|
|
|
case *kyvernov1.ClusterPolicy:
|
|
|
|
policy = obj
|
|
|
|
case *kyvernov1.Policy:
|
|
|
|
policy = obj
|
|
|
|
}
|
|
|
|
return policy
|
|
|
|
}
|
2024-08-14 01:14:06 +08:00
|
|
|
|
|
|
|
func policyKey(policy kyvernov1.PolicyInterface) string {
|
|
|
|
var policyNameNamespaceKey string
|
|
|
|
|
|
|
|
if policy.IsNamespaced() {
|
|
|
|
policyNameNamespaceKey = policy.GetNamespace() + "/" + policy.GetName()
|
|
|
|
} else {
|
|
|
|
policyNameNamespaceKey = policy.GetName()
|
|
|
|
}
|
|
|
|
return policyNameNamespaceKey
|
|
|
|
}
|