reuse the evaluator across calls
This commit is contained in:
parent
c4cb2ee824
commit
ae697cd9c8
27
migrator.go
27
migrator.go
@ -17,27 +17,30 @@ limitations under the License.
|
||||
package pspmigrator
|
||||
|
||||
import (
|
||||
"log"
|
||||
|
||||
v1 "k8s.io/api/core/v1"
|
||||
|
||||
"k8s.io/pod-security-admission/api"
|
||||
psaapi "k8s.io/pod-security-admission/api"
|
||||
"k8s.io/pod-security-admission/policy"
|
||||
)
|
||||
|
||||
var evaluator policy.Evaluator
|
||||
|
||||
func init() {
|
||||
var err error
|
||||
evaluator, err = policy.NewEvaluator(policy.DefaultChecks())
|
||||
if err != nil {
|
||||
log.Println("Error initializing evaluator:", err.Error())
|
||||
}
|
||||
}
|
||||
|
||||
func SuggestedPodSecurityStandard(pod *v1.Pod) (psaapi.Level, error) {
|
||||
evaluator, err := policy.NewEvaluator(policy.DefaultChecks())
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
apiVersion, err := api.ParseVersion("latest")
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
for _, level := range []string{"restricted", "baseline"} {
|
||||
apiLevel, err := psaapi.ParseLevel(level)
|
||||
apiVersion, err := psaapi.ParseVersion("latest")
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
for _, apiLevel := range []psaapi.Level{psaapi.LevelRestricted, psaapi.LevelBaseline} {
|
||||
result := policy.AggregateCheckResults(evaluator.EvaluatePod(
|
||||
psaapi.LevelVersion{Level: apiLevel, Version: apiVersion}, &pod.ObjectMeta, &pod.Spec))
|
||||
|
||||
@ -45,5 +48,5 @@ func SuggestedPodSecurityStandard(pod *v1.Pod) (psaapi.Level, error) {
|
||||
return apiLevel, nil
|
||||
}
|
||||
}
|
||||
return api.LevelPrivileged, nil
|
||||
return psaapi.LevelPrivileged, nil
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user