1
0
Fork 0
mirror of https://github.com/kyverno/kyverno.git synced 2025-03-07 00:17:13 +00:00
kyverno/pkg/imageverification/match/match.go

83 lines
1.6 KiB
Go
Raw Normal View History

package match
import (
"fmt"
"log"
"github.com/gobwas/glob"
"github.com/google/cel-go/cel"
"github.com/kyverno/kyverno/api/policies.kyverno.io/v1alpha1"
"github.com/kyverno/kyverno/pkg/cel/utils"
)
type CompiledMatch struct {
g glob.Glob
e cel.Program
}
func (c *CompiledMatch) Match(image string) (bool, error) {
if c.g != nil {
return c.g.Match(image), nil
} else if c.e != nil {
out, _, err := c.e.Eval(map[string]any{
"ref": image,
})
if err != nil {
log.Fatalf("runtime error: %s\n", err)
}
result, err := utils.ConvertToNative[bool](out)
if err != nil {
return false, err
}
return result, nil
} else {
return false, fmt.Errorf("invalid match block")
}
}
func Match(c []*CompiledMatch, image string) (bool, error) {
for _, v := range c {
if matched, err := v.Match(image); err != nil {
return false, err
} else if matched {
return true, nil
}
}
return false, nil
}
func CompileMatches(matches []v1alpha1.ImageRule) ([]*CompiledMatch, error) {
compiledMatches := make([]*CompiledMatch, 0, len(matches))
e, err := cel.NewEnv(
cel.Variable("ref", cel.StringType),
)
if err != nil {
return nil, err
}
for _, m := range matches {
c := &CompiledMatch{}
if m.Glob != "" {
g, err := glob.Compile(m.Glob)
if err != nil {
return nil, err
}
c.g = g
} else if m.CELExpression != "" {
ast, iss := e.Compile(m.CELExpression)
if iss.Err() != nil {
return nil, iss.Err()
}
prg, err := e.Program(ast)
if err != nil {
return nil, err
}
c.e = prg
}
compiledMatches = append(compiledMatches, c)
}
return compiledMatches, nil
}