From d9a7f3cc995d3d861e1380eafb886cb3c5e2b873 Mon Sep 17 00:00:00 2001 From: XmiliaH Date: Sun, 28 Aug 2022 15:50:12 +0200 Subject: [PATCH] Fix 467 --- lib/setup-sandbox.js | 3 ++- test/vm.js | 7 +++++++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/lib/setup-sandbox.js b/lib/setup-sandbox.js index 2c80dbc..f6cbb8e 100644 --- a/lib/setup-sandbox.js +++ b/lib/setup-sandbox.js @@ -67,7 +67,8 @@ Object.defineProperties(global, { global: {value: global, writable: true, configurable: true, enumerable: true}, globalThis: {value: global, writable: true, configurable: true}, GLOBAL: {value: global, writable: true, configurable: true}, - root: {value: global, writable: true, configurable: true} + root: {value: global, writable: true, configurable: true}, + Error: {value: LocalError} }); if (!localReflectDefineProperty(global, 'VMError', { diff --git a/test/vm.js b/test/vm.js index b72265d..d4f6a9f 100644 --- a/test/vm.js +++ b/test/vm.js @@ -1070,6 +1070,13 @@ describe('VM', () => { Error.prepareStackTrace = undefined; stack.process `)); + assert.throws(()=>vm2.run(`(()=>{ + const OldError = Error; + global.Error = {prepareStackTrace: (_, c) => c.map(c => c.getThis()).find(a => a && a.process)}; + const { stack } = new OldError(); + global.Error = OldError; + return stack.process.mainModule; + })()`)); }); it('Node internal prepareStackTrace attack', () => {