GHSA-x4mj-7f9g-29h4

Suggest an improvement
Source
https://github.com/advisories/GHSA-x4mj-7f9g-29h4
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-x4mj-7f9g-29h4/GHSA-x4mj-7f9g-29h4.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-x4mj-7f9g-29h4
Aliases
Downstream
Related
Published
2026-04-24T15:19:49Z
Modified
2026-04-25T14:29:59.850281783Z
Severity
  • 8.1 (High) CVSS_V3 - CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:N/A:H CVSS Calculator
Summary
Contour has Lua code injection via Cookie Path Rewrite Policy
Details

Impact

Contour's Cookie Rewriting feature is vulnerable to Lua code injection. An attacker with RBAC permissions to create or modify HTTPProxy resources can craft a malicious value in the following fields that results in arbitrary code execution in the Envoy proxy:

  • spec.routes[].cookieRewritePolicies[].pathRewrite.value
  • spec.routes[].services[].cookieRewritePolicies[].pathRewrite.value

The cookie rewriting feature is internally implemented using Envoy's HTTP Lua filter. User-controlled values are interpolated into Lua source code using Go text/template without sufficient sanitization.

The injected code only executes when processing traffic on the attacker's own route, which they already control. However, since Envoy runs as shared infrastructure, the injected code can also:

  • Read Envoy's xDS client credentials from the filesystem, which could be used to read all Contour xDS configuration, including TLS certificates and private keys of other tenants.
  • Cause denial of service for other tenants sharing the Envoy instance.

Other use cases of Lua filter are not vulnerable.

Patches

The fix is available in Contour v1.33.4, v1.32.5, and v1.31.6.

  • v1.33.4: User-provided values are no longer interpolated into Lua code. Use of text/template is removed. Requires Envoy 1.35.0 or later.
  • v1.32.5, v1.31.6: User-provided values are escaped before interpolation into Lua code.

Workarounds

There are no workarounds. Users should upgrade to a patched version.

Database specific
{
    "severity": "HIGH",
    "github_reviewed": true,
    "nvd_published_at": "2026-04-23T19:17:29Z",
    "cwe_ids": [
        "CWE-94"
    ],
    "github_reviewed_at": "2026-04-24T15:19:49Z"
}
References

Affected packages

Go / github.com/projectcontour/contour

Package

Name
github.com/projectcontour/contour
View open source insights on deps.dev
Purl
pkg:golang/github.com/projectcontour/contour

Affected ranges

Type
SEMVER
Events
Introduced
1.19.0
Fixed
1.31.6

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-x4mj-7f9g-29h4/GHSA-x4mj-7f9g-29h4.json"

Go / github.com/projectcontour/contour

Package

Name
github.com/projectcontour/contour
View open source insights on deps.dev
Purl
pkg:golang/github.com/projectcontour/contour

Affected ranges

Type
SEMVER
Events
Introduced
1.32.0
Fixed
1.32.5

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-x4mj-7f9g-29h4/GHSA-x4mj-7f9g-29h4.json"

Go / github.com/projectcontour/contour

Package

Name
github.com/projectcontour/contour
View open source insights on deps.dev
Purl
pkg:golang/github.com/projectcontour/contour

Affected ranges

Type
SEMVER
Events
Introduced
1.33.0
Fixed
1.33.4

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-x4mj-7f9g-29h4/GHSA-x4mj-7f9g-29h4.json"