// 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-CHROMIUM file. #include "browser/browser_context.h" #include "browser/brightray_paths.h" #include "browser/inspectable_web_contents_impl.h" #include "browser/network_delegate.h" #include "browser/permission_manager.h" #include "common/application_info.h" #include "base/files/file_path.h" #include "base/path_service.h" #include "base/prefs/json_pref_store.h" #include "base/prefs/pref_registry_simple.h" #include "base/prefs/pref_service.h" #include "base/prefs/pref_service_factory.h" #include "content/public/browser/browser_thread.h" #include "content/public/browser/resource_context.h" #include "content/public/browser/storage_partition.h" #include "net/ssl/client_cert_store.h" #if defined(USE_NSS_CERTS) #include "net/ssl/client_cert_store_nss.h" #elif defined(OS_WIN) #include "net/ssl/client_cert_store_win.h" #elif defined(OS_MACOSX) #include "net/ssl/client_cert_store_mac.h" #endif using content::BrowserThread; namespace brightray { class BrowserContext::ResourceContext : public content::ResourceContext { public: ResourceContext() : getter_(nullptr) {} void set_url_request_context_getter(URLRequestContextGetter* getter) { getter_ = getter; } private: net::HostResolver* GetHostResolver() override { return getter_->host_resolver(); } net::URLRequestContext* GetRequestContext() override { return getter_->GetURLRequestContext(); } scoped_ptr CreateClientCertStore() override { #if defined(USE_NSS_CERTS) return scoped_ptr(new net::ClientCertStoreNSS( net::ClientCertStoreNSS::PasswordDelegateFactory())); #elif defined(OS_WIN) return scoped_ptr(new net::ClientCertStoreWin()); #elif defined(OS_MACOSX) return scoped_ptr(new net::ClientCertStoreMac()); #elif defined(USE_OPENSSL) return scoped_ptr(); #endif } URLRequestContextGetter* getter_; }; BrowserContext::BrowserContext() : resource_context_(new ResourceContext) { } void BrowserContext::Initialize(const base::FilePath& partition_path, bool in_memory) { if (!PathService::Get(DIR_USER_DATA, &path_)) { PathService::Get(DIR_APP_DATA, &path_); path_ = path_.Append(base::FilePath::FromUTF8Unsafe(GetApplicationName())); PathService::Override(DIR_USER_DATA, path_); } if (!partition_path.empty()) path_ = path_.Append(partition_path); in_memory_ = in_memory; auto prefs_path = GetPath().Append(FILE_PATH_LITERAL("Preferences")); base::PrefServiceFactory prefs_factory; prefs_factory.SetUserPrefsFile(prefs_path, JsonPrefStore::GetTaskRunnerForFile( prefs_path, BrowserThread::GetBlockingPool()).get()); auto registry = make_scoped_refptr(new PrefRegistrySimple); RegisterInternalPrefs(registry.get()); RegisterPrefs(registry.get()); prefs_ = prefs_factory.Create(registry.get()); } BrowserContext::~BrowserContext() { BrowserThread::DeleteSoon(BrowserThread::IO, FROM_HERE, resource_context_.release()); } void BrowserContext::RegisterInternalPrefs(PrefRegistrySimple* registry) { InspectableWebContentsImpl::RegisterPrefs(registry); } net::URLRequestContextGetter* BrowserContext::CreateRequestContext( NetLog* net_log, content::ProtocolHandlerMap* protocol_handlers, content::URLRequestInterceptorScopedVector protocol_interceptors) { DCHECK(!url_request_getter_.get()); url_request_getter_ = new URLRequestContextGetter( this, net_log, GetPath(), in_memory_, BrowserThread::UnsafeGetMessageLoopForThread(BrowserThread::IO), BrowserThread::UnsafeGetMessageLoopForThread(BrowserThread::FILE), protocol_handlers, protocol_interceptors.Pass()); resource_context_->set_url_request_context_getter(url_request_getter_.get()); return url_request_getter_.get(); } net::NetworkDelegate* BrowserContext::CreateNetworkDelegate() { return new NetworkDelegate; } base::FilePath BrowserContext::GetPath() const { return path_; } scoped_ptr BrowserContext::CreateZoomLevelDelegate( const base::FilePath& partition_path) { return scoped_ptr(); } bool BrowserContext::IsOffTheRecord() const { return in_memory_; } net::URLRequestContextGetter* BrowserContext::GetRequestContext() { return GetDefaultStoragePartition(this)->GetURLRequestContext(); } net::URLRequestContextGetter* BrowserContext::GetRequestContextForRenderProcess( int renderer_child_id) { return GetRequestContext(); } net::URLRequestContextGetter* BrowserContext::GetMediaRequestContext() { return GetRequestContext(); } net::URLRequestContextGetter* BrowserContext::GetMediaRequestContextForRenderProcess( int renderer_child_id) { return GetRequestContext(); } net::URLRequestContextGetter* BrowserContext::GetMediaRequestContextForStoragePartition( const base::FilePath& partition_path, bool in_memory) { return GetRequestContext(); } content::ResourceContext* BrowserContext::GetResourceContext() { return resource_context_.get(); } content::DownloadManagerDelegate* BrowserContext::GetDownloadManagerDelegate() { return nullptr; } content::BrowserPluginGuestManager* BrowserContext::GetGuestManager() { return nullptr; } storage::SpecialStoragePolicy* BrowserContext::GetSpecialStoragePolicy() { return nullptr; } content::PushMessagingService* BrowserContext::GetPushMessagingService() { return nullptr; } content::SSLHostStateDelegate* BrowserContext::GetSSLHostStateDelegate() { return nullptr; } content::PermissionManager* BrowserContext::GetPermissionManager() { if (!permission_manager_.get()) permission_manager_.reset(new PermissionManager); return permission_manager_.get(); } } // namespace brightray