Skip to main content

Twig CVE-2026-46639

HIGH
Protection Mechanism Failure (CWE-693)
2026-05-21 https://github.com/twigphp/Twig GHSA-mm6w-gr99-p3jj
Share

Lifecycle Timeline

2
Source Code Evidence Fetched
May 21, 2026 - 22:33 vuln.today
Analysis Generated
May 21, 2026 - 22:33 vuln.today

DescriptionNVD

Description

The object-destructuring assignment syntax introduced in Twig 3.24.0 generates a call to CoreExtension::getAttribute() with the $sandboxed argument hardcoded to false, regardless of whether a SandboxExtension is active. This permanently disables the sandbox's property and method policy checks for every destructuring expression.

ObjectDestructuringSetBinary::compile() emits:

php
CoreExtension::getAttribute($this->env, $this->source, ..., \Twig\Template::ANY_CALL, false, false, false, ...);
//                                                                                ^^^^^
//                                                                       sandbox check never runs

Whereas GetAttrExpression::compile() correctly passes $env->hasExtension(SandboxExtension::class).

An attacker with write access to a sandboxed Twig template can read any public property or invoke any public getter on objects passed to the template engine, bypassing SecurityPolicy restrictions. The exploit requires only the {% do %} tag to be in allowedTags, which is a common configuration.

Resolution

The destructuring compiler now forwards the active sandbox flag to getAttribute() so property/method allowlists are enforced.

Credits

Twig would like to thank Anvil Secure in collaboration with Claude and Anthropic Research for reporting and fixing the issue.

AnalysisAI

{% do %} tag is permitted. No public exploit identified at time of analysis, but the issue was responsibly disclosed with vendor-confirmed root cause and an upstream patch.

Sign in for full analysis, threat intelligence, and remediation guidance.

RemediationAI

24 hours: Identify systems running Twig 3.24.0-3.25.x; audit who has template write access and what objects are exposed to templates. 7 days: Restrict template authorship to internal developers; remove non-essential objects from template context. …

Sign in for detailed remediation steps.

Share

CVE-2026-46639 vulnerability details – vuln.today

This site uses cookies essential for authentication and security. No tracking or analytics cookies are used. Privacy Policy