can_create_window.patch 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
  2. From: Cheng Zhao <[email protected]>
  3. Date: Thu, 20 Sep 2018 17:45:32 -0700
  4. Subject: can_create_window.patch
  5. This adds a hook to the window creation flow so that Electron can intercede and
  6. potentially prevent a window from being created.
  7. TODO(loc): this patch is currently broken.
  8. diff --git a/content/browser/renderer_host/render_frame_host_impl.cc b/content/browser/renderer_host/render_frame_host_impl.cc
  9. index 980582453b8b269b75fde409cdf0101809097a74..6f5076ea646d356946c4789143fdbec538150051 100644
  10. --- a/content/browser/renderer_host/render_frame_host_impl.cc
  11. +++ b/content/browser/renderer_host/render_frame_host_impl.cc
  12. @@ -8225,6 +8225,7 @@ void RenderFrameHostImpl::CreateNewWindow(
  13. last_committed_origin_, params->window_container_type,
  14. params->target_url, params->referrer.To<Referrer>(),
  15. params->frame_name, params->disposition, *params->features,
  16. + params->raw_features, params->body,
  17. effective_transient_activation_state, params->opener_suppressed,
  18. &no_javascript_access);
  19. diff --git a/content/browser/web_contents/web_contents_impl.cc b/content/browser/web_contents/web_contents_impl.cc
  20. index c9222aedf46fce9cd5ba332825dd832da730caa9..38b5a462873a48d37ea11b1a3d41da46ef63284a 100644
  21. --- a/content/browser/web_contents/web_contents_impl.cc
  22. +++ b/content/browser/web_contents/web_contents_impl.cc
  23. @@ -4497,6 +4497,12 @@ FrameTree* WebContentsImpl::CreateNewWindow(
  24. auto* new_contents_impl = new_contents.get();
  25. + if (delegate_) {
  26. + delegate_->WebContentsCreatedWithFullParams(this, render_process_id,
  27. + opener->GetRoutingID(),
  28. + params, new_contents_impl);
  29. + }
  30. +
  31. // If the new frame has a name, make sure any SiteInstances that can find
  32. // this named frame have proxies for it. Must be called after
  33. // SetSessionStorageNamespace, since this calls CreateRenderView, which uses
  34. @@ -4538,12 +4544,6 @@ FrameTree* WebContentsImpl::CreateNewWindow(
  35. AddWebContentsDestructionObserver(new_contents_impl);
  36. }
  37. - if (delegate_) {
  38. - delegate_->WebContentsCreated(this, render_process_id,
  39. - opener->GetRoutingID(), params.frame_name,
  40. - params.target_url, new_contents_impl);
  41. - }
  42. -
  43. observers_.NotifyObservers(&WebContentsObserver::DidOpenRequestedURL,
  44. new_contents_impl, opener, params.target_url,
  45. params.referrer.To<Referrer>(), params.disposition,
  46. diff --git a/content/common/frame.mojom b/content/common/frame.mojom
  47. index ecdc75ae7888096922fb1ae1c86e9b80595d6570..feb8f08b44568f2c09359c8f3ec343fdec2615de 100644
  48. --- a/content/common/frame.mojom
  49. +++ b/content/common/frame.mojom
  50. @@ -609,6 +609,10 @@ struct CreateNewWindowParams {
  51. // The navigation initiator's user activation and ad status.
  52. blink.mojom.NavigationInitiatorActivationAndAdStatus
  53. initiator_activation_and_ad_status;
  54. +
  55. + // Extra fields added by Electron.
  56. + string raw_features;
  57. + network.mojom.URLRequestBody? body;
  58. };
  59. // Operation result when the renderer asks the browser to create a new window.
  60. diff --git a/content/public/browser/content_browser_client.cc b/content/public/browser/content_browser_client.cc
  61. index e7127ba48f8508a42cdfd9aabf88c353739419ea..39114bd91b4589a66544dd6aee579bc9dde79c7f 100644
  62. --- a/content/public/browser/content_browser_client.cc
  63. +++ b/content/public/browser/content_browser_client.cc
  64. @@ -709,6 +709,8 @@ bool ContentBrowserClient::CanCreateWindow(
  65. const std::string& frame_name,
  66. WindowOpenDisposition disposition,
  67. const blink::mojom::WindowFeatures& features,
  68. + const std::string& raw_features,
  69. + const scoped_refptr<network::ResourceRequestBody>& body,
  70. bool user_gesture,
  71. bool opener_suppressed,
  72. bool* no_javascript_access) {
  73. diff --git a/content/public/browser/content_browser_client.h b/content/public/browser/content_browser_client.h
  74. index 8d975e6cd75caedcbd5a276618c29867467a50c8..51cf95131a2637e5fd4ff2b22a258231db9e1528 100644
  75. --- a/content/public/browser/content_browser_client.h
  76. +++ b/content/public/browser/content_browser_client.h
  77. @@ -182,6 +182,7 @@ class NetworkService;
  78. class TrustedURLLoaderHeaderClient;
  79. } // namespace mojom
  80. struct ResourceRequest;
  81. +class ResourceRequestBody;
  82. } // namespace network
  83. namespace sandbox {
  84. @@ -1160,6 +1161,8 @@ class CONTENT_EXPORT ContentBrowserClient {
  85. const std::string& frame_name,
  86. WindowOpenDisposition disposition,
  87. const blink::mojom::WindowFeatures& features,
  88. + const std::string& raw_features,
  89. + const scoped_refptr<network::ResourceRequestBody>& body,
  90. bool user_gesture,
  91. bool opener_suppressed,
  92. bool* no_javascript_access);
  93. diff --git a/content/public/browser/web_contents_delegate.cc b/content/public/browser/web_contents_delegate.cc
  94. index 8c0e628124ad6068d95935ac4960f2d744adb3fd..aa401c609d1062cfd4149bbd7677f66a2554c3b4 100644
  95. --- a/content/public/browser/web_contents_delegate.cc
  96. +++ b/content/public/browser/web_contents_delegate.cc
  97. @@ -30,6 +30,17 @@ namespace content {
  98. WebContentsDelegate::WebContentsDelegate() = default;
  99. +void WebContentsDelegate::WebContentsCreatedWithFullParams(
  100. + WebContents* source_contents,
  101. + int opener_render_process_id,
  102. + int opener_render_frame_id,
  103. + const mojom::CreateNewWindowParams& params,
  104. + WebContents* new_contents) {
  105. + WebContentsCreated(source_contents, opener_render_process_id,
  106. + opener_render_frame_id, params.frame_name,
  107. + params.target_url, new_contents);
  108. +}
  109. +
  110. WebContents* WebContentsDelegate::OpenURLFromTab(WebContents* source,
  111. const OpenURLParams& params) {
  112. return nullptr;
  113. diff --git a/content/public/browser/web_contents_delegate.h b/content/public/browser/web_contents_delegate.h
  114. index 4b32bf8ccc4ed370e2d1a218ae1fd69a98e23636..b9168a2488f5c4977eba5856882b561e07195c7f 100644
  115. --- a/content/public/browser/web_contents_delegate.h
  116. +++ b/content/public/browser/web_contents_delegate.h
  117. @@ -16,6 +16,7 @@
  118. #include "base/memory/scoped_refptr.h"
  119. #include "build/build_config.h"
  120. #include "content/common/content_export.h"
  121. +#include "content/common/frame.mojom.h"
  122. #include "content/public/browser/eye_dropper.h"
  123. #include "content/public/browser/fullscreen_types.h"
  124. #include "content/public/browser/invalidate_type.h"
  125. @@ -345,6 +346,13 @@ class CONTENT_EXPORT WebContentsDelegate {
  126. const StoragePartitionConfig& partition_config,
  127. SessionStorageNamespace* session_storage_namespace);
  128. + virtual void WebContentsCreatedWithFullParams(
  129. + WebContents* source_contents,
  130. + int opener_render_process_id,
  131. + int opener_render_frame_id,
  132. + const mojom::CreateNewWindowParams& params,
  133. + WebContents* new_contents);
  134. +
  135. // Notifies the delegate about the creation of a new WebContents. This
  136. // typically happens when popups are created.
  137. virtual void WebContentsCreated(WebContents* source_contents,
  138. diff --git a/content/renderer/render_frame_impl.cc b/content/renderer/render_frame_impl.cc
  139. index f9d31235bebe8855b8f7698f9c0d3a1d92f77303..7697bf80f0c5ce35fae8eb015f8295cbbb384784 100644
  140. --- a/content/renderer/render_frame_impl.cc
  141. +++ b/content/renderer/render_frame_impl.cc
  142. @@ -6556,6 +6556,10 @@ WebView* RenderFrameImpl::CreateNewWindow(
  143. request.HasUserGesture(), GetWebFrame()->IsAdFrame(),
  144. GetWebFrame()->IsAdScriptInStack());
  145. + params->raw_features = features.raw_features.Utf8(
  146. + WTF::UTF8ConversionMode::kStrictUTF8ConversionReplacingUnpairedSurrogatesWithFFFD);
  147. + params->body = GetRequestBodyForWebURLRequest(request);
  148. +
  149. // We preserve this information before sending the message since |params| is
  150. // moved on send.
  151. bool is_background_tab =
  152. diff --git a/content/web_test/browser/web_test_content_browser_client.cc b/content/web_test/browser/web_test_content_browser_client.cc
  153. index bb2a4c21374db039eeb7ed10722933b155cdf486..00a117d18b69180ece2b1b65f92aad02ef045a86 100644
  154. --- a/content/web_test/browser/web_test_content_browser_client.cc
  155. +++ b/content/web_test/browser/web_test_content_browser_client.cc
  156. @@ -512,6 +512,8 @@ bool WebTestContentBrowserClient::CanCreateWindow(
  157. const std::string& frame_name,
  158. WindowOpenDisposition disposition,
  159. const blink::mojom::WindowFeatures& features,
  160. + const std::string& raw_features,
  161. + const scoped_refptr<network::ResourceRequestBody>& body,
  162. bool user_gesture,
  163. bool opener_suppressed,
  164. bool* no_javascript_access) {
  165. diff --git a/content/web_test/browser/web_test_content_browser_client.h b/content/web_test/browser/web_test_content_browser_client.h
  166. index cc7eb097097e44a0538853c46bb19810eb5a076c..74ecd32f27cd5e1ead4ab507d2b68a1088ba827f 100644
  167. --- a/content/web_test/browser/web_test_content_browser_client.h
  168. +++ b/content/web_test/browser/web_test_content_browser_client.h
  169. @@ -88,6 +88,8 @@ class WebTestContentBrowserClient : public ShellContentBrowserClient {
  170. const std::string& frame_name,
  171. WindowOpenDisposition disposition,
  172. const blink::mojom::WindowFeatures& features,
  173. + const std::string& raw_features,
  174. + const scoped_refptr<network::ResourceRequestBody>& body,
  175. bool user_gesture,
  176. bool opener_suppressed,
  177. bool* no_javascript_access) override;
  178. diff --git a/third_party/blink/public/web/web_window_features.h b/third_party/blink/public/web/web_window_features.h
  179. index bef5a989bac50c177f15f52fe87ac3790d553e85..65dcd2e3b51929400c8bfb6a98a4fb59bb6a3d6b 100644
  180. --- a/third_party/blink/public/web/web_window_features.h
  181. +++ b/third_party/blink/public/web/web_window_features.h
  182. @@ -34,6 +34,7 @@
  183. #include "third_party/abseil-cpp/absl/types/optional.h"
  184. #include "third_party/blink/public/platform/web_string.h"
  185. #include "third_party/blink/public/platform/web_vector.h"
  186. +#include "third_party/blink/renderer/platform/wtf/text/wtf_string.h"
  187. namespace blink {
  188. @@ -73,6 +74,8 @@ struct WebWindowFeatures {
  189. // TODO(apaseltiner): Investigate moving this field to a non-public struct
  190. // since it is only needed within //third_party/blink.
  191. absl::optional<WebVector<WebString>> attribution_srcs;
  192. +
  193. + String raw_features;
  194. };
  195. } // namespace blink
  196. diff --git a/third_party/blink/renderer/core/frame/local_dom_window.cc b/third_party/blink/renderer/core/frame/local_dom_window.cc
  197. index 533b96d14e0e4599b0a404eb2f74bce6fb12f983..378640bfa4bc6adabd34f2ee759e60a8ea376e72 100644
  198. --- a/third_party/blink/renderer/core/frame/local_dom_window.cc
  199. +++ b/third_party/blink/renderer/core/frame/local_dom_window.cc
  200. @@ -2203,6 +2203,8 @@ DOMWindow* LocalDOMWindow::open(v8::Isolate* isolate,
  201. WebWindowFeatures window_features =
  202. GetWindowFeaturesFromString(features, entered_window);
  203. + window_features.raw_features = features;
  204. +
  205. // In fenced frames, we should always use `noopener`.
  206. if (GetFrame()->IsInFencedFrameTree()) {
  207. window_features.noopener = true;