init.js 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. 'use strict'
  2. /* global nodeProcess, isolatedWorld, worldId */
  3. const { EventEmitter } = require('events')
  4. process.electronBinding = require('@electron/internal/common/electron-binding-setup').electronBindingSetup(nodeProcess._linkedBinding, 'renderer')
  5. const v8Util = process.electronBinding('v8_util')
  6. // The `lib/renderer/ipc-renderer-internal.js` module looks for the ipc object in the
  7. // "ipc-internal" hidden value
  8. v8Util.setHiddenValue(global, 'ipc-internal', v8Util.getHiddenValue(isolatedWorld, 'ipc-internal'))
  9. // The process object created by webpack is not an event emitter, fix it so
  10. // the API is more compatible with non-sandboxed renderers.
  11. for (const prop of Object.keys(EventEmitter.prototype)) {
  12. if (process.hasOwnProperty(prop)) {
  13. delete process[prop]
  14. }
  15. }
  16. Object.setPrototypeOf(process, EventEmitter.prototype)
  17. const isolatedWorldArgs = v8Util.getHiddenValue(isolatedWorld, 'isolated-world-args')
  18. if (isolatedWorldArgs) {
  19. const { guestInstanceId, isHiddenPage, openerId, usesNativeWindowOpen } = isolatedWorldArgs
  20. const { windowSetup } = require('@electron/internal/renderer/window-setup')
  21. windowSetup(guestInstanceId, openerId, isHiddenPage, usesNativeWindowOpen)
  22. }
  23. const extensionId = v8Util.getHiddenValue(isolatedWorld, `extension-${worldId}`)
  24. if (extensionId) {
  25. const chromeAPI = require('@electron/internal/renderer/chrome-api')
  26. chromeAPI.injectTo(extensionId, window)
  27. }