mirror of
https://github.com/kyverno/kyverno.git
synced 2025-03-06 16:06:56 +00:00
* refactor: remove a couple of old util funcs Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com> * refactor: policy controller package Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com> * refactor Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com> Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>
95 lines
2.5 KiB
Go
95 lines
2.5 KiB
Go
package policy
|
|
|
|
import (
|
|
"errors"
|
|
"sync"
|
|
"time"
|
|
)
|
|
|
|
type ResourceManager interface {
|
|
ProcessResource(policy, pv, kind, ns, name, rv string) bool
|
|
// TODO removeResource(kind, ns, name string) error
|
|
RegisterResource(policy, pv, kind, ns, name, rv string)
|
|
RegisterScope(kind string, namespaced bool)
|
|
GetScope(kind string) (bool, error)
|
|
Drop()
|
|
}
|
|
|
|
// resourceManager stores the details on already processed resources for caching
|
|
type resourceManager struct {
|
|
// we drop and re-build the cache
|
|
// based on the memory consumer of by the map
|
|
scope map[string]bool
|
|
data map[string]interface{}
|
|
mux sync.RWMutex
|
|
time time.Time
|
|
rebuildTime int64 // after how many seconds should we rebuild the cache
|
|
}
|
|
|
|
// resourceManager returns a new ResourceManager
|
|
func NewResourceManager(rebuildTime int64) ResourceManager {
|
|
return &resourceManager{
|
|
scope: make(map[string]bool),
|
|
data: make(map[string]interface{}),
|
|
time: time.Now(),
|
|
rebuildTime: rebuildTime,
|
|
}
|
|
}
|
|
|
|
// Drop drop the cache after every rebuild interval mins
|
|
func (rm *resourceManager) Drop() {
|
|
timeSince := time.Since(rm.time)
|
|
if timeSince > time.Duration(rm.rebuildTime)*time.Second {
|
|
rm.mux.Lock()
|
|
defer rm.mux.Unlock()
|
|
rm.data = map[string]interface{}{}
|
|
rm.time = time.Now()
|
|
}
|
|
}
|
|
|
|
var empty struct{}
|
|
|
|
// RegisterResource stores if the policy is processed on this resource version
|
|
func (rm *resourceManager) RegisterResource(policy, pv, kind, ns, name, rv string) {
|
|
rm.mux.Lock()
|
|
defer rm.mux.Unlock()
|
|
// add the resource
|
|
key := buildKey(policy, pv, kind, ns, name, rv)
|
|
rm.data[key] = empty
|
|
}
|
|
|
|
// ProcessResource returns true if the policy was not applied on the resource
|
|
func (rm *resourceManager) ProcessResource(policy, pv, kind, ns, name, rv string) bool {
|
|
rm.mux.RLock()
|
|
defer rm.mux.RUnlock()
|
|
|
|
key := buildKey(policy, pv, kind, ns, name, rv)
|
|
_, ok := rm.data[key]
|
|
return !ok
|
|
}
|
|
|
|
// RegisterScope stores the scope of the given kind
|
|
func (rm *resourceManager) RegisterScope(kind string, namespaced bool) {
|
|
rm.mux.Lock()
|
|
defer rm.mux.Unlock()
|
|
|
|
rm.scope[kind] = namespaced
|
|
}
|
|
|
|
// GetScope gets the scope of the given kind
|
|
// return error if kind is not registered
|
|
func (rm *resourceManager) GetScope(kind string) (bool, error) {
|
|
rm.mux.RLock()
|
|
defer rm.mux.RUnlock()
|
|
|
|
namespaced, ok := rm.scope[kind]
|
|
if !ok {
|
|
return false, errors.New("NotFound")
|
|
}
|
|
|
|
return namespaced, nil
|
|
}
|
|
|
|
func buildKey(policy, pv, kind, ns, name, rv string) string {
|
|
return policy + "/" + pv + "/" + kind + "/" + ns + "/" + name + "/" + rv
|
|
}
|