2023-01-31 15:30:40 +01:00
|
|
|
package api
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2023-05-05 17:35:47 -07:00
|
|
|
"fmt"
|
2023-01-31 15:30:40 +01:00
|
|
|
|
2023-02-08 14:19:56 +01:00
|
|
|
"github.com/go-logr/logr"
|
2023-01-31 15:30:40 +01:00
|
|
|
kyvernov1 "github.com/kyverno/kyverno/api/kyverno/v1"
|
|
|
|
enginecontext "github.com/kyverno/kyverno/pkg/engine/context"
|
2023-04-13 13:29:40 +02:00
|
|
|
"github.com/kyverno/kyverno/pkg/engine/jmespath"
|
2023-02-08 14:19:56 +01:00
|
|
|
"github.com/kyverno/kyverno/pkg/logging"
|
2023-02-08 06:55:03 +01:00
|
|
|
"github.com/kyverno/kyverno/pkg/registryclient"
|
2023-01-31 15:30:40 +01:00
|
|
|
)
|
|
|
|
|
2023-02-07 16:09:15 +01:00
|
|
|
// ContextLoaderFactory provides a ContextLoader given a policy context and rule name
|
2023-02-08 06:55:03 +01:00
|
|
|
type ContextLoaderFactory = func(policy kyvernov1.PolicyInterface, rule kyvernov1.Rule) ContextLoader
|
2023-02-02 11:58:34 +01:00
|
|
|
|
2023-02-07 16:09:15 +01:00
|
|
|
// ContextLoader abstracts the mechanics to load context entries in the underlying json context
|
2023-01-31 15:30:40 +01:00
|
|
|
type ContextLoader interface {
|
2023-02-08 06:55:03 +01:00
|
|
|
Load(
|
|
|
|
ctx context.Context,
|
2023-04-13 13:29:40 +02:00
|
|
|
jp jmespath.Interface,
|
2023-06-10 11:20:34 +02:00
|
|
|
client Client,
|
2023-02-08 06:55:03 +01:00
|
|
|
rclient registryclient.Client,
|
|
|
|
contextEntries []kyvernov1.ContextEntry,
|
|
|
|
jsonContext enginecontext.Interface,
|
|
|
|
) error
|
2023-01-31 15:30:40 +01:00
|
|
|
}
|
2023-02-08 14:19:56 +01:00
|
|
|
|
|
|
|
func DefaultContextLoaderFactory(
|
|
|
|
cmResolver ConfigmapResolver,
|
|
|
|
) ContextLoaderFactory {
|
|
|
|
return func(policy kyvernov1.PolicyInterface, rule kyvernov1.Rule) ContextLoader {
|
|
|
|
return &contextLoader{
|
|
|
|
logger: logging.WithName("DefaultContextLoaderFactory"),
|
|
|
|
cmResolver: cmResolver,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type contextLoader struct {
|
|
|
|
logger logr.Logger
|
|
|
|
cmResolver ConfigmapResolver
|
|
|
|
}
|
|
|
|
|
|
|
|
func (l *contextLoader) Load(
|
|
|
|
ctx context.Context,
|
2023-04-13 13:29:40 +02:00
|
|
|
jp jmespath.Interface,
|
2023-06-10 11:20:34 +02:00
|
|
|
client Client,
|
2023-02-08 14:19:56 +01:00
|
|
|
rclient registryclient.Client,
|
|
|
|
contextEntries []kyvernov1.ContextEntry,
|
|
|
|
jsonContext enginecontext.Interface,
|
|
|
|
) error {
|
|
|
|
for _, entry := range contextEntries {
|
2023-05-05 17:35:47 -07:00
|
|
|
deferredLoader := l.newDeferredLoader(ctx, jp, client, rclient, entry, jsonContext)
|
|
|
|
if deferredLoader == nil {
|
|
|
|
return fmt.Errorf("invalid context entry %s", entry.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
jsonContext.AddDeferredLoader(entry.Name, deferredLoader)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (l *contextLoader) newDeferredLoader(
|
|
|
|
ctx context.Context,
|
|
|
|
jp jmespath.Interface,
|
2023-06-10 11:20:34 +02:00
|
|
|
client Client,
|
2023-05-05 17:35:47 -07:00
|
|
|
rclient registryclient.Client,
|
|
|
|
entry kyvernov1.ContextEntry,
|
|
|
|
jsonContext enginecontext.Interface,
|
|
|
|
) enginecontext.DeferredLoader {
|
|
|
|
if entry.ConfigMap != nil {
|
|
|
|
return func() error {
|
2023-02-08 14:19:56 +01:00
|
|
|
if err := LoadConfigMap(ctx, l.logger, entry, jsonContext, l.cmResolver); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-05-05 17:35:47 -07:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
} else if entry.APICall != nil {
|
|
|
|
return func() error {
|
2023-04-13 13:29:40 +02:00
|
|
|
if err := LoadAPIData(ctx, jp, l.logger, entry, jsonContext, client); err != nil {
|
2023-02-08 14:19:56 +01:00
|
|
|
return err
|
|
|
|
}
|
2023-05-05 17:35:47 -07:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
} else if entry.ImageRegistry != nil {
|
|
|
|
return func() error {
|
2023-04-13 13:29:40 +02:00
|
|
|
if err := LoadImageData(ctx, jp, rclient, l.logger, entry, jsonContext); err != nil {
|
2023-02-08 14:19:56 +01:00
|
|
|
return err
|
|
|
|
}
|
2023-05-05 17:35:47 -07:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
} else if entry.Variable != nil {
|
|
|
|
return func() error {
|
2023-04-13 13:29:40 +02:00
|
|
|
if err := LoadVariable(l.logger, jp, entry, jsonContext); err != nil {
|
2023-02-08 14:19:56 +01:00
|
|
|
return err
|
|
|
|
}
|
2023-05-05 17:35:47 -07:00
|
|
|
return nil
|
2023-02-08 14:19:56 +01:00
|
|
|
}
|
|
|
|
}
|
2023-05-05 17:35:47 -07:00
|
|
|
|
2023-02-08 14:19:56 +01:00
|
|
|
return nil
|
|
|
|
}
|