diff --git a/keps/sig-api-machinery/3488-cel-admission-control/README.md b/keps/sig-api-machinery/3488-cel-admission-control/README.md index 9937ffddf53..b8b09603b28 100644 --- a/keps/sig-api-machinery/3488-cel-admission-control/README.md +++ b/keps/sig-api-machinery/3488-cel-admission-control/README.md @@ -407,7 +407,7 @@ spec: validations: - name: max-replicas expression: "object.spec.replicas <= params.maxReplicas" - messageExpression: "'object.spec.replicas must be no greater than ' + string(params.maxReplicas)" + messageExpression: "'object.spec.replicas must be no greater than %d'.format([params.maxReplicas])" reason: Invalid # ...other rule related fields here... ``` @@ -850,6 +850,11 @@ Policy definitions: - Each validation may define a message: - `message` - plain string message - `messageExpression: ""` (mutually exclusive with `message`) + - As part of [the KEP update to add expression composition](https://github.com/kubernetes/enhancements/pull/3669/files), + expressions defined under `variables` will be accessible from `messageExpression` + - `messageExpression` is a CEL expression and thus factors into the runtime cost limit. + If the runtime cost limit is exceeded during `messageExpression` execution, then this is logged. + Whether or not the action is admitted after that depends upon failure policy. - If `message` and `messageExpression` are absent, `expression` and `name` will be included in the failure message - If `messageExpression` results in an error: `expression` and `name` will be @@ -871,7 +876,7 @@ spec: validations: - expression: "self.name.startsWith('xyz-')" name: name-prefix - messageExpression: "self.name + ' must start with xyz-'" + message: "self.name must start with xyz-" reason: Unauthorized - expression: "self.name.contains('bad')" name: bad-name @@ -880,7 +885,7 @@ spec: reason: Invalid - expression: "self.name.contains('suspicious')" name: suspicious-name - messageExpression: "self.name + ' contains suspicious'" + message: "'self.name contains suspicious'" code: 400 reason: Invalid ``` @@ -1223,7 +1228,10 @@ Plan: To consider: - labelSelector evaluation functions or other match evaluator functions ([original comment thread](https://github.com/kubernetes/enhancements/pull/3492#discussion_r981747317)) -- `string.format(string, list(dyn))` to make `messageExpression` more convenient. + +To implement: + +- `string.format` into CEL upstream ([tracking PR](https://github.com/google/cel-go/pull/617)) (TODO @DangerOnTheRanger: add tracking cel-go issue once available) #### Audit Annotations @@ -2872,7 +2880,7 @@ For example, to validate all containers: validations: - scope: "spec.containers[*]" expression: "scope.name.startsWith('xyz-')" - messageExpression: "scope.name + 'does not start with \'xyz\''" + message: "scope.name does not start with 'xyz'" ``` To make it possible to access the path information in the scope, we can offer a @@ -2886,7 +2894,7 @@ spec.x[xKey].y[yIndex].field validations: - scope: "x[xKey].y[yIndex].field" expression: "scope.startsWith('xyz-')" - messageExpression: "scopePath.xKey + ', ' + scopePath.yIndex + ': some problem'" + messageExpression: "'%s, %d: some problem'.format([scopePath.xKey, scopePath.yIndex])" ``` Prior art: @@ -2907,7 +2915,7 @@ Note: We considered extending to a list of scopes, e.g.: validations: - scopes: ["spec.containers[*]", "initContainers[*]", "spec.ephemeralContainers[*]"] expression: "scope.name.startsWith('xyz-')" - messageExpression: "scope.name + ' does not start with \'xyz\''" + message: "scope.name does not start with 'xyz'" ``` But feedback was this is signficantly more difficult to understand.