VDB
KO
HIGH 8.8

GHSA-qmch-v2q9-wg4p

CedarJava has policy injection vulnerability

Details

### Summary

CedarJava is an open source Java implementation of the Cedar policy language, used for fine-grained authorization decisions. Under certain circumstances, improper input handling could allow policy injection.

### Impact

**Cedar-expression injection via unescaped `toCedarExpr()`**

The `toCedarExpr()` method on Cedar Value types does not escape special characters (`"` or `\`) when converting values to Cedar source code. If an integrator uses `toCedarExpr()` to build policy text at runtime from user-controlled values, an actor could inject arbitrary Cedar expressions. For example, injecting `|| true` into a `permit ... when { ... }` clause could make the permit unconditional, or injecting `&& false` into a `forbid` clause could prevent the `forbid` from triggering.

This issue requires the integrator to use `toCedarExpr()` to build policy text at runtime from user-controlled input.

### Impacted versions: < 4.9

### Patches Addressed in CedarJava version 2.3.6, 3.4.1, and 4.9 and above. We recommend upgrading to the latest version and ensuring any forked or derivative code is patched to incorporate the new fixes.

### Workarounds Validate and sanitize all user-supplied input before passing it to `toCedarExpr()`. Avoid building policy text at runtime from user-controlled values.

### References If you have any questions or comments about this advisory, we ask that you contact us directly via email to [cedar-policy-security@lists.cncf.io](mailto:cedar-policy-security@lists.cncf.io). Please do not create a public GitHub issue.

Are you affected?

Enter the version of the package you're using.

Affected packages

Maven / com.cedarpolicy:cedar-java
Introduced in: 0 Fixed in: 2.3.6
Fix # pom.xml: bump <version>2.3.6</version> for com.cedarpolicy:cedar-java
Maven / com.cedarpolicy:cedar-java
Introduced in: 3.1.2 Fixed in: 3.4.1
Fix # pom.xml: bump <version>3.4.1</version> for com.cedarpolicy:cedar-java
Maven / com.cedarpolicy:cedar-java
Introduced in: 4.0.0 Fixed in: 4.9.0
Fix # pom.xml: bump <version>4.9.0</version> for com.cedarpolicy:cedar-java

References