can_create_window.patch 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  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/frame_host/render_frame_host_impl.cc b/content/browser/frame_host/render_frame_host_impl.cc
  9. index 563e07a5ac2d9c44c4484d59e3fc025c70b961ea..60e36fab0e6999688b88665d9ad3181a26525a38 100644
  10. --- a/content/browser/frame_host/render_frame_host_impl.cc
  11. +++ b/content/browser/frame_host/render_frame_host_impl.cc
  12. @@ -4369,6 +4369,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->additional_features, params->body,
  17. effective_transient_activation_state, params->opener_suppressed,
  18. &no_javascript_access);
  19. diff --git a/content/common/frame.mojom b/content/common/frame.mojom
  20. index fb4cdca43e59c2dd8156cbe12bec391b128a6dd9..5c3645bebf2009def133fcd845f50e7745a243ca 100644
  21. --- a/content/common/frame.mojom
  22. +++ b/content/common/frame.mojom
  23. @@ -302,6 +302,10 @@ struct CreateNewWindowParams {
  24. // The window features to use for the new window.
  25. blink.mojom.WindowFeatures features;
  26. +
  27. + // Extra fields added by Electron.
  28. + array<string> additional_features;
  29. + network.mojom.URLRequestBody? body;
  30. };
  31. // Operation result when the renderer asks the browser to create a new window.
  32. diff --git a/content/public/browser/content_browser_client.cc b/content/public/browser/content_browser_client.cc
  33. index 0788e0f5e4311d8978768cb0d4d09736c19d2d25..0baf2ab441d48ee32a3ccf40fbc73c2c5cbcea2a 100644
  34. --- a/content/public/browser/content_browser_client.cc
  35. +++ b/content/public/browser/content_browser_client.cc
  36. @@ -501,6 +501,8 @@ bool ContentBrowserClient::CanCreateWindow(
  37. const std::string& frame_name,
  38. WindowOpenDisposition disposition,
  39. const blink::mojom::WindowFeatures& features,
  40. + const std::vector<std::string>& additional_features,
  41. + const scoped_refptr<network::ResourceRequestBody>& body,
  42. bool user_gesture,
  43. bool opener_suppressed,
  44. bool* no_javascript_access) {
  45. diff --git a/content/public/browser/content_browser_client.h b/content/public/browser/content_browser_client.h
  46. index 16c89377db5909ace2d12281a5ad4db49076e805..3a32228e8c131468c535f3586b1c54b307062c42 100644
  47. --- a/content/public/browser/content_browser_client.h
  48. +++ b/content/public/browser/content_browser_client.h
  49. @@ -139,6 +139,7 @@ class NetworkService;
  50. class TrustedURLLoaderHeaderClient;
  51. } // namespace mojom
  52. struct ResourceRequest;
  53. +class ResourceRequestBody;
  54. } // namespace network
  55. namespace rappor {
  56. @@ -824,6 +825,8 @@ class CONTENT_EXPORT ContentBrowserClient {
  57. const std::string& frame_name,
  58. WindowOpenDisposition disposition,
  59. const blink::mojom::WindowFeatures& features,
  60. + const std::vector<std::string>& additional_features,
  61. + const scoped_refptr<network::ResourceRequestBody>& body,
  62. bool user_gesture,
  63. bool opener_suppressed,
  64. bool* no_javascript_access);
  65. diff --git a/content/renderer/render_view_impl.cc b/content/renderer/render_view_impl.cc
  66. index 23ea7af344a1eaca2d0301cee9fe4bedde57b93a..37ac96bb7d42fe4caeb31861875219079d986982 100644
  67. --- a/content/renderer/render_view_impl.cc
  68. +++ b/content/renderer/render_view_impl.cc
  69. @@ -69,6 +69,7 @@
  70. #include "content/renderer/ime_event_guard.h"
  71. #include "content/renderer/internal_document_state_data.h"
  72. #include "content/renderer/loader/request_extra_data.h"
  73. +#include "content/renderer/loader/web_url_request_util.h"
  74. #include "content/renderer/media/audio/audio_device_factory.h"
  75. #include "content/renderer/render_frame_impl.h"
  76. #include "content/renderer/render_frame_proxy.h"
  77. @@ -1294,6 +1295,8 @@ WebView* RenderViewImpl::CreateView(
  78. }
  79. params->features = ConvertWebWindowFeaturesToMojoWindowFeatures(features);
  80. + params->body = GetRequestBodyForWebURLRequest(request);
  81. +
  82. // We preserve this information before sending the message since |params| is
  83. // moved on send.
  84. bool is_background_tab =
  85. diff --git a/content/shell/browser/web_test/web_test_content_browser_client.cc b/content/shell/browser/web_test/web_test_content_browser_client.cc
  86. index 4497b2d0c264f3e8ebc05230bdc117b6abccc23b..2eaa105035208d92cdcfe0e4de2a62ebbce1414b 100644
  87. --- a/content/shell/browser/web_test/web_test_content_browser_client.cc
  88. +++ b/content/shell/browser/web_test/web_test_content_browser_client.cc
  89. @@ -326,6 +326,8 @@ bool WebTestContentBrowserClient::CanCreateWindow(
  90. const std::string& frame_name,
  91. WindowOpenDisposition disposition,
  92. const blink::mojom::WindowFeatures& features,
  93. + const std::vector<std::string>& additional_features,
  94. + const scoped_refptr<network::ResourceRequestBody>& body,
  95. bool user_gesture,
  96. bool opener_suppressed,
  97. bool* no_javascript_access) {
  98. diff --git a/content/shell/browser/web_test/web_test_content_browser_client.h b/content/shell/browser/web_test/web_test_content_browser_client.h
  99. index 5f985e2f11ebef42ed676260297e5e699096ba4a..2f3e68199f50b0e85dbb0d5cb95388279a194028 100644
  100. --- a/content/shell/browser/web_test/web_test_content_browser_client.h
  101. +++ b/content/shell/browser/web_test/web_test_content_browser_client.h
  102. @@ -66,6 +66,8 @@ class WebTestContentBrowserClient : public ShellContentBrowserClient {
  103. const std::string& frame_name,
  104. WindowOpenDisposition disposition,
  105. const blink::mojom::WindowFeatures& features,
  106. + const std::vector<std::string>& additional_features,
  107. + const scoped_refptr<network::ResourceRequestBody>& body,
  108. bool user_gesture,
  109. bool opener_suppressed,
  110. bool* no_javascript_access) override;