fix: emit will-navigate for sandboxed contents (#22188)

This commit is contained in:
Jeremy Apthorp 2020-02-21 11:08:26 -08:00 committed by GitHub
parent 8045152e59
commit a25d7fa440
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 187 additions and 104 deletions

View file

@ -292,8 +292,21 @@ content::WebContents* CommonWebContentsDelegate::OpenURLFromTab(
load_url_params.should_replace_current_entry = load_url_params.should_replace_current_entry =
params.should_replace_current_entry; params.should_replace_current_entry;
load_url_params.is_renderer_initiated = params.is_renderer_initiated; load_url_params.is_renderer_initiated = params.is_renderer_initiated;
load_url_params.started_from_context_menu = params.started_from_context_menu;
load_url_params.initiator_origin = params.initiator_origin; load_url_params.initiator_origin = params.initiator_origin;
load_url_params.should_clear_history_list = true; load_url_params.source_site_instance = params.source_site_instance;
load_url_params.frame_tree_node_id = params.frame_tree_node_id;
load_url_params.redirect_chain = params.redirect_chain;
load_url_params.has_user_gesture = params.user_gesture;
load_url_params.blob_url_loader_factory = params.blob_url_loader_factory;
load_url_params.href_translate = params.href_translate;
load_url_params.reload_type = params.reload_type;
if (params.post_data) {
load_url_params.load_type =
content::NavigationController::LOAD_TYPE_HTTP_POST;
load_url_params.post_data = params.post_data;
}
source->GetController().LoadURLWithParams(load_url_params); source->GetController().LoadURLWithParams(load_url_params);
return source; return source;

View file

@ -291,4 +291,12 @@ void ElectronSandboxedRendererClient::WillReleaseScriptContext(
InvokeHiddenCallback(context, kLifecycleKey, "onExit"); InvokeHiddenCallback(context, kLifecycleKey, "onExit");
} }
bool ElectronSandboxedRendererClient::ShouldFork(blink::WebLocalFrame* frame,
const GURL& url,
const std::string& http_method,
bool is_initial_navigation,
bool is_server_redirect) {
return true;
}
} // namespace electron } // namespace electron

View file

@ -37,6 +37,11 @@ class ElectronSandboxedRendererClient : public RendererClientBase {
void RenderViewCreated(content::RenderView*) override; void RenderViewCreated(content::RenderView*) override;
void RunScriptsAtDocumentStart(content::RenderFrame* render_frame) override; void RunScriptsAtDocumentStart(content::RenderFrame* render_frame) override;
void RunScriptsAtDocumentEnd(content::RenderFrame* render_frame) override; void RunScriptsAtDocumentEnd(content::RenderFrame* render_frame) override;
bool ShouldFork(blink::WebLocalFrame* frame,
const GURL& url,
const std::string& http_method,
bool is_initial_navigation,
bool is_server_redirect) override;
private: private:
std::unique_ptr<base::ProcessMetrics> metrics_; std::unique_ptr<base::ProcessMetrics> metrics_;

View file

@ -434,10 +434,11 @@ describe('BrowserWindow module', () => {
}) })
}) })
describe('navigation events', () => { for (const sandbox of [false, true]) {
describe(`navigation events${sandbox ? ' with sandbox' : ''}`, () => {
let w = null as unknown as BrowserWindow let w = null as unknown as BrowserWindow
beforeEach(() => { beforeEach(() => {
w = new BrowserWindow({ show: false, webPreferences: { nodeIntegration: true } }) w = new BrowserWindow({ show: false, webPreferences: { nodeIntegration: false, sandbox } })
}) })
afterEach(async () => { afterEach(async () => {
await closeWindow(w) await closeWindow(w)
@ -445,6 +446,20 @@ describe('BrowserWindow module', () => {
}) })
describe('will-navigate event', () => { describe('will-navigate event', () => {
let server = null as unknown as http.Server
let url = null as unknown as string
before((done) => {
server = http.createServer((req, res) => { res.end('') })
server.listen(0, '127.0.0.1', () => {
url = `http://127.0.0.1:${(server.address() as AddressInfo).port}/`
done()
})
})
after(() => {
server.close()
})
it('allows the window to be closed from the event listener', (done) => { it('allows the window to be closed from the event listener', (done) => {
w.webContents.once('will-navigate', () => { w.webContents.once('will-navigate', () => {
w.close() w.close()
@ -452,6 +467,48 @@ describe('BrowserWindow module', () => {
}) })
w.loadFile(path.join(fixtures, 'pages', 'will-navigate.html')) w.loadFile(path.join(fixtures, 'pages', 'will-navigate.html'))
}) })
it('can be prevented', (done) => {
let willNavigate = false
w.webContents.once('will-navigate', (e) => {
willNavigate = true
e.preventDefault()
})
w.webContents.on('did-stop-loading', () => {
if (willNavigate) {
// i.e. it shouldn't have had '?navigated' appended to it.
expect(w.webContents.getURL().endsWith('will-navigate.html')).to.be.true()
done()
}
})
w.loadFile(path.join(fixtures, 'pages', 'will-navigate.html'))
})
it('is triggered when navigating from file: to http:', async () => {
await w.loadFile(path.join(fixtures, 'api', 'blank.html'))
w.webContents.executeJavaScript(`location.href = ${JSON.stringify(url)}`)
const navigatedTo = await new Promise(resolve => {
w.webContents.once('will-navigate', (e, url) => {
e.preventDefault()
resolve(url)
})
})
expect(navigatedTo).to.equal(url)
expect(w.webContents.getURL()).to.match(/^file:/)
})
it('is triggered when navigating from about:blank to http:', async () => {
await w.loadURL('about:blank')
w.webContents.executeJavaScript(`location.href = ${JSON.stringify(url)}`)
const navigatedTo = await new Promise(resolve => {
w.webContents.once('will-navigate', (e, url) => {
e.preventDefault()
resolve(url)
})
})
expect(navigatedTo).to.equal(url)
expect(w.webContents.getURL()).to.equal('about:blank')
})
}) })
describe('will-redirect event', () => { describe('will-redirect event', () => {
@ -538,6 +595,7 @@ describe('BrowserWindow module', () => {
}) })
}) })
}) })
}
describe('focus and visibility', () => { describe('focus and visibility', () => {
let w = null as unknown as BrowserWindow let w = null as unknown as BrowserWindow
@ -2088,8 +2146,7 @@ describe('BrowserWindow module', () => {
'did-finish-load', 'did-finish-load',
'did-frame-finish-load', 'did-frame-finish-load',
'did-navigate-in-page', 'did-navigate-in-page',
// TODO(nornagon): sandboxed pages should also emit will-navigate 'will-navigate',
// 'will-navigate',
'did-start-loading', 'did-start-loading',
'did-stop-loading', 'did-stop-loading',
'did-frame-finish-load', 'did-frame-finish-load',

View file

@ -1,7 +1,7 @@
<html> <html>
<body> <body>
<script type="text/javascript" charset="utf-8"> <script type="text/javascript" charset="utf-8">
location.reload(); location.href += '?navigated'
</script> </script>
</body> </body>
</html> </html>