37 lines
1.5 KiB
JavaScript
37 lines
1.5 KiB
JavaScript
'use strict';
|
|
|
|
/* global nodeProcess, isolatedWorld, worldId */
|
|
|
|
const { EventEmitter } = require('events');
|
|
|
|
process.electronBinding = require('@electron/internal/common/electron-binding-setup').electronBindingSetup(nodeProcess._linkedBinding, 'renderer');
|
|
|
|
const v8Util = process.electronBinding('v8_util');
|
|
|
|
// The `lib/renderer/ipc-renderer-internal.js` module looks for the ipc object in the
|
|
// "ipc-internal" hidden value
|
|
v8Util.setHiddenValue(global, 'ipc-internal', v8Util.getHiddenValue(isolatedWorld, 'ipc-internal'));
|
|
|
|
// The process object created by webpack is not an event emitter, fix it so
|
|
// the API is more compatible with non-sandboxed renderers.
|
|
for (const prop of Object.keys(EventEmitter.prototype)) {
|
|
if (Object.prototype.hasOwnProperty.call(process, prop)) {
|
|
delete process[prop];
|
|
}
|
|
}
|
|
Object.setPrototypeOf(process, EventEmitter.prototype);
|
|
|
|
const isolatedWorldArgs = v8Util.getHiddenValue(isolatedWorld, 'isolated-world-args');
|
|
|
|
if (isolatedWorldArgs) {
|
|
const { guestInstanceId, isHiddenPage, openerId, usesNativeWindowOpen, rendererProcessReuseEnabled } = isolatedWorldArgs;
|
|
const { windowSetup } = require('@electron/internal/renderer/window-setup');
|
|
windowSetup(guestInstanceId, openerId, isHiddenPage, usesNativeWindowOpen, rendererProcessReuseEnabled);
|
|
}
|
|
|
|
const extensionId = v8Util.getHiddenValue(isolatedWorld, `extension-${worldId}`);
|
|
|
|
if (extensionId) {
|
|
const chromeAPI = require('@electron/internal/renderer/chrome-api');
|
|
chromeAPI.injectTo(extensionId, window);
|
|
}
|