From 305e3aad402d14678b63f8cdf36f86a9c2f42d12 Mon Sep 17 00:00:00 2001 From: Cheng Zhao Date: Mon, 23 Jul 2018 18:08:36 +0900 Subject: [PATCH] refactor: remove private webContents.getId() API (#13674) --- atom/browser/api/atom_api_web_contents.cc | 14 +------------- atom/browser/api/atom_api_web_contents.h | 3 --- atom/browser/atom_browser_client.cc | 4 ---- atom/common/options_switches.cc | 3 --- atom/common/options_switches.h | 1 - lib/browser/guest-view-manager.js | 6 +++--- lib/browser/rpc-server.js | 5 ++--- lib/renderer/web-view/web-view.js | 1 - lib/sandboxed_renderer/init.js | 8 +------- spec/api-browser-window-spec.js | 2 +- spec/api-web-contents-spec.js | 8 ++++---- spec/webview-spec.js | 4 ++-- 12 files changed, 14 insertions(+), 45 deletions(-) diff --git a/atom/browser/api/atom_api_web_contents.cc b/atom/browser/api/atom_api_web_contents.cc index 9e613f4bb692..1fde7dc8d1aa 100644 --- a/atom/browser/api/atom_api_web_contents.cc +++ b/atom/browser/api/atom_api_web_contents.cc @@ -1103,17 +1103,6 @@ void WebContents::NavigationEntryCommitted( details.is_same_document, details.did_replace_entry); } -int64_t WebContents::GetIDForContents(content::WebContents* web_contents) { - int64_t process_id = web_contents->GetMainFrame()->GetProcess()->GetID(); - int64_t routing_id = web_contents->GetMainFrame()->GetRoutingID(); - int64_t rv = (process_id << 32) + routing_id; - return rv; -} - -int64_t WebContents::GetID() const { - return WebContents::GetIDForContents(web_contents()); -} - int WebContents::GetProcessID() const { return web_contents()->GetMainFrame()->GetProcess()->GetID(); } @@ -1129,7 +1118,7 @@ WebContents::Type WebContents::GetType() const { } bool WebContents::Equal(const WebContents* web_contents) const { - return GetID() == web_contents->GetID(); + return ID() == web_contents->ID(); } void WebContents::LoadURL(const GURL& url, const mate::Dictionary& options) { @@ -1992,7 +1981,6 @@ void WebContents::BuildPrototype(v8::Isolate* isolate, prototype->SetClassName(mate::StringToV8(isolate, "WebContents")); mate::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate()) .MakeDestroyable() - .SetMethod("getId", &WebContents::GetID) .SetMethod("getProcessId", &WebContents::GetProcessID) .SetMethod("getOSProcessId", &WebContents::GetOSProcessID) .SetMethod("equal", &WebContents::Equal) diff --git a/atom/browser/api/atom_api_web_contents.h b/atom/browser/api/atom_api_web_contents.h index 1e3c7a927adb..b6d939307ea3 100644 --- a/atom/browser/api/atom_api_web_contents.h +++ b/atom/browser/api/atom_api_web_contents.h @@ -98,12 +98,9 @@ class WebContents : public mate::TrackableObject, static void BuildPrototype(v8::Isolate* isolate, v8::Local prototype); - static int64_t GetIDForContents(content::WebContents* web_contents); - // Notifies to destroy any guest web contents before destroying self. void DestroyWebContents(bool async); - int64_t GetID() const; int GetProcessID() const; base::ProcessId GetOSProcessID() const; Type GetType() const; diff --git a/atom/browser/atom_browser_client.cc b/atom/browser/atom_browser_client.cc index d109b73033ce..c165eaa40361 100644 --- a/atom/browser/atom_browser_client.cc +++ b/atom/browser/atom_browser_client.cc @@ -344,10 +344,6 @@ void AtomBrowserClient::AppendExtraCommandLineSwitches( web_preferences->AppendCommandLineSwitches(command_line); SessionPreferences::AppendExtraCommandLineSwitches( web_contents->GetBrowserContext(), command_line); - - auto context_id = atom::api::WebContents::GetIDForContents(web_contents); - command_line->AppendSwitchASCII(switches::kContextId, - base::IntToString(context_id)); } } diff --git a/atom/common/options_switches.cc b/atom/common/options_switches.cc index 35e8f5e42cfc..fd5ae7c83d6e 100644 --- a/atom/common/options_switches.cc +++ b/atom/common/options_switches.cc @@ -188,9 +188,6 @@ const char kAppUserModelId[] = "app-user-model-id"; // The application path const char kAppPath[] = "app-path"; -// The context ID for this process -const char kContextId[] = "context-id"; - // The command line switch versions of the options. const char kBackgroundColor[] = "background-color"; const char kPreloadScript[] = "preload"; diff --git a/atom/common/options_switches.h b/atom/common/options_switches.h index c0d8f6dcf272..988defce9f5a 100644 --- a/atom/common/options_switches.h +++ b/atom/common/options_switches.h @@ -92,7 +92,6 @@ extern const char kRegisterServiceWorkerSchemes[]; extern const char kSecureSchemes[]; extern const char kAppUserModelId[]; extern const char kAppPath[]; -extern const char kContextId[]; extern const char kBackgroundColor[]; extern const char kPreloadScript[]; diff --git a/lib/browser/guest-view-manager.js b/lib/browser/guest-view-manager.js index 1e448762686c..3e13e6ec3fc8 100644 --- a/lib/browser/guest-view-manager.js +++ b/lib/browser/guest-view-manager.js @@ -179,7 +179,7 @@ const createGuest = function (embedder, params) { const attachGuest = function (event, elementInstanceId, guestInstanceId, params) { const embedder = event.sender // Destroy the old guest when attaching. - const key = `${embedder.getId()}-${elementInstanceId}` + const key = `${embedder.id}-${elementInstanceId}` const oldGuestInstanceId = embedderElementsMap[key] if (oldGuestInstanceId != null) { // Reattachment to the same guest is just a no-op. @@ -199,7 +199,7 @@ const attachGuest = function (event, elementInstanceId, guestInstanceId, params) // If this guest is already attached to an element then remove it if (guestInstance.elementInstanceId) { - const oldKey = `${guestInstance.embedder.getId()}-${guestInstance.elementInstanceId}` + const oldKey = `${guestInstance.embedder.id}-${guestInstance.elementInstanceId}` delete embedderElementsMap[oldKey] // Remove guest from embedder if moving across web views @@ -290,7 +290,7 @@ const destroyGuest = function (embedder, guestInstanceId) { guestInstance.guest.destroy() delete guestInstances[guestInstanceId] - const key = `${embedder.getId()}-${guestInstance.elementInstanceId}` + const key = `${embedder.id}-${guestInstance.elementInstanceId}` delete embedderElementsMap[key] } diff --git a/lib/browser/rpc-server.js b/lib/browser/rpc-server.js index 31c38ed7ce14..91e1484411d2 100644 --- a/lib/browser/rpc-server.js +++ b/lib/browser/rpc-server.js @@ -210,9 +210,9 @@ const unwrapArgs = function (sender, contextId, args) { return rendererFunctions.get(objectId) } - const webContentsId = sender.getId() + const processId = sender.getProcessId() let callIntoRenderer = function (...args) { - if (!sender.isDestroyed() && webContentsId === sender.getId()) { + if (!sender.isDestroyed() && processId === sender.getProcessId()) { sender.send('ELECTRON_RENDERER_CALLBACK', contextId, meta.id, valueToMeta(sender, contextId, args)) } else { removeRemoteListenersAndLogWarning(this, meta, callIntoRenderer) @@ -453,7 +453,6 @@ ipcMain.on('ELECTRON_BROWSER_SANDBOX_LOAD', function (event, preloadPath) { event.returnValue = { preloadSrc: preloadSrc, preloadError: preloadError, - webContentsId: event.sender.getId(), platform: process.platform, execPath: process.execPath, env: process.env diff --git a/lib/renderer/web-view/web-view.js b/lib/renderer/web-view/web-view.js index c6db4cee1098..be9700921bdf 100644 --- a/lib/renderer/web-view/web-view.js +++ b/lib/renderer/web-view/web-view.js @@ -365,7 +365,6 @@ const registerWebViewElement = function () { 'replaceMisspelling', 'findInPage', 'stopFindInPage', - 'getId', 'downloadURL', 'inspectServiceWorker', 'print', diff --git a/lib/sandboxed_renderer/init.js b/lib/sandboxed_renderer/init.js index 7018ca897e39..1fbcc47b7e8c 100644 --- a/lib/sandboxed_renderer/init.js +++ b/lib/sandboxed_renderer/init.js @@ -36,15 +36,9 @@ const loadedModules = new Map([ ]) const { - preloadSrc, preloadError, webContentsId, platform, execPath, env + preloadSrc, preloadError, platform, execPath, env } = electron.ipcRenderer.sendSync('ELECTRON_BROWSER_SANDBOX_LOAD', preloadPath) -Object.defineProperty(process, 'webContentsId', { - configurable: false, - writable: false, - value: webContentsId -}) - require('../renderer/web-frame-init')() // Pass different process object to the preload script(which should not have diff --git a/spec/api-browser-window-spec.js b/spec/api-browser-window-spec.js index 36b98f5ff742..3306b1ae42f4 100644 --- a/spec/api-browser-window-spec.js +++ b/spec/api-browser-window-spec.js @@ -207,7 +207,7 @@ describe('BrowserWindow module', () => { const contents = w.webContents w.destroy() assert.throws(() => { - contents.getId() + contents.getProcessId() }, /Object has been destroyed/) }) }) diff --git a/spec/api-web-contents-spec.js b/spec/api-web-contents-spec.js index 2dc786753cf3..0ec5196c1da7 100644 --- a/spec/api-web-contents-spec.js +++ b/spec/api-web-contents-spec.js @@ -40,7 +40,7 @@ describe('webContents module', () => { it('returns an array of web contents', (done) => { w.webContents.on('devtools-opened', () => { const all = webContents.getAllWebContents().sort((a, b) => { - return a.getId() - b.getId() + return a.id - b.id }) assert.ok(all.length >= 4) @@ -61,15 +61,15 @@ describe('webContents module', () => { if (isCi) return done() const specWebContents = remote.getCurrentWebContents() - assert.equal(specWebContents.getId(), webContents.getFocusedWebContents().getId()) + assert.equal(specWebContents.id, webContents.getFocusedWebContents().id) specWebContents.once('devtools-opened', () => { - assert.equal(specWebContents.devToolsWebContents.getId(), webContents.getFocusedWebContents().getId()) + assert.equal(specWebContents.devToolsWebContents.id, webContents.getFocusedWebContents().id) specWebContents.closeDevTools() }) specWebContents.once('devtools-closed', () => { - assert.equal(specWebContents.getId(), webContents.getFocusedWebContents().getId()) + assert.equal(specWebContents.id, webContents.getFocusedWebContents().id) done() }) diff --git a/spec/webview-spec.js b/spec/webview-spec.js index 73ed7bb91aff..bfba27f12755 100644 --- a/spec/webview-spec.js +++ b/spec/webview-spec.js @@ -1035,7 +1035,7 @@ describe(' tag', function () { assert.ok(webview.partition) const listener = function (webContents, permission, callback) { - if (webContents.getId() === webview.getId()) { + if (webContents.id === webview.getWebContents().id) { // requestMIDIAccess with sysex requests both midi and midiSysex so // grant the first midi one and then reject the midiSysex one if (requestedPermission === 'midiSysex' && permission === 'midi') { @@ -1121,7 +1121,7 @@ describe(' tag', function () { webview.partition = 'permissionTest' webview.setAttribute('nodeintegration', 'on') session.fromPartition(webview.partition).setPermissionRequestHandler((webContents, permission, callback) => { - if (webContents.getId() === webview.getId()) { + if (webContents.id === webview.getWebContents().id) { assert.equal(permission, 'notifications') setTimeout(() => { callback(true) }, 10) }