mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	- Add CefRequestContext::LoadExtension, CefExtension, CefExtensionHandler and related methods/interfaces. - Add chrome://extensions-support that lists supported Chrome APIs. - Add CefBrowserHost::SetAutoResizeEnabled and CefDisplayHandler::OnAutoResize to support browser resize based on preferred web contents size. - views: Add support for custom CefMenuButton popups. - cefclient: Run with `--load-extension=set_page_color` command-line flag for an extension loading example. Add `--use-views` on Windows and Linux for an even better example.
		
			
				
	
	
		
			172 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			172 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
// Copyright (c) 2013 The Chromium Embedded Framework 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_REQUEST_CONTEXT_IMPL_H_
 | 
						|
#define CEF_LIBCEF_REQUEST_CONTEXT_IMPL_H_
 | 
						|
#pragma once
 | 
						|
 | 
						|
#include "include/cef_request_context.h"
 | 
						|
#include "libcef/browser/browser_context.h"
 | 
						|
#include "libcef/browser/thread_util.h"
 | 
						|
 | 
						|
class CefBrowserContextImpl;
 | 
						|
class CefBrowserContextProxy;
 | 
						|
 | 
						|
// Implementation of the CefRequestContext interface. All methods are thread-
 | 
						|
// safe unless otherwise indicated. Will be deleted on the UI thread.
 | 
						|
