Exceptions

Exceptions lets you to specify cases where you allow policy violations. Trivy supports two types of exceptions.

Info

Exceptions can be applied to built-in policies as well as custom policies.

Namespace-based exceptions

There are some cases where you need to disable built-in policies partially or fully. Namespace-based exceptions lets you rough choose which individual packages to exempt.

To use namespace-based exceptions, create a Rego rule with the name exception that returns the package names to exempt. The exception rule must be defined under namespace.exceptions. data.namespaces includes all package names.

Example

  1. package namespace.exceptions
  2. import data.namespaces
  3. exception[ns] {
  4. ns := data.namespaces[_]
  5. startswith(ns, "appshield")
  6. }

This example exempts all built-in policies for Kubernetes.

For more details, see an example.

Rule-based exceptions

There are some cases where you need more flexibility and granularity in defining which cases to exempt. Rule-based exceptions lets you granularly choose which individual rules to exempt, while also declaring under which conditions to exempt them.

To use rule-based exceptions, create a Rego rule with the name exception that returns the rule name suffixes to exempt, prefixed by deny_ (for example, returning foo will exempt deny_foo). The rule can make any other assertion, for example, on the input or data documents. This is useful to specify the exemption for a specific case.

Note that if you specify the empty string, the exception will match all rules named deny.

  1. exception[rules] {
  2. # Logic
  3. rules = ["foo","bar"]
  4. }

The above would provide an exception from deny_foo and deny_bar.

Example

  1. package user.kubernetes.ID100
  2. __rego_metadata := {
  3. "id": "ID100",
  4. "title": "Deployment not allowed",
  5. "severity": "HIGH",
  6. "type": "Kubernetes Custom Check",
  7. }
  8. deny_deployment[msg] {
  9. input.kind == "Deployment"
  10. msg = sprintf("Found deployment '%s' but deployments are not allowed", [name])
  11. }
  12. exception[rules] {
  13. input.kind == "Deployment"
  14. input.metadata.name == "allow-deployment"
  15. rules := ["deployment"]
  16. }

If you want to apply rule-based exceptions to built-in policies, you have to define the exception under the same package.

Example

  1. package appshield.kubernetes.KSV012
  2. exception[rules] {
  3. input.metadata.name == "can-run-as-root"
  4. rules := [""]
  5. }

This exception is applied to KSV012 in AppShield. You can get the package names in AppShield repository or the JSON output from Trivy.

For more details, see an example.