diff --git a/lib/contextify.js b/lib/contextify.js index d9b1dae..621d4d4 100644 --- a/lib/contextify.js +++ b/lib/contextify.js @@ -44,13 +44,25 @@ const DEBUG = false; const OPNA = 'Operation not allowed on contextified object.'; const captureStackTrace = Error.captureStackTrace; -const FROZEN_TRAPS = host.Object.create(null); -FROZEN_TRAPS.set = (target, key) => false; -FROZEN_TRAPS.setPrototypeOf = (target, key) => false; -FROZEN_TRAPS.defineProperty = (target, key) => false; -FROZEN_TRAPS.deleteProperty = (target, key) => false; -FROZEN_TRAPS.isExtensible = (target, key) => false; -FROZEN_TRAPS.preventExtensions = (target) => false; +const RETURN_FALSE = () => false; + +const FROZEN_TRAPS = { + __proto__: null, + set(target, key, value, receiver) { + return local.Reflect.defineProperty(receiver, key, { + __proto__: null, + value: value, + writable: true, + enumerable: true, + configurable: true + }); + }, + setPrototypeOf: RETURN_FALSE, + defineProperty: RETURN_FALSE, + deleteProperty: RETURN_FALSE, + isExtensible: RETURN_FALSE, + preventExtensions: RETURN_FALSE +}; // Map of contextified objects to original objects const Contextified = new host.WeakMap(); diff --git a/test/vm.js b/test/vm.js index 9c062ac..d4915b3 100644 --- a/test/vm.js +++ b/test/vm.js @@ -1009,6 +1009,9 @@ describe('freeze, protect', () => { vm.run('x.c.d = () => { return `---` };'); assert.strictEqual(x.c.d(), 'd'); + + // Extension of frozen objects should be writeable. + assert.strictEqual(vm.run('y = Object.create(x); y.f = 1; y.f'), 1); }); it('without protect', () => {