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 ca13a23e0531e6f40e130c1294b44c98fdb2c0d7..b146b1c93f809667c730c2587e180a29718fc9e3 100644
  10. --- a/content/browser/renderer_host/render_frame_host_impl.cc
  11. +++ b/content/browser/renderer_host/render_frame_host_impl.cc
  12. @@ -8846,6 +8846,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 feec75ff8bb5ac4ae1f911b67826a4984ff06d83..c72bdcbb1039d524098851aa914630d14f8e49a1 100644
  21. --- a/content/browser/web_contents/web_contents_impl.cc
  22. +++ b/content/browser/web_contents/web_contents_impl.cc
  23. @@ -4741,6 +4741,12 @@ FrameTree* WebContentsImpl::CreateNewWindow(
  24. new_contents_impl->is_popup_ =
  25. params.disposition == WindowOpenDisposition::NEW_POPUP;
  26. + if (delegate_) {
  27. + delegate_->WebContentsCreatedWithFullParams(this, render_process_id,
  28. + opener->GetRoutingID(),
  29. + params, new_contents_impl);
  30. + }
  31. +
  32. // If the new frame has a name, make sure any SiteInstances that can find
  33. // this named frame have proxies for it. Must be called after
  34. // SetSessionStorageNamespace, since this calls CreateRenderView, which uses
  35. @@ -4782,12 +4788,6 @@ FrameTree* WebContentsImpl::CreateNewWindow(
  36. AddWebContentsDestructionObserver(new_contents_impl);
  37. }
  38. - if (delegate_) {
  39. - delegate_->WebContentsCreated(this, render_process_id,
  40. - opener->GetRoutingID(), params.frame_name,
  41. - params.target_url, new_contents_impl);
  42. - }
  43. -
  44. observers_.NotifyObservers(&WebContentsObserver::DidOpenRequestedURL,
  45. new_contents_impl, opener, params.target_url,
  46. params.referrer.To<Referrer>(), params.disposition,
  47. diff --git a/content/common/frame.mojom b/content/common/frame.mojom
  48. index 37a00f8d520e6043faa9b202e2f7a3d7a0794664..08b56afaa591137aafc4aad38da84361742bbe66 100644
  49. --- a/content/common/frame.mojom
  50. +++ b/content/common/frame.mojom
  51. @@ -605,6 +605,10 @@ struct CreateNewWindowParams {
  52. // The navigation initiator's user activation and ad status.
  53. blink.mojom.NavigationInitiatorActivationAndAdStatus
  54. initiator_activation_and_ad_status;
  55. +
  56. + // Extra fields added by Electron.
  57. + string raw_features;
  58. + network.mojom.URLRequestBody? body;
  59. };
  60. // Operation result when the renderer asks the browser to create a new window.
  61. diff --git a/content/public/browser/content_browser_client.cc b/content/public/browser/content_browser_client.cc
  62. index 7f43e745f4d9764b720a976d3343637ec9457415..113262c96869f766c80c4485e55902accc43c239 100644
  63. --- a/content/public/browser/content_browser_client.cc
  64. +++ b/content/public/browser/content_browser_client.cc
  65. @@ -750,6 +750,8 @@ bool ContentBrowserClient::CanCreateWindow(
  66. const std::string& frame_name,
  67. WindowOpenDisposition disposition,
  68. const blink::mojom::WindowFeatures& features,
  69. + const std::string& raw_features,
  70. + const scoped_refptr<network::ResourceRequestBody>& body,
  71. bool user_gesture,
  72. bool opener_suppressed,
  73. bool* no_javascript_access) {
  74. diff --git a/content/public/browser/content_browser_client.h b/content/public/browser/content_browser_client.h
  75. index 4c982411a8508270ec93b444ae999f7e51973aaa..9aff128608ca60c2031b131eff59622e74b5a55a 100644
  76. --- a/content/public/browser/content_browser_client.h
  77. +++ b/content/public/browser/content_browser_client.h
  78. @@ -190,6 +190,7 @@ class NetworkService;
  79. class TrustedURLLoaderHeaderClient;
  80. } // namespace mojom
  81. struct ResourceRequest;
  82. +class ResourceRequestBody;
  83. } // namespace network
  84. namespace sandbox {
  85. @@ -1286,6 +1287,8 @@ class CONTENT_EXPORT ContentBrowserClient {
  86. const std::string& frame_name,
  87. WindowOpenDisposition disposition,
  88. const blink::mojom::WindowFeatures& features,
  89. + const std::string& raw_features,
  90. + const scoped_refptr<network::ResourceRequestBody>& body,
  91. bool user_gesture,
  92. bool opener_suppressed,
  93. bool* no_javascript_access);
  94. diff --git a/content/public/browser/web_contents_delegate.cc b/content/public/browser/web_contents_delegate.cc
  95. index 8b8ad58fede66aa4423fe1b17637bb26f54cd862..4998328a01525a12fa54ca5b9bf85f518c64de83 100644
  96. --- a/content/public/browser/web_contents_delegate.cc
  97. +++ b/content/public/browser/web_contents_delegate.cc
  98. @@ -30,6 +30,17 @@ namespace content {
  99. WebContentsDelegate::WebContentsDelegate() = default;
  100. +void WebContentsDelegate::WebContentsCreatedWithFullParams(
  101. + WebContents* source_contents,
  102. + int opener_render_process_id,
  103. + int opener_render_frame_id,
  104. + const mojom::CreateNewWindowParams& params,
  105. + WebContents* new_contents) {
  106. + WebContentsCreated(source_contents, opener_render_process_id,
  107. + opener_render_frame_id, params.frame_name,
  108. + params.target_url, new_contents);
  109. +}
  110. +
  111. WebContents* WebContentsDelegate::OpenURLFromTab(
  112. WebContents* source,
  113. const OpenURLParams& params,
  114. diff --git a/content/public/browser/web_contents_delegate.h b/content/public/browser/web_contents_delegate.h
  115. index 00c51ef739d8b369f67112a341fa8b8947d8aa90..38ab9071bdab02e855f59c93941da1153cd06d88 100644
  116. --- a/content/public/browser/web_contents_delegate.h
  117. +++ b/content/public/browser/web_contents_delegate.h
  118. @@ -17,6 +17,7 @@
  119. #include "base/memory/scoped_refptr.h"
  120. #include "build/build_config.h"
  121. #include "content/common/content_export.h"
  122. +#include "content/common/frame.mojom.h"
  123. #include "content/public/browser/back_forward_transition_animation_manager.h"
  124. #include "content/public/browser/eye_dropper.h"
  125. #include "content/public/browser/fullscreen_types.h"
  126. @@ -359,6 +360,13 @@ class CONTENT_EXPORT WebContentsDelegate {
  127. const StoragePartitionConfig& partition_config,
  128. SessionStorageNamespace* session_storage_namespace);
  129. + virtual void WebContentsCreatedWithFullParams(
  130. + WebContents* source_contents,
  131. + int opener_render_process_id,
  132. + int opener_render_frame_id,
  133. + const mojom::CreateNewWindowParams& params,
  134. + WebContents* new_contents);
  135. +
  136. // Notifies the delegate about the creation of a new WebContents. This
  137. // typically happens when popups are created.
  138. virtual void WebContentsCreated(WebContents* source_contents,
  139. diff --git a/content/renderer/render_frame_impl.cc b/content/renderer/render_frame_impl.cc
  140. index ccaa4b368f7831edae409f68765c496c70ed4889..ee688da4100412ff58bffa1b266a4c823486dd56 100644
  141. --- a/content/renderer/render_frame_impl.cc
  142. +++ b/content/renderer/render_frame_impl.cc
  143. @@ -6701,6 +6701,10 @@ WebView* RenderFrameImpl::CreateNewWindow(
  144. request.HasUserGesture(), GetWebFrame()->IsAdFrame(),
  145. GetWebFrame()->IsAdScriptInStack());
  146. + params->raw_features = features.raw_features.Utf8(
  147. + WTF::UTF8ConversionMode::kStrictUTF8ConversionReplacingUnpairedSurrogatesWithFFFD);
  148. + params->body = GetRequestBodyForWebURLRequest(request);
  149. +
  150. // We preserve this information before sending the message since |params| is
  151. // moved on send.
  152. bool is_background_tab =
  153. diff --git a/content/web_test/browser/web_test_content_browser_client.cc b/content/web_test/browser/web_test_content_browser_client.cc
  154. index 634a48627e1fa1442d5977b9b09692e933ae5001..e39e2e16d98f3d9258aea360f5c89781d2100ac8 100644
  155. --- a/content/web_test/browser/web_test_content_browser_client.cc
  156. +++ b/content/web_test/browser/web_test_content_browser_client.cc
  157. @@ -516,6 +516,8 @@ bool WebTestContentBrowserClient::CanCreateWindow(
  158. const std::string& frame_name,
  159. WindowOpenDisposition disposition,
  160. const blink::mojom::WindowFeatures& features,
  161. + const std::string& raw_features,
  162. + const scoped_refptr<network::ResourceRequestBody>& body,
  163. bool user_gesture,
  164. bool opener_suppressed,
  165. bool* no_javascript_access) {
  166. diff --git a/content/web_test/browser/web_test_content_browser_client.h b/content/web_test/browser/web_test_content_browser_client.h
  167. index 115b75966f53ee16f7886fc4152741727c7825c8..a1944f7de539f04f85fdb238ccf67e091f413ad3 100644
  168. --- a/content/web_test/browser/web_test_content_browser_client.h
  169. +++ b/content/web_test/browser/web_test_content_browser_client.h
  170. @@ -92,6 +92,8 @@ class WebTestContentBrowserClient : public ShellContentBrowserClient {
  171. const std::string& frame_name,
  172. WindowOpenDisposition disposition,
  173. const blink::mojom::WindowFeatures& features,
  174. + const std::string& raw_features,
  175. + const scoped_refptr<network::ResourceRequestBody>& body,
  176. bool user_gesture,
  177. bool opener_suppressed,
  178. bool* no_javascript_access) override;
  179. diff --git a/third_party/blink/public/web/web_window_features.h b/third_party/blink/public/web/web_window_features.h
  180. index 7c901dcc9f171a936ee6eb41dfd899a095a8a915..71748ad3a28946f816e2001ba78bbcb56cac7629 100644
  181. --- a/third_party/blink/public/web/web_window_features.h
  182. +++ b/third_party/blink/public/web/web_window_features.h
  183. @@ -35,6 +35,7 @@
  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. @@ -70,6 +71,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. std::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 93eb1484857b2f021eb8e691bd2fe12b2f49f12c..a489e6c6fee3e4d16b66675f40ce2e0608229f10 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. @@ -2240,6 +2240,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;