Skip to content
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

No warning displayed on kubectl apply with enforcementAction warn #3302

Open
globalundo opened this issue Mar 12, 2024 · 7 comments
Open

No warning displayed on kubectl apply with enforcementAction warn #3302

globalundo opened this issue Mar 12, 2024 · 7 comments
Labels
bug Something isn't working stale

Comments

@globalundo
Copy link

What steps did you take and what happened:

  • OPA Gatekeeper is installed in the k8s cluster
  • A constraint has been created
  • On enforcementAction: deny, resource admission is denied on constraint violation, with a proper message on kubectl apply
  • On enforcementAction: warn, no warning message is displayed on kubectl apply, even if resources violates the constraint/

What did you expect to happen:
A warning message would be printed according to the Warn enforcement action.

Anything else you would like to add:

  • Gatekeeper has been deployed via gatekeeper.yaml
  • A proper message is printed when enforcementAction is set to deny
  • If --log-denies is set, a constrain violation get logged correctly on both warn and deny.
  • Based of kubectl --v=9 and Gatekeeper’s --logdenies, a constrain violation gets logged in stderr of the gatekeeper’s pod but kubectl does not get a HTTP 299 response but 201 instead
  • Any debugging tips or requests for an additional information are welcome

Environment:

  • Gatekeeper version: 3.13.0
  • Kubernetes version:
Client Version: v1.27.11
Kustomize Version: v5.0.1
Server Version: v1.27.9
@globalundo globalundo added the bug Something isn't working label Mar 12, 2024
@ritazh
Copy link
Member

ritazh commented Mar 13, 2024

@globalundo can you please share your ConstraintTemplate, constraint, and request that should have returned a warning?
For constraints using warn enforcementAction, gatekeeper should be returning a 299 status code:

const httpStatusWarning = 299

@globalundo
Copy link
Author

globalundo commented Mar 21, 2024

@ritazh while preparing a minimal set of ConstraintTemplate, constraint, and request to reproduce the issue, I have managed to locate an exact issue:

  • in all our constants we have a multi-line violation message.
  • a violation is printed correctly when enforcementAction is deny
  • no message is printed if enforcementAction is warn

Here's a minimal example:

---
apiVersion: constraints.gatekeeper.sh/v1beta1
kind: AlwaysDeny
metadata:
  name: deny-all-requests-in-namespace
spec:
  enforcementAction: deny
  match:
    kinds:
      - apiGroups: [""]
        kinds: ["Pod"]
    namespaces:
      - "default"
---
apiVersion: constraints.gatekeeper.sh/v1beta1
kind: AlwaysDenyMultiline
metadata:
  name: deny-all-requests-in-namespace-multiline
spec:
  enforcementAction: deny
  match:
    kinds:
      - apiGroups: [""]
        kinds: ["Pod"]
    namespaces:
      - "default"
---
apiVersion: templates.gatekeeper.sh/v1beta1
kind: ConstraintTemplate
metadata:
  name: alwaysdenymultiline
spec:
  crd:
    spec:
      names:
        kind: AlwaysDenyMultiline
  targets:
    - target: admission.k8s.gatekeeper.sh
      rego: |
        package alwaysdeny

        violation[{"msg": "All requests are denied by this policy \n multiline message"}] {
          true
        }
---
apiVersion: templates.gatekeeper.sh/v1beta1
kind: ConstraintTemplate
metadata:
  name: alwaysdeny
spec:
  crd:
    spec:
      names:
        kind: AlwaysDeny
  targets:
    - target: admission.k8s.gatekeeper.sh
      rego: |
        package alwaysdeny

        violation[{"msg": "All requests are denied by this policy."}] {
          true
        }

Now, with enforcementAction:deny

$ kubectl run -i --rm --tty podinfo -n default --image=stefanprodan/podinfo  --restart=Never 
Error from server (Forbidden): admission webhook "validation.gatekeeper.sh" denied the request: [deny-all-requests-in-namespace-multiline] All requests are denied by this policy 
 multiline message
[deny-all-requests-in-namespace] All requests are denied by this policy.

However, with enforcementAction:warn only a single line violation message is present:

$ kubectl run -i --rm --tty podinfo -n default --image=stefanprodan/podinfo  --restart=Never 
Warning: [deny-all-requests-in-namespace] All requests are denied by this policy.

The multi-line warning message did work in previous OPA Gatekeeper version, but I can not pinpoint at after what version this has stopped working.

@maxsmythe
Copy link
Contributor

I don't think Gatekeeper has changed any of its violation-reporting-via-webhook logic recently. Is this perhaps related to a Kubernetes or kubectl version change?

Copy link

stale bot commented May 25, 2024

This issue has been automatically marked as stale because it has not had recent activity. It will be closed in 14 days if no further activity occurs. Thank you for your contributions.

@stale stale bot added the stale label May 25, 2024
@stale stale bot closed this as completed Jun 9, 2024
@andrevcf
Copy link

Confirmed the problem with multi-line violation message.
With single-line message it works!

K8S server: v1.28.4
Gatekeeper: openpolicyagent/gatekeeper:v3.17.0

@sozercan sozercan reopened this Oct 23, 2024
@ritazh ritazh reopened this Oct 23, 2024
@malexander2012
Copy link

malexander2012 commented Oct 29, 2024

we were working through a different issue related to ISSUE-3216 where our violations show in audit but are not denied by the webhook. Gator CLI worked as it should but the Gatekeeper webhook allowed resources to be created. I was not able to duplicate this issue so in my opinion we can close it.

@stale stale bot removed the stale label Oct 29, 2024
Copy link

stale bot commented Dec 29, 2024

This issue has been automatically marked as stale because it has not had recent activity. It will be closed in 14 days if no further activity occurs. Thank you for your contributions.

@stale stale bot added the stale label Dec 29, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working stale
Projects
None yet
Development

No branches or pull requests

6 participants