mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	- mac: Xcode 14.0 with macOS SDK 13.0 is now required. - Remove CefRequestHandler::OnQuotaRequest because persistent quota is no longer supported (see https://crbug.com/1208141)
		
			
				
	
	
		
			181 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			181 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| diff --git content/browser/devtools/devtools_http_handler.cc content/browser/devtools/devtools_http_handler.cc
 | |
| index af3f911d7f435..998ba65198721 100644
 | |
| --- content/browser/devtools/devtools_http_handler.cc
 | |
| +++ content/browser/devtools/devtools_http_handler.cc
 | |
| @@ -596,7 +596,7 @@ void DevToolsHttpHandler::OnJsonRequest(
 | |
|      version.SetString("Protocol-Version",
 | |
|                        DevToolsAgentHost::GetProtocolVersion());
 | |
|      version.SetString("WebKit-Version", GetWebKitVersion());
 | |
| -    version.SetString("Browser", GetContentClient()->browser()->GetProduct());
 | |
| +    version.SetString("Browser", GetContentClient()->browser()->GetChromeProduct());
 | |
|      version.SetString("User-Agent",
 | |
|                        GetContentClient()->browser()->GetUserAgent());
 | |
|      version.SetString("V8-Version", V8_VERSION_STRING);
 | |
| diff --git content/browser/loader/navigation_url_loader_impl.cc content/browser/loader/navigation_url_loader_impl.cc
 | |
| index 95ab3cd395b8a..1a82cf112454e 100644
 | |
| --- content/browser/loader/navigation_url_loader_impl.cc
 | |
| +++ content/browser/loader/navigation_url_loader_impl.cc
 | |
| @@ -715,6 +715,17 @@ NavigationURLLoaderImpl::PrepareForNonInterceptedRequest(
 | |
|            resource_request_->has_user_gesture, initiating_origin,
 | |
|            initiator_document_.AsRenderFrameHostIfValid(), &loader_factory);
 | |
|  
 | |
| +      if (!handled) {
 | |
| +        handled = GetContentClient()->browser()->HandleExternalProtocol(
 | |
| +            web_contents_getter_, frame_tree_node_id_,
 | |
| +            navigation_ui_data_.get(), request_info_->is_primary_main_frame,
 | |
| +            FrameTreeNode::GloballyFindByID(frame_tree_node_id_)
 | |
| +                ->IsInFencedFrameTree(),
 | |
| +            request_info_->sandbox_flags,
 | |
| +            *resource_request_, initiating_origin,
 | |
| +            initiator_document_.AsRenderFrameHostIfValid(), &loader_factory);
 | |
| +      }
 | |
| +
 | |
|        if (loader_factory) {
 | |
|          factory = base::MakeRefCounted<network::WrapperSharedURLLoaderFactory>(
 | |
|              std::move(loader_factory));
 | |
| diff --git content/public/browser/content_browser_client.cc content/public/browser/content_browser_client.cc
 | |
| index 560e66d4e402c..f25a012d63424 100644
 | |
| --- content/public/browser/content_browser_client.cc
 | |
| +++ content/public/browser/content_browser_client.cc
 | |
| @@ -960,7 +960,7 @@ ContentBrowserClient::CreateURLLoaderHandlerForServiceWorkerNavigationPreload(
 | |
|  void ContentBrowserClient::OnNetworkServiceCreated(
 | |
|      network::mojom::NetworkService* network_service) {}
 | |
|  
 | |
| -void ContentBrowserClient::ConfigureNetworkContextParams(
 | |
| +bool ContentBrowserClient::ConfigureNetworkContextParams(
 | |
|      BrowserContext* context,
 | |
|      bool in_memory,
 | |
|      const base::FilePath& relative_partition_path,
 | |
| @@ -969,6 +969,7 @@ void ContentBrowserClient::ConfigureNetworkContextParams(
 | |
|          cert_verifier_creation_params) {
 | |
|    network_context_params->user_agent = GetUserAgentBasedOnPolicy(context);
 | |
|    network_context_params->accept_language = "en-us,en";
 | |
| +  return true;
 | |
|  }
 | |
|  
 | |
|  std::vector<base::FilePath>
 | |
| diff --git content/public/browser/content_browser_client.h content/public/browser/content_browser_client.h
 | |
| index bdb4632c56534..fb2334e9bd462 100644
 | |
| --- content/public/browser/content_browser_client.h
 | |
| +++ content/public/browser/content_browser_client.h
 | |
| @@ -35,6 +35,7 @@
 | |
|  #include "content/public/browser/login_delegate.h"
 | |
|  #include "content/public/browser/mojo_binder_policy_map.h"
 | |
|  #include "content/public/browser/storage_partition_config.h"
 | |
| +#include "content/public/browser/web_contents.h"
 | |
|  #include "content/public/common/alternative_error_page_override_info.mojom-forward.h"
 | |
|  #include "content/public/common/page_visibility_state.h"
 | |
|  #include "content/public/common/window_container_type.mojom-forward.h"
 | |
| @@ -1768,7 +1769,7 @@ class CONTENT_EXPORT ContentBrowserClient {
 | |
|    //
 | |
|    // If |relative_partition_path| is the empty string, it means this needs to
 | |
|    // create the default NetworkContext for the BrowserContext.
 | |
| -  virtual void ConfigureNetworkContextParams(
 | |
| +  virtual bool ConfigureNetworkContextParams(
 | |
|        BrowserContext* context,
 | |
|        bool in_memory,
 | |
|        const base::FilePath& relative_partition_path,
 | |
| @@ -1960,6 +1961,19 @@ class CONTENT_EXPORT ContentBrowserClient {
 | |
|        RenderFrameHost* initiator_document,
 | |
|        mojo::PendingRemote<network::mojom::URLLoaderFactory>* out_factory);
 | |
|  
 | |
| +  // Same as above, but exposing the whole ResourceRequest object.
 | |
| +  virtual bool HandleExternalProtocol(
 | |
| +      WebContents::Getter web_contents_getter,
 | |
| +      int frame_tree_node_id,
 | |
| +      NavigationUIData* navigation_data,
 | |
| +      bool is_primary_main_frame,
 | |
| +      bool is_in_fenced_frame_tree,
 | |
| +      network::mojom::WebSandboxFlags sandbox_flags,
 | |
| +      const network::ResourceRequest& request,
 | |
| +      const absl::optional<url::Origin>& initiating_origin,
 | |
| +      RenderFrameHost* initiator_document,
 | |
| +      mojo::PendingRemote<network::mojom::URLLoaderFactory>* out_factory) { return false; }
 | |
| +
 | |
|    // Creates an OverlayWindow to be used for video or Picture-in-Picture.
 | |
|    // This window will house the content shown when in Picture-in-Picture mode.
 | |
|    // This will return a new OverlayWindow.
 | |
| @@ -2012,6 +2026,10 @@ class CONTENT_EXPORT ContentBrowserClient {
 | |
|    // Used as part of the user agent string.
 | |
|    virtual std::string GetProduct();
 | |
|  
 | |
| +  // Returns the Chrome-specific product string. This is used for compatibility
 | |
| +  // purposes with external tools like Selenium.
 | |
| +  virtual std::string GetChromeProduct() { return GetProduct(); }
 | |
| +
 | |
|    // Returns the user agent. This can also return the reduced user agent, based
 | |
|    // on blink::features::kUserAgentReduction. Content may cache this value.
 | |
|    virtual std::string GetUserAgent();
 | |
| diff --git content/public/renderer/content_renderer_client.h content/public/renderer/content_renderer_client.h
 | |
| index 09846e00f1a75..18b396a631f45 100644
 | |
| --- content/public/renderer/content_renderer_client.h
 | |
| +++ content/public/renderer/content_renderer_client.h
 | |
| @@ -96,6 +96,9 @@ class CONTENT_EXPORT ContentRendererClient {
 | |
|    // binding requests from RenderProcessHost::BindReceiver().
 | |
|    virtual void ExposeInterfacesToBrowser(mojo::BinderMap* binders) {}
 | |
|  
 | |
| +  // Notifies that the RenderThread can now send sync IPC messages.
 | |
| +  virtual void RenderThreadConnected() {}
 | |
| +
 | |
|    // Notifies that a new RenderFrame has been created.
 | |
|    virtual void RenderFrameCreated(RenderFrame* render_frame) {}
 | |
|  
 | |
| @@ -315,6 +318,10 @@ class CONTENT_EXPORT ContentRendererClient {
 | |
|    // This method may invalidate the frame.
 | |
|    virtual void RunScriptsAtDocumentIdle(RenderFrame* render_frame) {}
 | |
|  
 | |
| +  // Notifies that a DevTools agent has attached or detached.
 | |
| +  virtual void DevToolsAgentAttached() {}
 | |
| +  virtual void DevToolsAgentDetached() {}
 | |
| +
 | |
|    // Allows subclasses to enable some runtime features before Blink has
 | |
|    // started.
 | |
|    virtual void SetRuntimeFeaturesDefaultsBeforeBlinkInitialization() {}
 | |
| diff --git content/renderer/render_thread_impl.cc content/renderer/render_thread_impl.cc
 | |
| index 49688b3adc657..6a1f4b26ef757 100644
 | |
| --- content/renderer/render_thread_impl.cc
 | |
| +++ content/renderer/render_thread_impl.cc
 | |
| @@ -604,6 +604,8 @@ void RenderThreadImpl::Init() {
 | |
|        GetContentClient()->renderer()->CreateURLLoaderThrottleProvider(
 | |
|            blink::URLLoaderThrottleProviderType::kFrame);
 | |
|  
 | |
| +  GetContentClient()->renderer()->RenderThreadConnected();
 | |
| +
 | |
|    GetAssociatedInterfaceRegistry()->AddInterface<mojom::Renderer>(
 | |
|        base::BindRepeating(&RenderThreadImpl::OnRendererInterfaceReceiver,
 | |
|                            base::Unretained(this)));
 | |
| diff --git content/renderer/renderer_blink_platform_impl.cc content/renderer/renderer_blink_platform_impl.cc
 | |
| index ab6a83247fb18..385d99d09a5d8 100644
 | |
| --- content/renderer/renderer_blink_platform_impl.cc
 | |
| +++ content/renderer/renderer_blink_platform_impl.cc
 | |
| @@ -1023,6 +1023,15 @@ SkBitmap* RendererBlinkPlatformImpl::GetSadPageBitmap() {
 | |
|  
 | |
|  //------------------------------------------------------------------------------
 | |
|  
 | |
| +void RendererBlinkPlatformImpl::DevToolsAgentAttached() {
 | |
| +  GetContentClient()->renderer()->DevToolsAgentAttached();
 | |
| +}
 | |
| +void RendererBlinkPlatformImpl::DevToolsAgentDetached() {
 | |
| +  GetContentClient()->renderer()->DevToolsAgentDetached();
 | |
| +}
 | |
| +
 | |
| +//------------------------------------------------------------------------------
 | |
| +
 | |
|  std::unique_ptr<blink::WebV8ValueConverter>
 | |
|  RendererBlinkPlatformImpl::CreateWebV8ValueConverter() {
 | |
|    return std::make_unique<V8ValueConverterImpl>();
 | |
| diff --git content/renderer/renderer_blink_platform_impl.h content/renderer/renderer_blink_platform_impl.h
 | |
| index 76ca0135501ae..e81ac506214d8 100644
 | |
| --- content/renderer/renderer_blink_platform_impl.h
 | |
| +++ content/renderer/renderer_blink_platform_impl.h
 | |
| @@ -230,6 +230,9 @@ class CONTENT_EXPORT RendererBlinkPlatformImpl : public BlinkPlatformImpl {
 | |
|    blink::mojom::AttributionOsSupport GetOsSupportForAttributionReporting()
 | |
|        override;
 | |
|  
 | |
| +  void DevToolsAgentAttached() override;
 | |
| +  void DevToolsAgentDetached() override;
 | |
| +
 | |
|    // Tells this platform that the renderer is locked to a site (i.e., a scheme
 | |
|    // plus eTLD+1, such as https://google.com), or to a more specific origin.
 | |
|    void SetIsLockedToSite();
 |