2024-09-06 12:12:56 +05:30
|
|
|
package validation
|
|
|
|
|
|
|
|
import (
|
|
|
|
kyvernov1 "github.com/kyverno/kyverno/api/kyverno/v1"
|
|
|
|
kyvernov2 "github.com/kyverno/kyverno/api/kyverno/v2"
|
|
|
|
kyvernov2beta1 "github.com/kyverno/kyverno/api/kyverno/v2beta1"
|
|
|
|
"github.com/kyverno/kyverno/pkg/utils/match"
|
|
|
|
"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
|
|
|
|
)
|
|
|
|
|
|
|
|
func matchResource(resource unstructured.Unstructured, rule kyvernov1.Rule) bool {
|
|
|
|
if rule.MatchResources.All != nil || rule.MatchResources.Any != nil {
|
|
|
|
matched := match.CheckMatchesResources(
|
|
|
|
resource,
|
|
|
|
kyvernov2beta1.MatchResources{
|
|
|
|
Any: rule.MatchResources.Any,
|
|
|
|
All: rule.MatchResources.All,
|
|
|
|
},
|
|
|
|
make(map[string]string),
|
|
|
|
kyvernov2.RequestInfo{},
|
|
|
|
resource.GroupVersionKind(),
|
|
|
|
"",
|
|
|
|
)
|
|
|
|
if matched != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
2024-09-10 13:14:49 +02:00
|
|
|
if rule.ExcludeResources != nil {
|
|
|
|
if rule.ExcludeResources.All != nil || rule.ExcludeResources.Any != nil {
|
|
|
|
excluded := match.CheckMatchesResources(
|
|
|
|
resource,
|
|
|
|
kyvernov2beta1.MatchResources{
|
|
|
|
Any: rule.ExcludeResources.Any,
|
|
|
|
All: rule.ExcludeResources.All,
|
|
|
|
},
|
|
|
|
make(map[string]string),
|
|
|
|
kyvernov2.RequestInfo{},
|
|
|
|
resource.GroupVersionKind(),
|
|
|
|
"",
|
|
|
|
)
|
|
|
|
if excluded == nil {
|
|
|
|
return false
|
|
|
|
}
|
2024-09-06 12:12:56 +05:30
|
|
|
}
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|