2019-10-28 22:12:35 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2020-02-06 07:05:30 +00:00
|
|
|
From: Shelley Vohr <shelley.vohr@gmail.com>
|
|
|
|
Date: Tue, 4 Feb 2020 08:59:32 -0700
|
2019-10-28 22:12:35 +00:00
|
|
|
Subject: Revert "Remove ContentRendererClient::ShouldFork."
|
|
|
|
|
2020-02-06 07:05:30 +00:00
|
|
|
This reverts the CL at https://chromium-review.googlesource.com/c/chromium/src/+/1812128.
|
|
|
|
We use it to force a new renderer process for navigations, and need to start a new renderer process
|
|
|
|
for every navigation to keep Node.js working properly. Once Native Modules in the renderer process
|
|
|
|
are required to be NAPI or context aware (Electron v11), this patch can be removed.
|
2019-10-28 22:12:35 +00:00
|
|
|
|
|
|
|
diff --git a/chrome/renderer/chrome_content_renderer_client.cc b/chrome/renderer/chrome_content_renderer_client.cc
|
2021-01-12 23:31:23 +00:00
|
|
|
index fea876ec7fa3cf0d3c11dad64750837b28658bef..a87d23b7d2171663fa55c78d390bc3b8279a04f1 100644
|
2019-10-28 22:12:35 +00:00
|
|
|
--- a/chrome/renderer/chrome_content_renderer_client.cc
|
|
|
|
+++ b/chrome/renderer/chrome_content_renderer_client.cc
|
2021-01-12 23:31:23 +00:00
|
|
|
@@ -1277,6 +1277,25 @@ ChromeContentRendererClient::GetProtocolHandlerSecurityLevel() {
|
2020-02-06 07:05:30 +00:00
|
|
|
#endif
|
|
|
|
}
|
2019-10-28 22:12:35 +00:00
|
|
|
|
2020-02-06 07:05:30 +00:00
|
|
|
+bool ChromeContentRendererClient::ShouldFork(WebLocalFrame* frame,
|
|
|
|
+ const GURL& url,
|
|
|
|
+ const std::string& http_method,
|
|
|
|
+ bool is_initial_navigation,
|
|
|
|
+ bool is_server_redirect) {
|
2019-10-28 22:12:35 +00:00
|
|
|
+ DCHECK(!frame->Parent());
|
|
|
|
+
|
|
|
|
+ // If |url| matches one of the prerendered URLs, stop this navigation and try
|
|
|
|
+ // to swap in the prerendered page on the browser process. If the prerendered
|
|
|
|
+ // page no longer exists by the time the OpenURL IPC is handled, a normal
|
|
|
|
+ // navigation is attempted.
|
|
|
|
+ if (prerender_dispatcher_.get() &&
|
|
|
|
+ prerender_dispatcher_->IsPrerenderURL(url)) {
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+
|
2020-02-06 07:05:30 +00:00
|
|
|
+ return false;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
void ChromeContentRendererClient::WillSendRequest(
|
|
|
|
WebLocalFrame* frame,
|
|
|
|
ui::PageTransition transition_type,
|
|
|
|
diff --git a/chrome/renderer/chrome_content_renderer_client.h b/chrome/renderer/chrome_content_renderer_client.h
|
2020-12-14 18:57:36 +00:00
|
|
|
index 857b350afe980dd79e4c76ebd3cb1be461457f0a..1cac9fc1d8d92d5afe02aa1d1dba05895d4d2672 100644
|
2020-02-06 07:05:30 +00:00
|
|
|
--- a/chrome/renderer/chrome_content_renderer_client.h
|
|
|
|
+++ b/chrome/renderer/chrome_content_renderer_client.h
|
2020-10-28 00:33:04 +00:00
|
|
|
@@ -122,6 +122,11 @@ class ChromeContentRendererClient
|
2020-02-06 07:05:30 +00:00
|
|
|
base::SingleThreadTaskRunner* compositor_thread_task_runner) override;
|
|
|
|
bool RunIdleHandlerWhenWidgetsHidden() override;
|
|
|
|
bool AllowPopup() override;
|
|
|
|
+ bool ShouldFork(blink::WebLocalFrame* frame,
|
2020-11-14 00:16:56 +00:00
|
|
|
+ const GURL& url,
|
|
|
|
+ const std::string& http_method,
|
|
|
|
+ bool is_initial_navigation,
|
|
|
|
+ bool is_server_redirect) override;
|
|
|
|
blink::ProtocolHandlerSecurityLevel GetProtocolHandlerSecurityLevel()
|
|
|
|
override;
|
2020-02-06 07:05:30 +00:00
|
|
|
void WillSendRequest(blink::WebLocalFrame* frame,
|
|
|
|
diff --git a/content/public/renderer/content_renderer_client.cc b/content/public/renderer/content_renderer_client.cc
|
2020-12-22 22:14:44 +00:00
|
|
|
index 78174b924c7b8429d1400b51f4a560d750cc0af6..20eee821969cfa32a61cc0c16e216d3821253d77 100644
|
2020-02-06 07:05:30 +00:00
|
|
|
--- a/content/public/renderer/content_renderer_client.cc
|
|
|
|
+++ b/content/public/renderer/content_renderer_client.cc
|
2020-12-22 22:14:44 +00:00
|
|
|
@@ -117,6 +117,14 @@ bool ContentRendererClient::HandleNavigation(
|
2019-10-28 22:12:35 +00:00
|
|
|
}
|
2020-02-06 07:05:30 +00:00
|
|
|
#endif
|
2019-10-28 22:12:35 +00:00
|
|
|
|
2020-02-06 07:05:30 +00:00
|
|
|
+bool ContentRendererClient::ShouldFork(blink::WebLocalFrame* frame,
|
|
|
|
+ const GURL& url,
|
|
|
|
+ const std::string& http_method,
|
|
|
|
+ bool is_initial_navigation,
|
|
|
|
+ bool is_server_redirect) {
|
|
|
|
+ return false;
|
2019-10-28 22:12:35 +00:00
|
|
|
+}
|
|
|
|
+
|
2020-02-06 07:05:30 +00:00
|
|
|
void ContentRendererClient::WillSendRequest(
|
|
|
|
blink::WebLocalFrame* frame,
|
|
|
|
ui::PageTransition transition_type,
|
|
|
|
diff --git a/content/public/renderer/content_renderer_client.h b/content/public/renderer/content_renderer_client.h
|
2020-12-14 18:57:36 +00:00
|
|
|
index 16d0dd4456f214b14fbdf224ba938ebb1cb63106..4dc340938d54597a315ebb441d769dccb398757d 100644
|
2020-02-06 07:05:30 +00:00
|
|
|
--- a/content/public/renderer/content_renderer_client.h
|
|
|
|
+++ b/content/public/renderer/content_renderer_client.h
|
2020-10-28 00:33:04 +00:00
|
|
|
@@ -210,6 +210,13 @@ class CONTENT_EXPORT ContentRendererClient {
|
2020-02-06 07:05:30 +00:00
|
|
|
bool is_redirect);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
+ // Returns true if we should fork a new process for the given navigation.
|
|
|
|
+ virtual bool ShouldFork(blink::WebLocalFrame* frame,
|
|
|
|
+ const GURL& url,
|
|
|
|
+ const std::string& http_method,
|
|
|
|
+ bool is_initial_navigation,
|
|
|
|
+ bool is_server_redirect);
|
|
|
|
+
|
|
|
|
// Notifies the embedder that the given frame is requesting the resource at
|
|
|
|
// |url|. If the function returns a valid |new_url|, the request must be
|
2020-12-14 18:57:36 +00:00
|
|
|
// updated to use it.
|
2020-02-06 07:05:30 +00:00
|
|
|
diff --git a/content/renderer/render_frame_impl.cc b/content/renderer/render_frame_impl.cc
|
2021-01-12 23:31:23 +00:00
|
|
|
index 74301e21452af01ebbd5f945610c75cf66aed8a9..fd0e06f2b56b9380b2aef25118976dc137f6f4b0 100644
|
2020-02-06 07:05:30 +00:00
|
|
|
--- a/content/renderer/render_frame_impl.cc
|
|
|
|
+++ b/content/renderer/render_frame_impl.cc
|
2021-01-12 23:31:23 +00:00
|
|
|
@@ -5461,6 +5461,23 @@ void RenderFrameImpl::BeginNavigation(
|
2020-04-24 01:55:17 +00:00
|
|
|
// we can do a per-frame check here rather than a process-wide check.
|
2020-02-06 07:05:30 +00:00
|
|
|
bool should_fork = HasWebUIScheme(url) || HasWebUIScheme(old_url) ||
|
2020-04-24 01:55:17 +00:00
|
|
|
(enabled_bindings_ & kWebUIBindingsPolicyMask);
|
2019-10-28 22:12:35 +00:00
|
|
|
+
|
2020-02-06 07:05:30 +00:00
|
|
|
+ if (!should_fork && url.SchemeIs(url::kFileScheme)) {
|
|
|
|
+ // Fork non-file to file opens (see https://crbug.com/1031119). Note that
|
|
|
|
+ // this may fork unnecessarily if another tab (hosting a file or not)
|
|
|
|
+ // targeted this one before its initial navigation, but that shouldn't
|
|
|
|
+ // cause a problem.
|
|
|
|
+ should_fork = !old_url.SchemeIs(url::kFileScheme);
|
|
|
|
+ }
|
2019-10-28 22:12:35 +00:00
|
|
|
+
|
2020-02-06 07:05:30 +00:00
|
|
|
+ if (!should_fork) {
|
|
|
|
+ // Give the embedder a chance.
|
|
|
|
+ bool is_initial_navigation = render_view_->history_list_length_ == 0;
|
|
|
|
+ should_fork = GetContentClient()->renderer()->ShouldFork(
|
|
|
|
+ frame_, url, info->url_request.HttpMethod().Utf8(),
|
|
|
|
+ is_initial_navigation, false /* is_redirect */);
|
|
|
|
+ }
|
2019-10-28 22:12:35 +00:00
|
|
|
+
|
2020-02-06 07:05:30 +00:00
|
|
|
if (should_fork) {
|
|
|
|
OpenURL(std::move(info));
|
|
|
|
return; // Suppress the load here.
|