-
Notifications
You must be signed in to change notification settings - Fork 18
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Feature] Extract context information from an array when passing to message #466
Comments
@kurktchiev do you have a sample policy I can work with ? |
Sure, if i want to add a container ARN to the message of the policy below, I do not have a way to apiVersion: json.kyverno.io/v1alpha1
kind: ValidatingPolicy
metadata:
name: validate-ecs-task-and-definition-memory-hard-limit
annotations:
policies.kyverno.io/title: Validate ECS Task Definition Memory Hard Limit
policies.kyverno.io/category: ECS Best Practices
policies.kyverno.io/severity: low
policies.kyverno.io/description: >-
This policy checks if Amazon Elastic Container Service
(ECS) task definitions and tasks have a set memory limit for its container definitions.
If a memory limit is not set for a container, it can consume excessive memory, potentially starving other containers running on the same host.
Therefore, it is crucial to enforce a hard memory limit on each container to prevent resource contention.
If a container exceeds its memory limit, it will be terminated by ECS.
spec:
rules:
- name: validate-ecs-task-memory-hard-limit
match:
all:
- source: aws.ecs
- detail-type: "ECS Task State Change"
- detail:
lastStatus: 'PROVISIONING'
assert:
all:
- message: From Lambda - Memory limit for containers in the task should be set in the container definitions of its task
check:
detail:
~.(containers):
(!memory): false |
Thanks, it doesn't work directly with the payload you posted in the issue description right ? |
It should if you modify the match and drop the source and detail-type |
The Can we use the simple example above to clarify what you want ? |
Ok so using the above as an example, lets say container 1 fails, but container 2 doesn't. What you provide above just dumps out all container ARNs, which is better than nothing but not useful as I still am not pointing the user to the specific failure. |
Or if we take the example further how can I pull out the Task ARN from the original JSON reference block, when a container ends up failing, considering that the Task list is an Array and the containers are an Array? |
Ok so you want to get the specific sub-element that caused the error right ? |
Yes I want to contextualize my errors |
This is a tricky one 🥵 Basically kyverno-json is all about projecting data and passing the projected data to children until we hit a leaf. I can imaging different solutions:
Example solution 1 (prolog): assert:
all:
- check:
detail:
~.(containers)/(join(' ', ['container needs memory', containerArn])): # expression behind the / is the prolog
(!memory): false Example solution 2 (small checks): checks:
container-needs-memory:
message: container needs memory {{ containerArn }}
assert:
(!memory): false
assert:
all:
- with:
list: containers
checks:
- container-needs-memory |
Or maybe just this: apiVersion: json.kyverno.io/v1alpha1
kind: ValidatingPolicy
metadata:
name: validate-ecs-task-and-definition-memory-hard-limit
annotations:
policies.kyverno.io/title: Validate ECS Task Definition Memory Hard Limit
policies.kyverno.io/category: ECS Best Practices
policies.kyverno.io/severity: low
policies.kyverno.io/description: >-
This policy checks if Amazon Elastic Container Service
(ECS) task definitions and tasks have a set memory limit for its container definitions.
If a memory limit is not set for a container, it can consume excessive memory, potentially starving other containers running on the same host.
Therefore, it is crucial to enforce a hard memory limit on each container to prevent resource contention.
If a container exceeds its memory limit, it will be terminated by ECS.
spec:
rules:
- name: validate-ecs-task-memory-hard-limit
match:
all:
- source: aws.ecs
- detail-type: "ECS Task State Change"
- detail:
lastStatus: 'PROVISIONING'
assert:
all:
- message: container needs memory {{ containerArn }}
with:
list: containers
check:
detail:
memory: {} |
how would that work if we are in a nested array situation? |
you can project as much as you want |
can you provide an example? maybe I am not understanding the vision here |
you rebuild the objects you need, leveraging jp flattening and projections features |
using things like: |
I've been playing around with the idea and have a working prototype: apiVersion: json.kyverno.io/v1alpha1
kind: ValidatingPolicy
metadata:
name: validate-ecs-task-and-definition-memory-hard-limit
annotations:
policies.kyverno.io/title: Validate ECS Task Definition Memory Hard Limit
policies.kyverno.io/category: ECS Best Practices
policies.kyverno.io/severity: low
policies.kyverno.io/description: >-
This policy checks if Amazon Elastic Container Service
(ECS) task definitions and tasks have a set memory limit for its container definitions.
If a memory limit is not set for a container, it can consume excessive memory, potentially starving other containers running on the same host.
Therefore, it is crucial to enforce a hard memory limit on each container to prevent resource contention.
If a container exceeds its memory limit, it will be terminated by ECS.
spec:
rules:
- name: validate-ecs-task-memory-hard-limit
assert:
all:
- with: >-
~.(tasks[].let $taskArn = taskArn in containers[].{taskArn:$taskArn,container:@})[]
check:
container:
memory: {}
message: >-
container {{ container.containerArn }}
in task {{ taskArn }}
needs memory WDYT ? |
Prototype here #471 |
Problem Statement
Currently, if I would like my user message to include information stored in an Array, there is no way to traverse the objects of the array and extract the field I am looking for to send back to the end user. I want my user message to include information stored in an Array, and there is no way to traverse the array's objects in that context
Solution Description
Lets say we have the following Reference JSON, I want to be able to grab
tasks[*].taskArn
ortasks[*].containers[*].containerArn
and provide it in mymessage
block as proper identification for my end users:Alternatives
No response
Additional Context
No response
Slack discussion
No response
Research
The text was updated successfully, but these errors were encountered: