mirror of
https://github.com/kyverno/kyverno.git
synced 2025-03-31 03:45:17 +00:00
added: a pre-flight validation check for ensuring that only 'any'/'all' fields are present under conditions (#1791)
Signed-off-by: Yashvardhan Kukreja <yash.kukreja.98@gmail.com>
This commit is contained in:
parent
6a0305674a
commit
69c3418ca9
1 changed files with 26 additions and 2 deletions
|
@ -205,6 +205,26 @@ func SliceContains(slice []string, values ...string) bool {
|
|||
// and converts it into []kyverno.Condition or kyverno.AnyAllConditions according to its content.
|
||||
// it also helps in validating the condtions as it returns an error when the conditions are provided wrongfully by the user.
|
||||
func ApiextensionsJsonToKyvernoConditions(original apiextensions.JSON) (interface{}, error) {
|
||||
path := "preconditions/validate.deny.conditions"
|
||||
|
||||
// checks for the existence any other field apart from 'any'/'all' under preconditions/validate.deny.conditions
|
||||
unknownFieldChecker := func(jsonByteArr []byte, path string) error {
|
||||
allowedKeys := map[string]bool{
|
||||
"any": true,
|
||||
"all": true,
|
||||
}
|
||||
var jsonDecoded map[string]interface{}
|
||||
if err := json.Unmarshal(jsonByteArr, &jsonDecoded); err != nil {
|
||||
return fmt.Errorf("error occurred while checking for unknown fields under %s: %+v", path, err)
|
||||
}
|
||||
for k := range jsonDecoded {
|
||||
if !allowedKeys[k] {
|
||||
return fmt.Errorf("unknown field '%s' found under %s", k, path)
|
||||
}
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
// marshalling the abstract apiextensions.JSON back to JSON form
|
||||
jsonByte, err := json.Marshal(original)
|
||||
|
||||
|
@ -215,8 +235,12 @@ func ApiextensionsJsonToKyvernoConditions(original apiextensions.JSON) (interfac
|
|||
|
||||
var kyvernoAnyAllConditions kyverno.AnyAllConditions
|
||||
if err = json.Unmarshal(jsonByte, &kyvernoAnyAllConditions); err == nil {
|
||||
// checking if unknown fields exist or not
|
||||
err = unknownFieldChecker(jsonByte, path)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("error occurred while parsing %s: %+v", path, err)
|
||||
}
|
||||
return kyvernoAnyAllConditions, nil
|
||||
}
|
||||
|
||||
return nil, fmt.Errorf("conditions filled wrongfully")
|
||||
return nil, fmt.Errorf("error occurred while parsing %s: %+v", path, err)
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue