CVE-2026-47210
CRITICALvm2 sandbox escape via JSPI-backed Promise `.finally()` species bypass
Title source: cnaDescription
vm2 is an open source vm/sandbox for Node.js. Prior to version 3.11.4, a sandbox escape vulnerability in vm2 allows arbitrary code execution in the host process when untrusted code is executed with async support on runtimes exposing WebAssembly JSPI (WebAssembly.promising / WebAssembly.Suspending). In the tested configuration, a JSPI-backed Promise can reach Promise.prototype.finally() in a way that bypasses the expected Promise-species hardening and exposes a host-originated rejection object to attacker-controlled species logic, breaking the sandbox boundary. This issue has been patched in version 3.11.4.
References (3)
Core 3
Core References
X_Refsource_Confirm x_refsource_confirm
https://github.com/patriksimek/vm2/security/advisories/GHSA-6j2x-vhqr-qr7q
X_Refsource_Misc x_refsource_misc
https://github.com/patriksimek/vm2/commit/6915fa4d9bcebd47b9a4f39a1adc1aa94ef6ffc6
X_Refsource_Misc x_refsource_misc
https://github.com/patriksimek/vm2/releases/tag/v3.11.4
Scores
CVSS v3
9.8
EPSS
0.0088
EPSS Percentile
54.3%
Attack Vector
NETWORK
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
CISA SSVC
Vulnrichment
Exploitation
poc
Automatable
yes
Technical Impact
total
Details
CWE
CWE-913
Status
published
Products (2)
npm/vm2
0 - 3.11.4npm
patriksimek/vm2
< 3.11.4
Published
Jun 12, 2026
Tracked Since
Jun 12, 2026