chore: disable JS impl when //extensions support is on (#19512)
This commit is contained in:
parent
a5f87cee6b
commit
c71cdce0b7
9 changed files with 50 additions and 9 deletions
|
@ -1,5 +1,9 @@
|
||||||
'use strict'
|
'use strict'
|
||||||
|
|
||||||
|
if (process.electronBinding('features').isExtensionsEnabled()) {
|
||||||
|
throw new Error('Attempted to load JS chrome-extension polyfill with //extensions support enabled')
|
||||||
|
}
|
||||||
|
|
||||||
const { app, webContents, BrowserWindow } = require('electron')
|
const { app, webContents, BrowserWindow } = require('electron')
|
||||||
const { getAllWebContents } = process.electronBinding('web_contents')
|
const { getAllWebContents } = process.electronBinding('web_contents')
|
||||||
const ipcMainUtils = require('@electron/internal/browser/ipc-main-internal-utils')
|
const ipcMainUtils = require('@electron/internal/browser/ipc-main-internal-utils')
|
||||||
|
|
|
@ -152,7 +152,9 @@ app._setDefaultAppPaths(packagePath)
|
||||||
require('@electron/internal/browser/devtools')
|
require('@electron/internal/browser/devtools')
|
||||||
|
|
||||||
// Load the chrome extension support.
|
// Load the chrome extension support.
|
||||||
require('@electron/internal/browser/chrome-extension')
|
if (!process.electronBinding('features').isExtensionsEnabled()) {
|
||||||
|
require('@electron/internal/browser/chrome-extension')
|
||||||
|
}
|
||||||
|
|
||||||
// Load protocol module to ensure it is populated on app ready
|
// Load protocol module to ensure it is populated on app ready
|
||||||
require('@electron/internal/browser/api/protocol')
|
require('@electron/internal/browser/api/protocol')
|
||||||
|
|
|
@ -9,7 +9,6 @@ const eventBinding = process.electronBinding('event')
|
||||||
const clipboard = process.electronBinding('clipboard')
|
const clipboard = process.electronBinding('clipboard')
|
||||||
const features = process.electronBinding('features')
|
const features = process.electronBinding('features')
|
||||||
|
|
||||||
const { getContentScripts } = require('@electron/internal/browser/chrome-extension')
|
|
||||||
const { crashReporterInit } = require('@electron/internal/browser/crash-reporter-init')
|
const { crashReporterInit } = require('@electron/internal/browser/crash-reporter-init')
|
||||||
const { ipcMainInternal } = require('@electron/internal/browser/ipc-main-internal')
|
const { ipcMainInternal } = require('@electron/internal/browser/ipc-main-internal')
|
||||||
const ipcMainUtils = require('@electron/internal/browser/ipc-main-internal-utils')
|
const ipcMainUtils = require('@electron/internal/browser/ipc-main-internal-utils')
|
||||||
|
@ -526,13 +525,24 @@ const getPreloadScript = async function (preloadPath) {
|
||||||
return { preloadPath, preloadSrc, preloadError }
|
return { preloadPath, preloadSrc, preloadError }
|
||||||
}
|
}
|
||||||
|
|
||||||
ipcMainUtils.handle('ELECTRON_GET_CONTENT_SCRIPTS', () => getContentScripts())
|
if (process.electronBinding('features').isExtensionsEnabled()) {
|
||||||
|
ipcMainUtils.handle('ELECTRON_GET_CONTENT_SCRIPTS', () => [])
|
||||||
|
} else {
|
||||||
|
const { getContentScripts } = require('@electron/internal/browser/chrome-extension')
|
||||||
|
ipcMainUtils.handle('ELECTRON_GET_CONTENT_SCRIPTS', () => getContentScripts())
|
||||||
|
}
|
||||||
|
|
||||||
ipcMainUtils.handle('ELECTRON_BROWSER_SANDBOX_LOAD', async function (event) {
|
ipcMainUtils.handle('ELECTRON_BROWSER_SANDBOX_LOAD', async function (event) {
|
||||||
const preloadPaths = event.sender._getPreloadPaths()
|
const preloadPaths = event.sender._getPreloadPaths()
|
||||||
|
|
||||||
|
let contentScripts = []
|
||||||
|
if (!process.electronBinding('features').isExtensionsEnabled()) {
|
||||||
|
const { getContentScripts } = require('@electron/internal/browser/chrome-extension')
|
||||||
|
contentScripts = getContentScripts()
|
||||||
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
contentScripts: getContentScripts(),
|
contentScripts,
|
||||||
preloadScripts: await Promise.all(preloadPaths.map(path => getPreloadScript(path))),
|
preloadScripts: await Promise.all(preloadPaths.map(path => getPreloadScript(path))),
|
||||||
isRemoteModuleEnabled: isRemoteModuleEnabled(event.sender),
|
isRemoteModuleEnabled: isRemoteModuleEnabled(event.sender),
|
||||||
isWebViewTagEnabled: guestViewManager.isWebViewTagEnabled(event.sender),
|
isWebViewTagEnabled: guestViewManager.isWebViewTagEnabled(event.sender),
|
||||||
|
|
|
@ -67,6 +67,10 @@ class Port {
|
||||||
|
|
||||||
// Inject chrome API to the |context|
|
// Inject chrome API to the |context|
|
||||||
export function injectTo (extensionId: string, context: any) {
|
export function injectTo (extensionId: string, context: any) {
|
||||||
|
if (process.electronBinding('features').isExtensionsEnabled()) {
|
||||||
|
throw new Error('Attempted to load JS chrome-extension polyfill with //extensions support enabled')
|
||||||
|
}
|
||||||
|
|
||||||
const chrome = context.chrome = context.chrome || {}
|
const chrome = context.chrome = context.chrome || {}
|
||||||
|
|
||||||
ipcRendererInternal.on(`CHROME_RUNTIME_ONCONNECT_${extensionId}`, (
|
ipcRendererInternal.on(`CHROME_RUNTIME_ONCONNECT_${extensionId}`, (
|
||||||
|
|
|
@ -101,7 +101,9 @@ switch (window.location.protocol) {
|
||||||
}
|
}
|
||||||
case 'chrome-extension:': {
|
case 'chrome-extension:': {
|
||||||
// Inject the chrome.* APIs that chrome extensions require
|
// Inject the chrome.* APIs that chrome extensions require
|
||||||
require('@electron/internal/renderer/chrome-api').injectTo(window.location.hostname, window)
|
if (!process.electronBinding('features').isExtensionsEnabled()) {
|
||||||
|
require('@electron/internal/renderer/chrome-api').injectTo(window.location.hostname, window)
|
||||||
|
}
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
case 'chrome:':
|
case 'chrome:':
|
||||||
|
@ -112,8 +114,10 @@ switch (window.location.protocol) {
|
||||||
windowSetup(guestInstanceId, openerId, isHiddenPage, usesNativeWindowOpen)
|
windowSetup(guestInstanceId, openerId, isHiddenPage, usesNativeWindowOpen)
|
||||||
|
|
||||||
// Inject content scripts.
|
// Inject content scripts.
|
||||||
const contentScripts = ipcRendererUtils.invokeSync('ELECTRON_GET_CONTENT_SCRIPTS') as Electron.ContentScriptEntry[]
|
if (!process.electronBinding('features').isExtensionsEnabled()) {
|
||||||
require('@electron/internal/renderer/content-scripts-injector')(contentScripts)
|
const contentScripts = ipcRendererUtils.invokeSync('ELECTRON_GET_CONTENT_SCRIPTS') as Electron.ContentScriptEntry[]
|
||||||
|
require('@electron/internal/renderer/content-scripts-injector')(contentScripts)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -116,7 +116,9 @@ switch (window.location.protocol) {
|
||||||
}
|
}
|
||||||
case 'chrome-extension:': {
|
case 'chrome-extension:': {
|
||||||
// Inject the chrome.* APIs that chrome extensions require
|
// Inject the chrome.* APIs that chrome extensions require
|
||||||
require('@electron/internal/renderer/chrome-api').injectTo(window.location.hostname, window)
|
if (!process.electronBinding('features').isExtensionsEnabled()) {
|
||||||
|
require('@electron/internal/renderer/chrome-api').injectTo(window.location.hostname, window)
|
||||||
|
}
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
case 'chrome': {
|
case 'chrome': {
|
||||||
|
@ -124,7 +126,9 @@ switch (window.location.protocol) {
|
||||||
}
|
}
|
||||||
default: {
|
default: {
|
||||||
// Inject content scripts.
|
// Inject content scripts.
|
||||||
require('@electron/internal/renderer/content-scripts-injector')(contentScripts)
|
if (!process.electronBinding('features').isExtensionsEnabled()) {
|
||||||
|
require('@electron/internal/renderer/content-scripts-injector')(contentScripts)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,6 +13,7 @@
|
||||||
#include "base/trace_event/trace_event.h"
|
#include "base/trace_event/trace_event.h"
|
||||||
#include "content/public/renderer/render_frame.h"
|
#include "content/public/renderer/render_frame.h"
|
||||||
#include "content/public/renderer/render_view.h"
|
#include "content/public/renderer/render_view.h"
|
||||||
|
#include "electron/buildflags/buildflags.h"
|
||||||
#include "electron/shell/common/api/api.mojom.h"
|
#include "electron/shell/common/api/api.mojom.h"
|
||||||
#include "ipc/ipc_message_macros.h"
|
#include "ipc/ipc_message_macros.h"
|
||||||
#include "native_mate/dictionary.h"
|
#include "native_mate/dictionary.h"
|
||||||
|
@ -85,11 +86,13 @@ void AtomRenderFrameObserver::DidCreateScriptContext(
|
||||||
renderer_client_->SetupMainWorldOverrides(context, render_frame_);
|
renderer_client_->SetupMainWorldOverrides(context, render_frame_);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if !BUILDFLAG(ENABLE_ELECTRON_EXTENSIONS)
|
||||||
if (world_id >= World::ISOLATED_WORLD_EXTENSIONS &&
|
if (world_id >= World::ISOLATED_WORLD_EXTENSIONS &&
|
||||||
world_id <= World::ISOLATED_WORLD_EXTENSIONS_END) {
|
world_id <= World::ISOLATED_WORLD_EXTENSIONS_END) {
|
||||||
renderer_client_->SetupExtensionWorldOverrides(context, render_frame_,
|
renderer_client_->SetupExtensionWorldOverrides(context, render_frame_,
|
||||||
world_id);
|
world_id);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void AtomRenderFrameObserver::DraggableRegionsChanged() {
|
void AtomRenderFrameObserver::DraggableRegionsChanged() {
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
#include "base/command_line.h"
|
#include "base/command_line.h"
|
||||||
#include "content/public/renderer/render_frame.h"
|
#include "content/public/renderer/render_frame.h"
|
||||||
|
#include "electron/buildflags/buildflags.h"
|
||||||
#include "native_mate/dictionary.h"
|
#include "native_mate/dictionary.h"
|
||||||
#include "shell/common/api/electron_bindings.h"
|
#include "shell/common/api/electron_bindings.h"
|
||||||
#include "shell/common/api/event_emitter_caller.h"
|
#include "shell/common/api/event_emitter_caller.h"
|
||||||
|
@ -225,6 +226,9 @@ void AtomRendererClient::SetupExtensionWorldOverrides(
|
||||||
v8::Handle<v8::Context> context,
|
v8::Handle<v8::Context> context,
|
||||||
content::RenderFrame* render_frame,
|
content::RenderFrame* render_frame,
|
||||||
int world_id) {
|
int world_id) {
|
||||||
|
#if BUILDFLAG(ENABLE_ELECTRON_EXTENSIONS)
|
||||||
|
NOTREACHED();
|
||||||
|
#else
|
||||||
auto* isolate = context->GetIsolate();
|
auto* isolate = context->GetIsolate();
|
||||||
|
|
||||||
std::vector<v8::Local<v8::String>> isolated_bundle_params = {
|
std::vector<v8::Local<v8::String>> isolated_bundle_params = {
|
||||||
|
@ -244,6 +248,7 @@ void AtomRendererClient::SetupExtensionWorldOverrides(
|
||||||
node::native_module::NativeModuleEnv::CompileAndCall(
|
node::native_module::NativeModuleEnv::CompileAndCall(
|
||||||
context, "electron/js2c/content_script_bundle", &isolated_bundle_params,
|
context, "electron/js2c/content_script_bundle", &isolated_bundle_params,
|
||||||
&isolated_bundle_args, nullptr);
|
&isolated_bundle_args, nullptr);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
node::Environment* AtomRendererClient::GetEnvironment(
|
node::Environment* AtomRendererClient::GetEnvironment(
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
#include "base/path_service.h"
|
#include "base/path_service.h"
|
||||||
#include "base/process/process_handle.h"
|
#include "base/process/process_handle.h"
|
||||||
#include "content/public/renderer/render_frame.h"
|
#include "content/public/renderer/render_frame.h"
|
||||||
|
#include "electron/buildflags/buildflags.h"
|
||||||
#include "gin/converter.h"
|
#include "gin/converter.h"
|
||||||
#include "native_mate/dictionary.h"
|
#include "native_mate/dictionary.h"
|
||||||
#include "shell/common/api/electron_bindings.h"
|
#include "shell/common/api/electron_bindings.h"
|
||||||
|
@ -266,6 +267,9 @@ void AtomSandboxedRendererClient::SetupExtensionWorldOverrides(
|
||||||
v8::Handle<v8::Context> context,
|
v8::Handle<v8::Context> context,
|
||||||
content::RenderFrame* render_frame,
|
content::RenderFrame* render_frame,
|
||||||
int world_id) {
|
int world_id) {
|
||||||
|
#if BUILDFLAG(ENABLE_ELECTRON_EXTENSIONS)
|
||||||
|
NOTREACHED();
|
||||||
|
#else
|
||||||
auto* isolate = context->GetIsolate();
|
auto* isolate = context->GetIsolate();
|
||||||
|
|
||||||
mate::Dictionary process = mate::Dictionary::CreateEmpty(isolate);
|
mate::Dictionary process = mate::Dictionary::CreateEmpty(isolate);
|
||||||
|
@ -284,6 +288,7 @@ void AtomSandboxedRendererClient::SetupExtensionWorldOverrides(
|
||||||
node::native_module::NativeModuleEnv::CompileAndCall(
|
node::native_module::NativeModuleEnv::CompileAndCall(
|
||||||
context, "electron/js2c/content_script_bundle", &isolated_bundle_params,
|
context, "electron/js2c/content_script_bundle", &isolated_bundle_params,
|
||||||
&isolated_bundle_args, nullptr);
|
&isolated_bundle_args, nullptr);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void AtomSandboxedRendererClient::WillReleaseScriptContext(
|
void AtomSandboxedRendererClient::WillReleaseScriptContext(
|
||||||
|
|
Loading…
Reference in a new issue