From 33325e3608bdc4f45798817643ff9c94279656d6 Mon Sep 17 00:00:00 2001 From: Robo Date: Tue, 23 Aug 2022 10:25:57 +0900 Subject: [PATCH] fix: undefined details.requestingUrl from session.setPermissionCheckHandler (#35281) fix: undefined details.requestingUrl from setPermissionCheckHandler --- shell/browser/electron_permission_manager.cc | 13 ++- spec/api-session-spec.ts | 86 +++++++++++++++++++- 2 files changed, 95 insertions(+), 4 deletions(-) diff --git a/shell/browser/electron_permission_manager.cc b/shell/browser/electron_permission_manager.cc index 74c523b54a3e..dde2714caec0 100644 --- a/shell/browser/electron_permission_manager.cc +++ b/shell/browser/electron_permission_manager.cc @@ -339,9 +339,16 @@ blink::mojom::PermissionStatus ElectronPermissionManager::GetPermissionStatusForCurrentDocument( blink::PermissionType permission, content::RenderFrameHost* render_frame_host) { - return GetPermissionStatus( - permission, render_frame_host->GetLastCommittedOrigin().GetURL(), - content::PermissionUtil::GetLastCommittedOriginAsURL(render_frame_host)); + base::Value::Dict details; + details.Set("embeddingOrigin", + content::PermissionUtil::GetLastCommittedOriginAsURL( + render_frame_host->GetMainFrame()) + .spec()); + bool granted = CheckPermissionWithDetails( + permission, render_frame_host, + render_frame_host->GetLastCommittedOrigin().GetURL(), std::move(details)); + return granted ? blink::mojom::PermissionStatus::GRANTED + : blink::mojom::PermissionStatus::DENIED; } blink::mojom::PermissionStatus diff --git a/spec/api-session-spec.ts b/spec/api-session-spec.ts index 1046b1377a15..1aa8fdc6fd34 100644 --- a/spec/api-session-spec.ts +++ b/spec/api-session-spec.ts @@ -4,7 +4,7 @@ import * as https from 'https'; import * as path from 'path'; import * as fs from 'fs'; import * as ChildProcess from 'child_process'; -import { app, session, BrowserWindow, net, ipcMain, Session } from 'electron/main'; +import { app, session, BrowserWindow, net, ipcMain, Session, webFrameMain, WebFrameMain } from 'electron/main'; import * as send from 'send'; import * as auth from 'basic-auth'; import { closeAllWindows } from './window-helpers'; @@ -1043,6 +1043,90 @@ describe('session module', () => { }); }); + describe('ses.setPermissionCheckHandler(handler)', () => { + afterEach(closeAllWindows); + it('details provides requestingURL for mainFrame', async () => { + const w = new BrowserWindow({ + show: false, + webPreferences: { + partition: 'very-temp-permission-handler' + } + }); + const ses = w.webContents.session; + const loadUrl = 'https://myfakesite/'; + let handlerDetails : Electron.PermissionCheckHandlerHandlerDetails; + + ses.protocol.interceptStringProtocol('https', (req, cb) => { + cb(''); + }); + + ses.setPermissionCheckHandler((wc, permission, requestingOrigin, details) => { + if (permission === 'clipboard-read') { + handlerDetails = details; + return true; + } + return false; + }); + + const readClipboardPermission: any = () => { + return w.webContents.executeJavaScript(` + navigator.permissions.query({name: 'clipboard-read'}) + .then(permission => permission.state).catch(err => err.message); + `, true); + }; + + await w.loadURL(loadUrl); + const state = await readClipboardPermission(); + expect(state).to.equal('granted'); + expect(handlerDetails!.requestingUrl).to.equal(loadUrl); + }); + + it('details provides requestingURL for cross origin subFrame', async () => { + const w = new BrowserWindow({ + show: false, + webPreferences: { + partition: 'very-temp-permission-handler' + } + }); + const ses = w.webContents.session; + const loadUrl = 'https://myfakesite/'; + let handlerDetails : Electron.PermissionCheckHandlerHandlerDetails; + + ses.protocol.interceptStringProtocol('https', (req, cb) => { + cb(''); + }); + + ses.setPermissionCheckHandler((wc, permission, requestingOrigin, details) => { + if (permission === 'clipboard-read') { + handlerDetails = details; + return true; + } + return false; + }); + + const readClipboardPermission: any = (frame: WebFrameMain) => { + return frame.executeJavaScript(` + navigator.permissions.query({name: 'clipboard-read'}) + .then(permission => permission.state).catch(err => err.message); + `, true); + }; + + await w.loadFile(path.join(fixtures, 'api', 'blank.html')); + w.webContents.executeJavaScript(` + var iframe = document.createElement('iframe'); + iframe.src = '${loadUrl}'; + document.body.appendChild(iframe); + null; + `); + const [,, frameProcessId, frameRoutingId] = await emittedOnce(w.webContents, 'did-frame-finish-load'); + const state = await readClipboardPermission(webFrameMain.fromId(frameProcessId, frameRoutingId)); + expect(state).to.equal('granted'); + expect(handlerDetails!.requestingUrl).to.equal(loadUrl); + expect(handlerDetails!.isMainFrame).to.be.false(); + expect(handlerDetails!.embeddingOrigin).to.equal('file:///'); + }); + }); + describe('ses.isPersistent()', () => { afterEach(closeAllWindows);