chore: make raw requires type-safe (#29006)
* chore: make raw requires type-safe * refactor: no need for separate webViewImplModule * refactor: no need for separate guestViewInternalModule
This commit is contained in:
parent
8d0e7aed9f
commit
2c65060ec8
13 changed files with 68 additions and 58 deletions
|
@ -13,7 +13,7 @@ function isValid (options: Electron.SourcesOptions) {
|
||||||
return Array.isArray(types);
|
return Array.isArray(types);
|
||||||
}
|
}
|
||||||
|
|
||||||
export const getSourcesImpl = (event: Electron.IpcMainEvent | null, args: Electron.SourcesOptions) => {
|
export const getSourcesImpl = (sender: Electron.WebContents | null, args: Electron.SourcesOptions) => {
|
||||||
if (!isValid(args)) throw new Error('Invalid options');
|
if (!isValid(args)) throw new Error('Invalid options');
|
||||||
|
|
||||||
const captureWindow = args.types.includes('window');
|
const captureWindow = args.types.includes('window');
|
||||||
|
@ -48,8 +48,8 @@ export const getSourcesImpl = (event: Electron.IpcMainEvent | null, args: Electr
|
||||||
}
|
}
|
||||||
// Remove from currentlyRunning once we resolve or reject
|
// Remove from currentlyRunning once we resolve or reject
|
||||||
currentlyRunning = currentlyRunning.filter(running => running.options !== options);
|
currentlyRunning = currentlyRunning.filter(running => running.options !== options);
|
||||||
if (event) {
|
if (sender) {
|
||||||
event.sender.removeListener('destroyed', stopRunning);
|
sender.removeListener('destroyed', stopRunning);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -68,8 +68,8 @@ export const getSourcesImpl = (event: Electron.IpcMainEvent | null, args: Electr
|
||||||
// If the WebContents is destroyed before receiving result, just remove the
|
// If the WebContents is destroyed before receiving result, just remove the
|
||||||
// reference to emit and the capturer itself so that it never dispatches
|
// reference to emit and the capturer itself so that it never dispatches
|
||||||
// back to the renderer
|
// back to the renderer
|
||||||
if (event) {
|
if (sender) {
|
||||||
event.sender.once('destroyed', stopRunning);
|
sender.once('destroyed', stopRunning);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,8 @@ import { EventEmitter } from 'events';
|
||||||
import * as fs from 'fs';
|
import * as fs from 'fs';
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
|
|
||||||
|
import type * as defaultMenuModule from '@electron/internal/browser/default-menu';
|
||||||
|
|
||||||
const Module = require('module');
|
const Module = require('module');
|
||||||
|
|
||||||
// We modified the original process.argv to let node.js load the init.js,
|
// We modified the original process.argv to let node.js load the init.js,
|
||||||
|
@ -172,7 +174,7 @@ app.on('window-all-closed', () => {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
const { setDefaultApplicationMenu } = require('@electron/internal/browser/default-menu');
|
const { setDefaultApplicationMenu } = require('@electron/internal/browser/default-menu') as typeof defaultMenuModule;
|
||||||
|
|
||||||
// Create default menu.
|
// Create default menu.
|
||||||
//
|
//
|
||||||
|
|
|
@ -7,6 +7,8 @@ import * as ipcMainUtils from '@electron/internal/browser/ipc-main-internal-util
|
||||||
import * as typeUtils from '@electron/internal/common/type-utils';
|
import * as typeUtils from '@electron/internal/common/type-utils';
|
||||||
import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
|
import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
|
||||||
|
|
||||||
|
import type * as desktopCapturerModule from '@electron/internal/browser/desktop-capturer';
|
||||||
|
|
||||||
const eventBinding = process._linkedBinding('electron_browser_event');
|
const eventBinding = process._linkedBinding('electron_browser_event');
|
||||||
|
|
||||||
const emitCustomEvent = function (contents: WebContents, eventName: string, ...args: any[]) {
|
const emitCustomEvent = function (contents: WebContents, eventName: string, ...args: any[]) {
|
||||||
|
@ -58,7 +60,7 @@ ipcMainUtils.handleSync(IPC_MESSAGES.BROWSER_CLIPBOARD_SYNC, function (event, me
|
||||||
});
|
});
|
||||||
|
|
||||||
if (BUILDFLAG(ENABLE_DESKTOP_CAPTURER)) {
|
if (BUILDFLAG(ENABLE_DESKTOP_CAPTURER)) {
|
||||||
const desktopCapturer = require('@electron/internal/browser/desktop-capturer');
|
const desktopCapturer = require('@electron/internal/browser/desktop-capturer') as typeof desktopCapturerModule;
|
||||||
|
|
||||||
ipcMainInternal.handle(IPC_MESSAGES.DESKTOP_CAPTURER_GET_SOURCES, async function (event, options: Electron.SourcesOptions, stack: string) {
|
ipcMainInternal.handle(IPC_MESSAGES.DESKTOP_CAPTURER_GET_SOURCES, async function (event, options: Electron.SourcesOptions, stack: string) {
|
||||||
logStack(event.sender, 'desktopCapturer.getSources()', stack);
|
logStack(event.sender, 'desktopCapturer.getSources()', stack);
|
||||||
|
@ -69,7 +71,7 @@ if (BUILDFLAG(ENABLE_DESKTOP_CAPTURER)) {
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
return typeUtils.serialize(await desktopCapturer.getSourcesImpl(event, options));
|
return typeUtils.serialize(await desktopCapturer.getSourcesImpl(event.sender, options));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,13 @@
|
||||||
import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
|
import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
|
||||||
|
|
||||||
|
import type * as ipcRendererUtilsModule from '@electron/internal/renderer/ipc-renderer-internal-utils';
|
||||||
|
import type * as typeUtilsModule from '@electron/internal/common/type-utils';
|
||||||
|
|
||||||
const clipboard = process._linkedBinding('electron_common_clipboard');
|
const clipboard = process._linkedBinding('electron_common_clipboard');
|
||||||
|
|
||||||
if (process.type === 'renderer') {
|
if (process.type === 'renderer') {
|
||||||
const ipcRendererUtils = require('@electron/internal/renderer/ipc-renderer-internal-utils');
|
const ipcRendererUtils = require('@electron/internal/renderer/ipc-renderer-internal-utils') as typeof ipcRendererUtilsModule;
|
||||||
const typeUtils = require('@electron/internal/common/type-utils');
|
const typeUtils = require('@electron/internal/common/type-utils') as typeof typeUtilsModule;
|
||||||
|
|
||||||
const makeRemoteMethod = function (method: keyof Electron.Clipboard) {
|
const makeRemoteMethod = function (method: keyof Electron.Clipboard) {
|
||||||
return (...args: any[]) => {
|
return (...args: any[]) => {
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
/* global nodeProcess, isolatedWorld */
|
/* global nodeProcess, isolatedWorld */
|
||||||
|
|
||||||
|
import type * as webViewElementModule from '@electron/internal/renderer/web-view/web-view-element';
|
||||||
|
|
||||||
process._linkedBinding = nodeProcess._linkedBinding;
|
process._linkedBinding = nodeProcess._linkedBinding;
|
||||||
|
|
||||||
const v8Util = process._linkedBinding('electron_common_v8_util');
|
const v8Util = process._linkedBinding('electron_common_v8_util');
|
||||||
|
@ -8,6 +10,6 @@ const webViewImpl = v8Util.getHiddenValue(isolatedWorld, 'web-view-impl');
|
||||||
|
|
||||||
if (webViewImpl) {
|
if (webViewImpl) {
|
||||||
// Must setup the WebView element in main world.
|
// Must setup the WebView element in main world.
|
||||||
const { setupWebView } = require('@electron/internal/renderer/web-view/web-view-element');
|
const { setupWebView } = require('@electron/internal/renderer/web-view/web-view-element') as typeof webViewElementModule;
|
||||||
setupWebView(v8Util, webViewImpl);
|
setupWebView(v8Util, webViewImpl as any);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,12 @@
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
|
import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
|
||||||
|
|
||||||
|
import type * as ipcRendererInternalModule from '@electron/internal/renderer/ipc-renderer-internal';
|
||||||
|
import type * as webFrameInitModule from '@electron/internal/renderer/web-frame-init';
|
||||||
|
import type * as webViewInitModule from '@electron/internal/renderer/web-view/web-view-init';
|
||||||
|
import type * as windowSetupModule from '@electron/internal/renderer/window-setup';
|
||||||
|
import type * as securityWarningsModule from '@electron/internal/renderer/security-warnings';
|
||||||
|
|
||||||
const Module = require('module');
|
const Module = require('module');
|
||||||
|
|
||||||
// Make sure globals like "process" and "global" are always available in preload
|
// Make sure globals like "process" and "global" are always available in preload
|
||||||
|
@ -43,7 +49,7 @@ const v8Util = process._linkedBinding('electron_common_v8_util');
|
||||||
const contextId = v8Util.getHiddenValue<string>(global, 'contextId');
|
const contextId = v8Util.getHiddenValue<string>(global, 'contextId');
|
||||||
Object.defineProperty(process, 'contextId', { enumerable: true, value: contextId });
|
Object.defineProperty(process, 'contextId', { enumerable: true, value: contextId });
|
||||||
|
|
||||||
const { ipcRendererInternal } = require('@electron/internal/renderer/ipc-renderer-internal');
|
const { ipcRendererInternal } = require('@electron/internal/renderer/ipc-renderer-internal') as typeof ipcRendererInternalModule;
|
||||||
const ipcRenderer = require('@electron/internal/renderer/api/ipc-renderer').default;
|
const ipcRenderer = require('@electron/internal/renderer/api/ipc-renderer').default;
|
||||||
|
|
||||||
v8Util.setHiddenValue(global, 'ipcNative', {
|
v8Util.setHiddenValue(global, 'ipcNative', {
|
||||||
|
@ -58,7 +64,7 @@ v8Util.setHiddenValue(global, 'ipcNative', {
|
||||||
});
|
});
|
||||||
|
|
||||||
// Use electron module after everything is ready.
|
// Use electron module after everything is ready.
|
||||||
const { webFrameInit } = require('@electron/internal/renderer/web-frame-init');
|
const { webFrameInit } = require('@electron/internal/renderer/web-frame-init') as typeof webFrameInitModule;
|
||||||
webFrameInit();
|
webFrameInit();
|
||||||
|
|
||||||
// Process command line arguments.
|
// Process command line arguments.
|
||||||
|
@ -72,8 +78,8 @@ const isHiddenPage = mainFrame.getWebPreference('hiddenPage');
|
||||||
const usesNativeWindowOpen = mainFrame.getWebPreference('nativeWindowOpen');
|
const usesNativeWindowOpen = mainFrame.getWebPreference('nativeWindowOpen');
|
||||||
const preloadScript = mainFrame.getWebPreference('preload');
|
const preloadScript = mainFrame.getWebPreference('preload');
|
||||||
const preloadScripts = mainFrame.getWebPreference('preloadScripts');
|
const preloadScripts = mainFrame.getWebPreference('preloadScripts');
|
||||||
const guestInstanceId = mainFrame.getWebPreference('guestInstanceId') || null;
|
const guestInstanceId = mainFrame.getWebPreference('guestInstanceId');
|
||||||
const openerId = mainFrame.getWebPreference('openerId') || null;
|
const openerId = mainFrame.getWebPreference('openerId');
|
||||||
const appPath = hasSwitch('app-path') ? getSwitchValue('app-path') : null;
|
const appPath = hasSwitch('app-path') ? getSwitchValue('app-path') : null;
|
||||||
|
|
||||||
// The webContents preload script is loaded after the session preload scripts.
|
// The webContents preload script is loaded after the session preload scripts.
|
||||||
|
@ -95,14 +101,14 @@ switch (window.location.protocol) {
|
||||||
}
|
}
|
||||||
default: {
|
default: {
|
||||||
// Override default web functions.
|
// Override default web functions.
|
||||||
const { windowSetup } = require('@electron/internal/renderer/window-setup');
|
const { windowSetup } = require('@electron/internal/renderer/window-setup') as typeof windowSetupModule;
|
||||||
windowSetup(guestInstanceId, openerId, isHiddenPage, usesNativeWindowOpen);
|
windowSetup(guestInstanceId, openerId, isHiddenPage, usesNativeWindowOpen);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Load webview tag implementation.
|
// Load webview tag implementation.
|
||||||
if (process.isMainFrame) {
|
if (process.isMainFrame) {
|
||||||
const { webViewInit } = require('@electron/internal/renderer/web-view/web-view-init');
|
const { webViewInit } = require('@electron/internal/renderer/web-view/web-view-init') as typeof webViewInitModule;
|
||||||
webViewInit(contextIsolation, webviewTag, guestInstanceId);
|
webViewInit(contextIsolation, webviewTag, guestInstanceId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -187,6 +193,6 @@ for (const preloadScript of preloadScripts) {
|
||||||
|
|
||||||
// Warn about security issues
|
// Warn about security issues
|
||||||
if (process.isMainFrame) {
|
if (process.isMainFrame) {
|
||||||
const { securityWarnings } = require('@electron/internal/renderer/security-warnings');
|
const { securityWarnings } = require('@electron/internal/renderer/security-warnings') as typeof securityWarningsModule;
|
||||||
securityWarnings(nodeIntegration);
|
securityWarnings(nodeIntegration);
|
||||||
}
|
}
|
||||||
|
|
|
@ -286,7 +286,7 @@ const getWebPreferences = async function () {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
export function securityWarnings (nodeIntegration: boolean) {
|
export function securityWarnings (nodeIntegration = false) {
|
||||||
const loadHandler = async function () {
|
const loadHandler = async function () {
|
||||||
if (shouldLogSecurityWarnings()) {
|
if (shouldLogSecurityWarnings()) {
|
||||||
const webPreferences = await getWebPreferences();
|
const webPreferences = await getWebPreferences();
|
||||||
|
|
|
@ -70,10 +70,3 @@ export function attachGuest (
|
||||||
export function detachGuest (guestInstanceId: number) {
|
export function detachGuest (guestInstanceId: number) {
|
||||||
return ipcRendererUtils.invokeSync(IPC_MESSAGES.GUEST_VIEW_MANAGER_DETACH_GUEST, guestInstanceId);
|
return ipcRendererUtils.invokeSync(IPC_MESSAGES.GUEST_VIEW_MANAGER_DETACH_GUEST, guestInstanceId);
|
||||||
}
|
}
|
||||||
|
|
||||||
export const guestViewInternalModule = {
|
|
||||||
deregisterEvents,
|
|
||||||
createGuest,
|
|
||||||
attachGuest,
|
|
||||||
detachGuest
|
|
||||||
};
|
|
||||||
|
|
|
@ -9,9 +9,11 @@
|
||||||
// modules must be passed from outside, all included files must be plain JS.
|
// modules must be passed from outside, all included files must be plain JS.
|
||||||
|
|
||||||
import { WEB_VIEW_CONSTANTS } from '@electron/internal/renderer/web-view/web-view-constants';
|
import { WEB_VIEW_CONSTANTS } from '@electron/internal/renderer/web-view/web-view-constants';
|
||||||
import { WebViewImpl as IWebViewImpl, webViewImplModule } from '@electron/internal/renderer/web-view/web-view-impl';
|
import type * as webViewImplModule from '@electron/internal/renderer/web-view/web-view-impl';
|
||||||
import type { SrcAttribute } from '@electron/internal/renderer/web-view/web-view-attributes';
|
import type { SrcAttribute } from '@electron/internal/renderer/web-view/web-view-attributes';
|
||||||
|
|
||||||
|
type IWebViewImpl = webViewImplModule.WebViewImpl;
|
||||||
|
|
||||||
// Return a WebViewElement class that is defined in this context.
|
// Return a WebViewElement class that is defined in this context.
|
||||||
const defineWebViewElement = (v8Util: NodeJS.V8UtilBinding, webViewImpl: typeof webViewImplModule) => {
|
const defineWebViewElement = (v8Util: NodeJS.V8UtilBinding, webViewImpl: typeof webViewImplModule) => {
|
||||||
const { guestViewInternal, WebViewImpl } = webViewImpl;
|
const { guestViewInternal, WebViewImpl } = webViewImpl;
|
||||||
|
|
|
@ -1,5 +1,3 @@
|
||||||
import * as electron from 'electron';
|
|
||||||
|
|
||||||
import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal';
|
import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal';
|
||||||
import * as ipcRendererUtils from '@electron/internal/renderer/ipc-renderer-internal-utils';
|
import * as ipcRendererUtils from '@electron/internal/renderer/ipc-renderer-internal-utils';
|
||||||
import * as guestViewInternal from '@electron/internal/renderer/web-view/guest-view-internal';
|
import * as guestViewInternal from '@electron/internal/renderer/web-view/guest-view-internal';
|
||||||
|
@ -8,7 +6,9 @@ import { syncMethods, asyncMethods, properties } from '@electron/internal/common
|
||||||
import type { WebViewAttribute, PartitionAttribute } from '@electron/internal/renderer/web-view/web-view-attributes';
|
import type { WebViewAttribute, PartitionAttribute } from '@electron/internal/renderer/web-view/web-view-attributes';
|
||||||
import { deserialize } from '@electron/internal/common/type-utils';
|
import { deserialize } from '@electron/internal/common/type-utils';
|
||||||
import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
|
import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
|
||||||
const { webFrame } = electron;
|
|
||||||
|
export { webFrame } from 'electron';
|
||||||
|
export * as guestViewInternal from '@electron/internal/renderer/web-view/guest-view-internal';
|
||||||
|
|
||||||
const v8Util = process._linkedBinding('electron_common_v8_util');
|
const v8Util = process._linkedBinding('electron_common_v8_util');
|
||||||
|
|
||||||
|
@ -272,11 +272,3 @@ export const setupMethods = (WebViewElement: typeof ElectronInternal.WebViewElem
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
export const webViewImplModule = {
|
|
||||||
setupAttributes,
|
|
||||||
setupMethods,
|
|
||||||
guestViewInternal,
|
|
||||||
webFrame,
|
|
||||||
WebViewImpl
|
|
||||||
};
|
|
||||||
|
|
|
@ -1,6 +1,9 @@
|
||||||
import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal';
|
import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal';
|
||||||
import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
|
import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
|
||||||
|
|
||||||
|
import type * as webViewImpl from '@electron/internal/renderer/web-view/web-view-impl';
|
||||||
|
import type * as webViewElement from '@electron/internal/renderer/web-view/web-view-element';
|
||||||
|
|
||||||
const v8Util = process._linkedBinding('electron_common_v8_util');
|
const v8Util = process._linkedBinding('electron_common_v8_util');
|
||||||
|
|
||||||
function handleFocusBlur () {
|
function handleFocusBlur () {
|
||||||
|
@ -16,16 +19,14 @@ function handleFocusBlur () {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export function webViewInit (
|
export function webViewInit (contextIsolation: boolean, webviewTag: boolean, guestInstanceId: number) {
|
||||||
contextIsolation: boolean, webviewTag: ElectronInternal.WebViewElement, guestInstanceId: number
|
|
||||||
) {
|
|
||||||
// Don't allow recursive `<webview>`.
|
// Don't allow recursive `<webview>`.
|
||||||
if (webviewTag && guestInstanceId == null) {
|
if (webviewTag && !guestInstanceId) {
|
||||||
const { webViewImplModule } = require('@electron/internal/renderer/web-view/web-view-impl');
|
const webViewImplModule = require('@electron/internal/renderer/web-view/web-view-impl') as typeof webViewImpl;
|
||||||
if (contextIsolation) {
|
if (contextIsolation) {
|
||||||
v8Util.setHiddenValue(window, 'web-view-impl', webViewImplModule);
|
v8Util.setHiddenValue(window, 'web-view-impl', webViewImplModule);
|
||||||
} else {
|
} else {
|
||||||
const { setupWebView } = require('@electron/internal/renderer/web-view/web-view-element');
|
const { setupWebView } = require('@electron/internal/renderer/web-view/web-view-element') as typeof webViewElement;
|
||||||
setupWebView(v8Util, webViewImplModule);
|
setupWebView(v8Util, webViewImplModule);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -244,7 +244,7 @@ class BrowserWindowProxy {
|
||||||
|
|
||||||
export const windowSetup = (
|
export const windowSetup = (
|
||||||
guestInstanceId: number, openerId: number, isHiddenPage: boolean, usesNativeWindowOpen: boolean) => {
|
guestInstanceId: number, openerId: number, isHiddenPage: boolean, usesNativeWindowOpen: boolean) => {
|
||||||
if (!process.sandboxed && guestInstanceId == null) {
|
if (!process.sandboxed && !guestInstanceId) {
|
||||||
// Override default window.close.
|
// Override default window.close.
|
||||||
window.close = function () {
|
window.close = function () {
|
||||||
ipcRendererInternal.send(IPC_MESSAGES.BROWSER_WINDOW_CLOSE);
|
ipcRendererInternal.send(IPC_MESSAGES.BROWSER_WINDOW_CLOSE);
|
||||||
|
@ -284,9 +284,9 @@ export const windowSetup = (
|
||||||
// [ grandparent window ] --> [ parent window ] --> [ child window ]
|
// [ grandparent window ] --> [ parent window ] --> [ child window ]
|
||||||
// n.W.O = false n.W.O = true n.W.O = true
|
// n.W.O = false n.W.O = true n.W.O = true
|
||||||
// id = 1 id = 2 id = 3
|
// id = 1 id = 2 id = 3
|
||||||
// openerId = null openerId = 1 openerId = 1 <- !!wrong!!
|
// openerId = 0 openerId = 1 openerId = 1 <- !!wrong!!
|
||||||
// opener = null opener = null opener = [parent window]
|
// opener = null opener = null opener = [parent window]
|
||||||
if (openerId != null && !window.opener) {
|
if (openerId && !window.opener) {
|
||||||
window.opener = getOrCreateProxy(openerId);
|
window.opener = getOrCreateProxy(openerId);
|
||||||
if (contextIsolationEnabled) internalContextBridge.overrideGlobalValueWithDynamicPropsFromIsolatedWorld(['opener'], window.opener);
|
if (contextIsolationEnabled) internalContextBridge.overrideGlobalValueWithDynamicPropsFromIsolatedWorld(['opener'], window.opener);
|
||||||
}
|
}
|
||||||
|
@ -297,7 +297,7 @@ export const windowSetup = (
|
||||||
};
|
};
|
||||||
if (contextIsolationEnabled) internalContextBridge.overrideGlobalValueFromIsolatedWorld(['prompt'], window.prompt);
|
if (contextIsolationEnabled) internalContextBridge.overrideGlobalValueFromIsolatedWorld(['prompt'], window.prompt);
|
||||||
|
|
||||||
if (!usesNativeWindowOpen || openerId != null) {
|
if (!usesNativeWindowOpen || openerId) {
|
||||||
ipcRendererInternal.on(IPC_MESSAGES.GUEST_WINDOW_POSTMESSAGE, function (
|
ipcRendererInternal.on(IPC_MESSAGES.GUEST_WINDOW_POSTMESSAGE, function (
|
||||||
_event, sourceId: number, message: any, sourceOrigin: string
|
_event, sourceId: number, message: any, sourceOrigin: string
|
||||||
) {
|
) {
|
||||||
|
@ -318,7 +318,7 @@ export const windowSetup = (
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
if (guestInstanceId != null) {
|
if (guestInstanceId) {
|
||||||
// Webview `document.visibilityState` tracks window visibility (and ignores
|
// Webview `document.visibilityState` tracks window visibility (and ignores
|
||||||
// the actual <webview> element visibility) for backwards compatibility.
|
// the actual <webview> element visibility) for backwards compatibility.
|
||||||
// See discussion in #9178.
|
// See discussion in #9178.
|
||||||
|
|
|
@ -3,6 +3,13 @@
|
||||||
import * as events from 'events';
|
import * as events from 'events';
|
||||||
import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
|
import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
|
||||||
|
|
||||||
|
import type * as ipcRendererUtilsModule from '@electron/internal/renderer/ipc-renderer-internal-utils';
|
||||||
|
import type * as ipcRendererInternalModule from '@electron/internal/renderer/ipc-renderer-internal';
|
||||||
|
import type * as webFrameInitModule from '@electron/internal/renderer/web-frame-init';
|
||||||
|
import type * as webViewInitModule from '@electron/internal/renderer/web-view/web-view-init';
|
||||||
|
import type * as windowSetupModule from '@electron/internal/renderer/window-setup';
|
||||||
|
import type * as securityWarningsModule from '@electron/internal/renderer/security-warnings';
|
||||||
|
|
||||||
const { EventEmitter } = events;
|
const { EventEmitter } = events;
|
||||||
|
|
||||||
process._linkedBinding = binding.get;
|
process._linkedBinding = binding.get;
|
||||||
|
@ -20,8 +27,8 @@ for (const prop of Object.keys(EventEmitter.prototype) as (keyof typeof process)
|
||||||
}
|
}
|
||||||
Object.setPrototypeOf(process, EventEmitter.prototype);
|
Object.setPrototypeOf(process, EventEmitter.prototype);
|
||||||
|
|
||||||
const { ipcRendererInternal } = require('@electron/internal/renderer/ipc-renderer-internal');
|
const { ipcRendererInternal } = require('@electron/internal/renderer/ipc-renderer-internal') as typeof ipcRendererInternalModule;
|
||||||
const ipcRendererUtils = require('@electron/internal/renderer/ipc-renderer-internal-utils');
|
const ipcRendererUtils = require('@electron/internal/renderer/ipc-renderer-internal-utils') as typeof ipcRendererUtilsModule;
|
||||||
|
|
||||||
const { preloadScripts, process: processProps } = ipcRendererUtils.invokeSync(IPC_MESSAGES.BROWSER_SANDBOX_LOAD);
|
const { preloadScripts, process: processProps } = ipcRendererUtils.invokeSync(IPC_MESSAGES.BROWSER_SANDBOX_LOAD);
|
||||||
|
|
||||||
|
@ -68,7 +75,7 @@ v8Util.setHiddenValue(global, 'lifecycle', {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
const { webFrameInit } = require('@electron/internal/renderer/web-frame-init');
|
const { webFrameInit } = require('@electron/internal/renderer/web-frame-init') as typeof webFrameInitModule;
|
||||||
webFrameInit();
|
webFrameInit();
|
||||||
|
|
||||||
// Pass different process object to the preload script.
|
// Pass different process object to the preload script.
|
||||||
|
@ -125,8 +132,8 @@ const contextIsolation = mainFrame.getWebPreference('contextIsolation');
|
||||||
const webviewTag = mainFrame.getWebPreference('webviewTag');
|
const webviewTag = mainFrame.getWebPreference('webviewTag');
|
||||||
const isHiddenPage = mainFrame.getWebPreference('hiddenPage');
|
const isHiddenPage = mainFrame.getWebPreference('hiddenPage');
|
||||||
const usesNativeWindowOpen = true;
|
const usesNativeWindowOpen = true;
|
||||||
const guestInstanceId = mainFrame.getWebPreference('guestInstanceId') || null;
|
const guestInstanceId = mainFrame.getWebPreference('guestInstanceId');
|
||||||
const openerId = mainFrame.getWebPreference('openerId') || null;
|
const openerId = mainFrame.getWebPreference('openerId');
|
||||||
|
|
||||||
switch (window.location.protocol) {
|
switch (window.location.protocol) {
|
||||||
case 'devtools:': {
|
case 'devtools:': {
|
||||||
|
@ -142,14 +149,14 @@ switch (window.location.protocol) {
|
||||||
}
|
}
|
||||||
default: {
|
default: {
|
||||||
// Override default web functions.
|
// Override default web functions.
|
||||||
const { windowSetup } = require('@electron/internal/renderer/window-setup');
|
const { windowSetup } = require('@electron/internal/renderer/window-setup') as typeof windowSetupModule;
|
||||||
windowSetup(guestInstanceId, openerId, isHiddenPage, usesNativeWindowOpen);
|
windowSetup(guestInstanceId, openerId, isHiddenPage, usesNativeWindowOpen);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Load webview tag implementation.
|
// Load webview tag implementation.
|
||||||
if (process.isMainFrame) {
|
if (process.isMainFrame) {
|
||||||
const { webViewInit } = require('@electron/internal/renderer/web-view/web-view-init');
|
const { webViewInit } = require('@electron/internal/renderer/web-view/web-view-init') as typeof webViewInitModule;
|
||||||
webViewInit(contextIsolation, webviewTag, guestInstanceId);
|
webViewInit(contextIsolation, webviewTag, guestInstanceId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -189,6 +196,6 @@ for (const { preloadPath, preloadSrc, preloadError } of preloadScripts) {
|
||||||
|
|
||||||
// Warn about security issues
|
// Warn about security issues
|
||||||
if (process.isMainFrame) {
|
if (process.isMainFrame) {
|
||||||
const { securityWarnings } = require('@electron/internal/renderer/security-warnings');
|
const { securityWarnings } = require('@electron/internal/renderer/security-warnings') as typeof securityWarningsModule;
|
||||||
securityWarnings();
|
securityWarnings();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue