// Copyright (c) 2015 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CEF_LIBCEF_BROWSER_RESOURCE_CONTEXT_H_ #define CEF_LIBCEF_BROWSER_RESOURCE_CONTEXT_H_ #pragma once #include "include/cef_request_context.h" #include "include/cef_request_context_handler.h" #include "include/cef_scheme.h" #include "base/files/file_path.h" #include "chrome/common/plugin.mojom.h" #include "content/public/browser/resource_context.h" #include "extensions/browser/info_map.h" #include "net/ssl/client_cert_store.h" #include "url/origin.h" // Acts as a bridge for resource loading. Life span is controlled by // CefBrowserContext. Created on the UI thread but accessed and destroyed on the // IO thread. Network request objects are associated with the ResourceContext // via ProxyURLLoaderFactory. When the ResourceContext is destroyed all // outstanding network request objects will be canceled. // See browser_context.h for an object relationship diagram. class CefResourceContext : public content::ResourceContext { public: explicit CefResourceContext(bool is_off_the_record); ~CefResourceContext() override; std::unique_ptr CreateClientCertStore(); void set_extensions_info_map(extensions::InfoMap* extensions_info_map); // Keep track of handlers associated with specific frames. This information // originates from frame create/delete notifications in CefBrowserHostImpl or // CefMimeHandlerViewGuestDelegate which are forwarded via // CefRequestContextImpl and CefBrowserContext. void AddHandler(int render_process_id, int render_frame_id, int frame_tree_node_id, CefRefPtr handler); void RemoveHandler(int render_process_id, int render_frame_id, int frame_tree_node_id); // Returns the handler that matches the specified IDs. Pass -1 for unknown // values. If |require_frame_match| is true only exact matches will be // returned. If |require_frame_match| is false, and there is not an exact // match, then the first handler for the same |render_process_id| will be // returned. CefRefPtr GetHandler(int render_process_id, int render_frame_id, int frame_tree_node_id, bool require_frame_match); // Remember the plugin load decision for plugin status requests that arrive // via CefPluginServiceFilter::IsPluginAvailable. void AddPluginLoadDecision(int render_process_id, const base::FilePath& plugin_path, bool is_main_frame, const url::Origin& main_frame_origin, chrome::mojom::PluginStatus status); bool HasPluginLoadDecision(int render_process_id, const base::FilePath& plugin_path, bool is_main_frame, const url::Origin& main_frame_origin, chrome::mojom::PluginStatus* status) const; // Clear the plugin load decisions associated with |render_process_id|, or all // plugin load decisions if |render_process_id| is -1. void ClearPluginLoadDecision(int render_process_id); // Manage scheme handler factories associated with this context. void RegisterSchemeHandlerFactory(const std::string& scheme_name, const std::string& domain_name, CefRefPtr factory); void ClearSchemeHandlerFactories(); CefRefPtr GetSchemeHandlerFactory(const GURL& url); // State transferred from the BrowserContext for use on the IO thread. bool IsOffTheRecord() const { return is_off_the_record_; } const extensions::InfoMap* GetExtensionInfoMap() const { return extension_info_map_.get(); } private: void InitOnIOThread(); // Only accessed on the IO thread. bool is_off_the_record_; scoped_refptr extension_info_map_; // Map of (render_process_id, render_frame_id) to handler. typedef std::map, CefRefPtr> RenderIdHandlerMap; RenderIdHandlerMap render_id_handler_map_; // Map of frame_tree_node_id to handler. Keeping this map is necessary // because, when navigating the main frame, a new (pre-commit) network request // will be created before the RenderFrameHost. Consequently we can't rely // on valid render IDs. See https://crbug.com/776884 for background. typedef std::map> NodeIdHandlerMap; NodeIdHandlerMap node_id_handler_map_; // Map (render_process_id, plugin_path, is_main_frame, main_frame_origin) to // plugin load decision. typedef std::map< std::pair, std::pair>, chrome::mojom::PluginStatus> PluginLoadDecisionMap; PluginLoadDecisionMap plugin_load_decision_map_; // Map (scheme, domain) to factories. typedef std::map, CefRefPtr> SchemeHandlerFactoryMap; SchemeHandlerFactoryMap scheme_handler_factory_map_; DISALLOW_COPY_AND_ASSIGN(CefResourceContext); }; #endif // CEF_LIBCEF_BROWSER_RESOURCE_CONTEXT_H_