blob: 05f80861400fb6f69bc88d6b2b777395b3c87341 [file] [log] [blame]
// Copyright (c) 2012 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 CONTENT_PUBLIC_BROWSER_BROWSER_CONTEXT_H_
#define CONTENT_PUBLIC_BROWSER_BROWSER_CONTEXT_H_
#include <stddef.h>
#include <stdint.h>
#include <map>
#include <memory>
#include "base/callback_forward.h"
#include "base/containers/hash_tables.h"
#include "base/memory/linked_ptr.h"
#include "base/memory/scoped_vector.h"
#include "base/supports_user_data.h"
#include "content/common/content_export.h"
#include "content/public/browser/zoom_level_delegate.h"
#include "content/public/common/push_event_payload.h"
#include "content/public/common/push_messaging_status.h"
#include "net/url_request/url_request_interceptor.h"
#include "net/url_request/url_request_job_factory.h"
class GURL;
namespace base {
class FilePath;
class Time;
}
namespace shell {
class Connector;
}
namespace storage {
class ExternalMountPoints;
}
namespace net {
class URLRequestContextGetter;
}
namespace storage {
class SpecialStoragePolicy;
}
namespace content {
class BackgroundSyncController;
class BlobHandle;
class BrowserPluginGuestManager;
class DownloadManager;
class DownloadManagerDelegate;
class IndexedDBContext;
class PermissionManager;
class PushMessagingService;
class ResourceContext;
class SiteInstance;
class StoragePartition;
class SSLHostStateDelegate;
// A mapping from the scheme name to the protocol handler that services its
// content.
typedef std::map<
std::string, linked_ptr<net::URLRequestJobFactory::ProtocolHandler> >
ProtocolHandlerMap;
// A scoped vector of protocol interceptors.
typedef ScopedVector<net::URLRequestInterceptor>
URLRequestInterceptorScopedVector;
// This class holds the context needed for a browsing session.
// It lives on the UI thread. All these methods must only be called on the UI
// thread.
class CONTENT_EXPORT BrowserContext : public base::SupportsUserData {
public:
static DownloadManager* GetDownloadManager(BrowserContext* browser_context);
// Returns BrowserContext specific external mount points. It may return
// nullptr if the context doesn't have any BrowserContext specific external
// mount points. Currenty, non-nullptr value is returned only on ChromeOS.
static storage::ExternalMountPoints* GetMountPoints(BrowserContext* context);
static content::StoragePartition* GetStoragePartition(
BrowserContext* browser_context, SiteInstance* site_instance);
static content::StoragePartition* GetStoragePartitionForSite(
BrowserContext* browser_context, const GURL& site);
typedef base::Callback<void(StoragePartition*)> StoragePartitionCallback;
static void ForEachStoragePartition(
BrowserContext* browser_context,
const StoragePartitionCallback& callback);
static void AsyncObliterateStoragePartition(
BrowserContext* browser_context,
const GURL& site,
const base::Closure& on_gc_required);
// This function clears the contents of |active_paths| but does not take
// ownership of the pointer.
static void GarbageCollectStoragePartitions(
BrowserContext* browser_context,
std::unique_ptr<base::hash_set<base::FilePath>> active_paths,
const base::Closure& done);
static content::StoragePartition* GetDefaultStoragePartition(
BrowserContext* browser_context);
typedef base::Callback<void(std::unique_ptr<BlobHandle>)> BlobCallback;
// |callback| returns a nullptr scoped_ptr on failure.
static void CreateMemoryBackedBlob(BrowserContext* browser_context,
const char* data, size_t length,
const BlobCallback& callback);
// |callback| returns a nullptr scoped_ptr on failure.
static void CreateFileBackedBlob(BrowserContext* browser_context,
const base::FilePath& path,
int64_t offset,
int64_t size,
const base::Time& expected_modification_time,
const BlobCallback& callback);
// Delivers a push message with |data| to the Service Worker identified by
// |origin| and |service_worker_registration_id|.
static void DeliverPushMessage(
BrowserContext* browser_context,
const GURL& origin,
int64_t service_worker_registration_id,
const PushEventPayload& payload,
const base::Callback<void(PushDeliveryStatus)>& callback);
static void NotifyWillBeDestroyed(BrowserContext* browser_context);
// Ensures that the corresponding ResourceContext is initialized. Normally the
// BrowserContext initializs the corresponding getters when its objects are
// created, but if the embedder wants to pass the ResourceContext to another
// thread before they use BrowserContext, they should call this to make sure
// that the ResourceContext is ready.
static void EnsureResourceContextInitialized(BrowserContext* browser_context);
// Tells the HTML5 objects on this context to persist their session state
// across the next restart.
static void SaveSessionState(BrowserContext* browser_context);
static void SetDownloadManagerForTesting(BrowserContext* browser_context,
DownloadManager* download_manager);
// Makes mojo aware of this BrowserContext, and assigns a user ID number to
// it. Should be called for each BrowserContext created.
static void Initialize(BrowserContext* browser_context,
const base::FilePath& path);
// Returns a Shell User ID associated with this BrowserContext. This ID is not
// persistent across runs. See
// services/shell/public/interfaces/connector.mojom. By default, this user id
// is randomly generated when Initialize() is called.
static const std::string& GetShellUserIdFor(BrowserContext* browser_context);
// Returns the BrowserContext associated with |user_id|, or nullptr if no
// BrowserContext exists for that |user_id|.
static BrowserContext* GetBrowserContextForShellUserId(
const std::string& user_id);
// Returns a Connector associated with this BrowserContext, which can be used
// to connect to service instances bound as this user.
static shell::Connector* GetShellConnectorFor(
BrowserContext* browser_context);
~BrowserContext() override;
// Creates a delegate to initialize a HostZoomMap and persist its information.
// This is called during creation of each StoragePartition.
virtual std::unique_ptr<ZoomLevelDelegate> CreateZoomLevelDelegate(
const base::FilePath& partition_path) = 0;
// Returns the path of the directory where this context's data is stored.
virtual base::FilePath GetPath() const = 0;
// Return whether this context is incognito. Default is false.
virtual bool IsOffTheRecord() const = 0;
// Returns the resource context.
virtual ResourceContext* GetResourceContext() = 0;
// Returns the DownloadManagerDelegate for this context. This will be called
// once per context. The embedder owns the delegate and is responsible for
// ensuring that it outlives DownloadManager. It's valid to return nullptr.
virtual DownloadManagerDelegate* GetDownloadManagerDelegate() = 0;
// Returns the guest manager for this context.
virtual BrowserPluginGuestManager* GetGuestManager() = 0;
// Returns a special storage policy implementation, or nullptr.
virtual storage::SpecialStoragePolicy* GetSpecialStoragePolicy() = 0;
// Returns a push messaging service. The embedder owns the service, and is
// responsible for ensuring that it outlives RenderProcessHost. It's valid to
// return nullptr.
virtual PushMessagingService* GetPushMessagingService() = 0;
// Returns the SSL host state decisions for this context. The context may
// return nullptr, implementing the default exception storage strategy.
virtual SSLHostStateDelegate* GetSSLHostStateDelegate() = 0;
// Returns the PermissionManager associated with that context if any, nullptr
// otherwise.
virtual PermissionManager* GetPermissionManager() = 0;
// Returns the BackgroundSyncController associated with that context if any,
// nullptr otherwise.
virtual BackgroundSyncController* GetBackgroundSyncController() = 0;
// Creates the main net::URLRequestContextGetter. It's called only once.
virtual net::URLRequestContextGetter* CreateRequestContext(
ProtocolHandlerMap* protocol_handlers,
URLRequestInterceptorScopedVector request_interceptors) = 0;
// Creates the net::URLRequestContextGetter for a StoragePartition. It's
// called only once per partition_path.
virtual net::URLRequestContextGetter* CreateRequestContextForStoragePartition(
const base::FilePath& partition_path,
bool in_memory,
ProtocolHandlerMap* protocol_handlers,
URLRequestInterceptorScopedVector request_interceptors) = 0;
// Creates the main net::URLRequestContextGetter for media resources. It's
// called only once.
virtual net::URLRequestContextGetter* CreateMediaRequestContext() = 0;
// Creates the media net::URLRequestContextGetter for a StoragePartition. It's
// called only once per partition_path.
virtual net::URLRequestContextGetter*
CreateMediaRequestContextForStoragePartition(
const base::FilePath& partition_path,
bool in_memory) = 0;
};
} // namespace content
#endif // CONTENT_PUBLIC_BROWSER_BROWSER_CONTEXT_H_