class CefRequestContextImpl : public CefRequestContext {
 | 
						|
 public:
 | 
						|
  ~CefRequestContextImpl() override;
 | 
						|
 | 
						|
  // Creates the singleton global RequestContext. Called from
 | 
						|
  // CefBrowserMainParts::PreMainMessageLoopRun.
 | 
						|
  static CefRefPtr<CefRequestContextImpl> CreateGlobalRequestContext(
 | 
						|
      const CefRequestContextSettings& settings);
 | 
						|
 | 
						|
  // Returns a CefRequestContextImpl for the specified |request_context|.
 | 
						|
  // Will return the global context if |request_context| is NULL.
 | 
						|
  static CefRefPtr<CefRequestContextImpl> GetOrCreateForRequestContext(
 | 
						|
      CefRefPtr<CefRequestContext> request_context);
 | 
						|
 | 
						|
  // Returns the browser context object. Can only be called on the UI thread.
 | 
						|
  CefBrowserContext* GetBrowserContext();
 | 
						|
 | 
						|
  // Executes |callback| either synchronously or asynchronously with the browser
 | 
						|
  // context object when it's available. If |task_runner| is NULL the callback
 | 
						|
  // will be executed on the originating thread. The resulting context object
 | 
						|
  // can only be accessed on the UI thread.
 | 
						|
  typedef base::Callback<void(CefBrowserContext*)> BrowserContextCallback;
 | 
						|
  void GetBrowserContext(
 | 
						|
      scoped_refptr<base::SingleThreadTaskRunner> task_runner,
 | 
						|
      const BrowserContextCallback& callback);
 | 
						|
 | 
						|
  // Executes |callback| either synchronously or asynchronously with the request
 | 
						|
  // context object when it's available. If |task_runner| is NULL the callback
 | 
						|
  // will be executed on the originating thread. The resulting context object
 | 
						|
  // can only be accessed on the IO thread.
 | 
						|
  typedef base::Callback<void(scoped_refptr<CefURLRequestContextGetterImpl>)>
 | 
						|
      RequestContextCallback;
 | 
						|
  void GetRequestContextImpl(
 | 
						|
      scoped_refptr<base::SingleThreadTaskRunner> task_runner,
 | 
						|
      const RequestContextCallback& callback);
 | 
						|
 | 
						|
  bool IsSame(CefRefPtr<CefRequestContext> other) override;
 | 
						|
  bool IsSharingWith(CefRefPtr<CefRequestContext> other) override;
 | 
						|
  bool IsGlobal() override;
 | 
						|
  CefRefPtr<CefRequestContextHandler> GetHandler() override;
 | 
						|
  CefString GetCachePath() override;
 | 
						|
  CefRefPtr<CefCookieManager> GetDefaultCookieManager(
 | 
						|
      CefRefPtr<CefCompletionCallback> callback) override;
 | 
						|
  bool RegisterSchemeHandlerFactory(
 | 
						|
      const CefString& scheme_name,
 | 
						|
      const CefString& domain_name,
 | 
						|
      CefRefPtr<CefSchemeHandlerFactory> factory) override;
 | 
						|
  bool ClearSchemeHandlerFactories() override;
 | 
						|
  void PurgePluginListCache(bool reload_pages) override;
 | 
						|
  bool HasPreference(const CefString& name) override;
 | 
						|
  CefRefPtr<CefValue> GetPreference(const CefString& name) override;
 | 
						|
  CefRefPtr<CefDictionaryValue> GetAllPreferences(
 | 
						|
      bool include_defaults) override;
 | 
						|
  bool CanSetPreference(const CefString& name) override;
 | 
						|
  bool SetPreference(const CefString& name,
 | 
						|
                     CefRefPtr<CefValue> value,
 | 
						|
                     CefString& error) override;
 | 
						|
  void ClearCertificateExceptions(
 | 
						|
      CefRefPtr<CefCompletionCallback> callback) override;
 | 
						|
  void CloseAllConnections(CefRefPtr<CefCompletionCallback> callback) override;
 | 
						|
  void ResolveHost(const CefString& origin,
 | 
						|
                   CefRefPtr<CefResolveCallback> callback) override;
 | 
						|
  cef_errorcode_t ResolveHostCached(
 | 
						|
      const CefString& origin,
 | 
						|
      std::vector<CefString>& resolved_ips) override;
 | 
						|
  void LoadExtension(const CefString& root_directory,
 | 
						|
                     CefRefPtr<CefDictionaryValue> manifest,
 | 
						|
                     CefRefPtr<CefExtensionHandler> handler) override;
 | 
						|
  bool DidLoadExtension(const CefString& extension_id) override;
 | 
						|
  bool HasExtension(const CefString& extension_id) override;
 | 
						|
  bool GetExtensions(std::vector<CefString>& extension_ids) override;
 | 
						|
  CefRefPtr<CefExtension> GetExtension(const CefString& extension_id) override;
 | 
						|
 | 
						|
  const CefRequestContextSettings& settings() const { return config_.settings; }
 | 
						|
 | 
						|
 private:
 | 
						|
  friend class CefRequestContext;
 | 
						|
 | 
						|
  struct Config {
 | 
						|
    // True if wrapping the global context.
 | 
						|
    bool is_global = false;
 | 
						|
 | 
						|
    // |settings| or |other| will be set when creating a new CefRequestContext
 | 
						|
    // via the API. When wrapping an existing CefBrowserContext* both will be
 | 
						|
    // empty and Initialize(CefBrowserContext*) will be called immediately after
 | 
						|
    // CefRequestContextImpl construction.
 | 
						|
    CefRequestContextSettings settings;
 | 
						|
    CefRefPtr<CefRequestContextImpl> other;
 | 
						|
 | 
						|
    // Optionally use this handler, in which case a CefBrowserContextProxy will
 | 
						|
    // be created.
 | 
						|
    CefRefPtr<CefRequestContextHandler> handler;
 | 
						|
 | 
						|
    // Used to uniquely identify CefRequestContext objects before an associated
 | 
						|
    // CefBrowserContext has been created. Should be set when a new
 | 
						|
    // CefRequestContext via the API.
 | 
						|
    int unique_id = -1;
 | 
						|
  };
 | 
						|
 | 
						|
  static CefRefPtr<CefRequestContextImpl> GetOrCreateRequestContext(
 | 
						|
      const Config& config);
 | 
						|
 | 
						|
  explicit CefRequestContextImpl(const Config& config);
 | 
						|
 | 
						|
  void Initialize();
 | 
						|
 | 
						|
  // Make sure the browser context exists. Only called on the UI thread.
 | 
						|
  void EnsureBrowserContext();
 | 
						|
 | 
						|
  void GetBrowserContextOnUIThread(
 | 
						|
      scoped_refptr<base::SingleThreadTaskRunner> task_runner,
 | 
						|
      const BrowserContextCallback& callback);
 | 
						|
  void GetRequestContextImplOnIOThread(
 | 
						|
      scoped_refptr<base::SingleThreadTaskRunner> task_runner,
 | 
						|
      const RequestContextCallback& callback,
 | 
						|
      CefBrowserContext* browser_context);
 | 
						|
 | 
						|
  void RegisterSchemeHandlerFactoryInternal(
 | 
						|
      const CefString& scheme_name,
 | 
						|
      const CefString& domain_name,
 | 
						|
      CefRefPtr<CefSchemeHandlerFactory> factory,
 | 
						|
      scoped_refptr<CefURLRequestContextGetterImpl> request_context);
 | 
						|
  void ClearSchemeHandlerFactoriesInternal(
 | 
						|
      scoped_refptr<CefURLRequestContextGetterImpl> request_context);
 | 
						|
  void PurgePluginListCacheInternal(bool reload_pages,
 | 
						|
                                    CefBrowserContext* browser_context);
 | 
						|
  void ClearCertificateExceptionsInternal(
 | 
						|
      CefRefPtr<CefCompletionCallback> callback,
 | 
						|
      CefBrowserContext* browser_context);
 | 
						|
  void CloseAllConnectionsInternal(
 | 
						|
      CefRefPtr<CefCompletionCallback> callback,
 | 
						|
      scoped_refptr<CefURLRequestContextGetterImpl> request_context);
 | 
						|
  void ResolveHostInternal(
 | 
						|
      const CefString& origin,
 | 
						|
      CefRefPtr<CefResolveCallback> callback,
 | 
						|
      scoped_refptr<CefURLRequestContextGetterImpl> request_context);
 | 
						|
 | 
						|
  CefBrowserContext* browser_context() const;
 | 
						|
 | 
						|
  // If *Impl then we must disassociate from it on destruction.
 | 
						|
  CefBrowserContextImpl* browser_context_impl_ = nullptr;
 | 
						|
  // If *Proxy then we own it.
 | 
						|
  std::unique_ptr<CefBrowserContextProxy> browser_context_proxy_;
 | 
						|
 | 
						|
  Config config_;
 | 
						|
 | 
						|
  // Owned by the CefBrowserContext.
 | 
						|
  CefURLRequestContextGetterImpl* request_context_getter_impl_ = nullptr;
 | 
						|
 | 
						|
  IMPLEMENT_REFCOUNTING_DELETE_ON_UIT(CefRequestContextImpl);
 | 
						|
  DISALLOW_COPY_AND_ASSIGN(CefRequestContextImpl);
 | 
						|
};
 | 
						|
 | 
						|
#endif  // CEF_LIBCEF_REQUEST_CONTEXT_IMPL_H_
 |