CVE-2026-41246: Contour has Lua code injection via Cookie Path Rewrite Policy
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.valuespec.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.
References
- github.com/advisories/GHSA-x4mj-7f9g-29h4
- github.com/projectcontour/contour
- github.com/projectcontour/contour/releases/tag/v1.31.6
- github.com/projectcontour/contour/releases/tag/v1.32.5
- github.com/projectcontour/contour/releases/tag/v1.33.4
- github.com/projectcontour/contour/security/advisories/GHSA-x4mj-7f9g-29h4
- nvd.nist.gov/vuln/detail/CVE-2026-41246
- projectcontour.io/docs/1.33/config/cookie-rewriting
- www.envoyproxy.io/docs/envoy/latest/configuration/http/http_filters/lua_filter
Code Behaviors & Features
Detect and mitigate CVE-2026-41246 with GitLab Dependency Scanning
Secure your software supply chain by verifying that all open source dependencies used in your projects contain no disclosed vulnerabilities. Learn more about Dependency Scanning →