| Index: content/browser/storage_partition_impl.cc
|
| diff --git a/content/browser/storage_partition_impl.cc b/content/browser/storage_partition_impl.cc
|
| index 01dc70688f27b2b916a3fbd5694569667fabb006..dbea3089dcedd5db9aadf7a77f1ca91fa4c4a054 100644
|
| --- a/content/browser/storage_partition_impl.cc
|
| +++ b/content/browser/storage_partition_impl.cc
|
| @@ -15,6 +15,7 @@
|
| #include "base/sequenced_task_runner.h"
|
| #include "base/single_thread_task_runner.h"
|
| #include "base/strings/utf_string_conversions.h"
|
| +#include "content/browser/blob_storage/chrome_blob_storage_context.h"
|
| #include "content/browser/browser_main_loop.h"
|
| #include "content/browser/browsing_data/storage_partition_http_cache_data_remover.h"
|
| #include "content/browser/fileapi/browser_file_system_helper.h"
|
| @@ -40,6 +41,7 @@
|
| #include "net/url_request/url_request_context_getter.h"
|
| #include "ppapi/features/features.h"
|
| #include "services/service_manager/public/cpp/connector.h"
|
| +#include "storage/browser/blob/blob_storage_context.h"
|
| #include "storage/browser/database/database_tracker.h"
|
| #include "storage/browser/quota/quota_manager.h"
|
|
|
| @@ -230,6 +232,12 @@ void ClearSessionStorageOnUIThread(
|
| callback));
|
| }
|
|
|
| +base::WeakPtr<storage::BlobStorageContext> BlobStorageContextGetter(
|
| + scoped_refptr<ChromeBlobStorageContext> blob_context) {
|
| + DCHECK_CURRENTLY_ON(BrowserThread::IO);
|
| + return blob_context->context()->AsWeakPtr();
|
| +}
|
| +
|
| } // namespace
|
|
|
| // Static.
|
| @@ -529,6 +537,13 @@ std::unique_ptr<StoragePartitionImpl> StoragePartitionImpl::Create(
|
| network_service->CreateNetworkContext(
|
| MakeRequest(&partition->network_context_), std::move(context_params));
|
|
|
| + scoped_refptr<ChromeBlobStorageContext> blob_context =
|
| + ChromeBlobStorageContext::GetFor(context);
|
| + BlobURLLoaderFactory::BlobContextGetter blob_getter =
|
| + base::BindOnce(&BlobStorageContextGetter, blob_context);
|
| + partition->blob_url_loader_factory_ = new BlobURLLoaderFactory(
|
| + std::move(blob_getter), partition->filesystem_context_);
|
| +
|
| partition->url_loader_factory_getter_ = new URLLoaderFactoryGetter();
|
| partition->url_loader_factory_getter_->Initialize(partition.get());
|
| }
|
| @@ -623,6 +638,10 @@ StoragePartitionImpl::GetBluetoothAllowedDevicesMap() {
|
| return bluetooth_allowed_devices_map_.get();
|
| }
|
|
|
| +BlobURLLoaderFactory* StoragePartitionImpl::GetBlobURLLoaderFactory() {
|
| + return blob_url_loader_factory_.get();
|
| +}
|
| +
|
| void StoragePartitionImpl::OpenLocalStorage(
|
| const url::Origin& origin,
|
| mojo::InterfaceRequest<mojom::LevelDBWrapper> request) {
|
|
|