// Copyright (c) 2011 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_BROWSER_CONTEXT_IMPL_H_ #define CEF_LIBCEF_BROWSER_BROWSER_CONTEXT_IMPL_H_ #pragma once #include #include #include #include "base/files/file_path.h" #include "base/functional/callback.h" #include "base/memory/weak_ptr.h" #include "base/task/sequenced_task_runner_helpers.h" #include "cef/include/cef_request_context_handler.h" #include "cef/libcef/browser/iothread_state.h" #include "cef/libcef/browser/request_context_handler_map.h" #include "cef/libcef/features/features.h" #include "chrome/common/plugin.mojom.h" #include "services/network/public/mojom/network_context.mojom.h" #include "ui/base/page_transition_types.h" #include "url/origin.h" /* // Classes used in request processing (network, storage, service, etc.): // // WC = WebContents // Content API representation of a browser. Created by BHI or the system (for // popups) and owned by BHI. Keeps a pointer to the content::BrowserContext. // // BHI = AlloyBrowserHostImpl // Implements the CefBrowser and CefBrowserHost interfaces which are exposed // to clients. References an RCI instance. Owns a WC. Lifespan is controlled // by client references and CefBrowserInfoManager (until the browser has // closed). // // RCI = CefRequestContextImpl // Implements the CefRequestContext interface which is exposed to clients. // Creates or references a BC. Lifespan is controlled by client references and // BrowserMainParts (for the global RCI). // // BC = CefBrowserContext // Is/owns the content::BrowserContext which is the entry point from WC. // Owns the IOTS and creates the SPI indirectly. Potentially shared by // multiple RCI. Deletes itself when no longer needed by RCI. // // SPI = content::StoragePartitionImpl // Owns storage-related objects like Quota, IndexedDB, Cache, etc. Created by // StoragePartitionImplMap::Get(). Life span is controlled indirectly by BC. // // IOTS = CefIOThreadState // Stores state for access on the IO thread. Life span is controlled by BC. // // // Relationship diagram: // ref = reference (CefRefPtr/scoped_refptr) // own = ownership (std::unique_ptr) // ptr = raw pointer // // BHI -ref-> RCI -ptr-> BC -own-> SPI, IOTS // ^ // BHI -own-> WC -ptr--/ // // // How shutdown works: // 1. AlloyBrowserHostImpl::DestroyBrowser is called on the UI thread after the // browser is closed and deletes the WebContents. // 1. AlloyBrowserHostImpl is destroyed on any thread when the last reference // is released. // 2. CefRequestContextImpl is destroyed (possibly asynchronously) on the UI // thread when the last reference is released. // 3. CefBrowserContext is destroyed on the UI thread when no longer needed // by any CefRequestContextImpl (via RemoveCefRequestContext). // 4. CefIOThreadState is destroyed asynchronously on the IO thread after // the owning CefBrowserContext is destroyed. */ namespace content { class BrowserContext; struct GlobalRenderFrameHostId; } // namespace content class CefMediaRouterManager; class CefRequestContextImpl; class Profile; // Main entry point for configuring behavior on a per-RequestContext basis. The // content::BrowserContext represented by this class is passed to // WebContents::Create in AlloyBrowserHostImpl::CreateInternal. Only accessed on // the UI thread unless otherwise indicated. class CefBrowserContext { public: CefBrowserContext(const CefBrowserContext&) = delete; CefBrowserContext& operator=(const CefBrowserContext&) = delete; // Returns the existing instance, if any, associated with the specified // |cache_path|. static CefBrowserContext* FromCachePath(const base::FilePath& cache_path); // Returns the existing instance, if any, associated with the specified IDs. // See comments on IsAssociatedContext() for usage. static CefBrowserContext* FromGlobalId( const content::GlobalRenderFrameHostId& global_id, bool require_frame_match); // Returns the underlying CefBrowserContext, if any. static CefBrowserContext* FromBrowserContext( const content::BrowserContext* context); static CefBrowserContext* FromProfile(const Profile* profile); // Returns all existing CefBrowserContext. static std::vector GetAll(); // Returns the content and chrome layer representations of the context. virtual content::BrowserContext* AsBrowserContext() = 0; virtual Profile* AsProfile() = 0; // Returns true if the context is fully initialized. virtual bool IsInitialized() const = 0; // If the context is fully initialized execute |callback|, otherwise // store it until the context is fully initialized. virtual void StoreOrTriggerInitCallback(base::OnceClosure callback) = 0; // Called from CefRequestContextImpl to track associated objects. This // object will delete itself when the count reaches zero. void AddCefRequestContext(CefRequestContextImpl* context); virtual void RemoveCefRequestContext(CefRequestContextImpl* context); // Called from CefRequestContextImpl::OnRenderFrameCreated. void OnRenderFrameCreated(CefRequestContextImpl* request_context, const content::GlobalRenderFrameHostId& global_id, bool is_main_frame); // Called from CefRequestContextImpl::OnRenderFrameDeleted. void OnRenderFrameDeleted(CefRequestContextImpl* request_context, const content::GlobalRenderFrameHostId& global_id, bool is_main_frame); // 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( const content::GlobalRenderFrameHostId& global_id, bool require_frame_match) const; // Returns true if this context is associated with the specified IDs. Pass -1 // for unknown values. If |require_frame_match| is true only exact matches // will qualify. If |require_frame_match| is false, and there is not an exact // match, then any match for |render_process_id| will qualify. bool IsAssociatedContext(const content::GlobalRenderFrameHostId& global_id, bool require_frame_match) const; // Called from CefRequestContextImpl methods of the same name. void RegisterSchemeHandlerFactory(const CefString& scheme_name, const CefString& domain_name, CefRefPtr factory); void ClearSchemeHandlerFactories(); #if BUILDFLAG(ENABLE_ALLOY_BOOTSTRAP) virtual void LoadExtension(const CefString& root_directory, CefRefPtr manifest, CefRefPtr handler, CefRefPtr loader_context); virtual bool GetExtensions(std::vector& extension_ids); virtual CefRefPtr GetExtension(const CefString& extension_id); // Called from CefExtensionImpl::Unload(). virtual bool UnloadExtension(const CefString& extension_id); #endif // Called from AlloyBrowserHostImpl::DidFinishNavigation to update the table // of visited links. virtual void AddVisitedURLs(const GURL& url, const std::vector& redirect_chain, ui::PageTransition transition) = 0; network::mojom::NetworkContext* GetNetworkContext(); CefMediaRouterManager* GetMediaRouterManager(); // Returns any CefRequestContext associated with this object, or nullptr if // none exist. If |prefer_no_handler| is true this method will try to return a // context without an associated CefRequestContextHandler. Use // CefRequestContextImpl::GetOrCreateForBrowserContext() instead of calling // this method directly. CefRefPtr GetAnyRequestContext( bool prefer_no_handler) const; using CookieableSchemes = std::optional>; // Returns the schemes associated with this context specifically, or the // global configuration if unset. CookieableSchemes GetCookieableSchemes() const; static CookieableSchemes GetGlobalCookieableSchemes(); // These accessors are safe to call from any thread because the values don't // change during this object's lifespan. const CefRequestContextSettings& settings() const { return settings_; } base::FilePath cache_path() const { return cache_path_; } scoped_refptr iothread_state() const { return iothread_state_; } // Used to hold a WeakPtr reference to this this object. The Getter returns // nullptr if this object has already been destroyed. using Getter = base::RepeatingCallback; Getter getter() const { return getter_; } protected: explicit CefBrowserContext(const CefRequestContextSettings& settings); virtual ~CefBrowserContext(); // Will be called immediately after this object is created. virtual void Initialize(); // Will be called immediately before this object is deleted. virtual void Shutdown(); // Members initialized during construction or Initialize() are safe to access // from any thread. const CefRequestContextSettings settings_; base::FilePath cache_path_; private: // For DeleteSoon(). friend class base::DeleteHelper; scoped_refptr iothread_state_; CookieableSchemes cookieable_schemes_; std::unique_ptr media_router_manager_; // CefRequestContextImpl objects referencing this object. std::set request_context_set_; // Map IDs to CefRequestContextHandler objects. CefRequestContextHandlerMap handler_map_; // Set of global IDs associated with this context. using RenderIdSet = std::set; RenderIdSet render_id_set_; #if DCHECK_IS_ON() bool is_shutdown_ = false; #endif Getter getter_; base::WeakPtrFactory weak_ptr_factory_; }; #endif // CEF_LIBCEF_BROWSER_BROWSER_CONTEXT_IMPL_H_