blob: 96730777eb284aebf2aacc6ac0f30041107801f3 [file] [log] [blame]
// Copyright (c) 2020 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_BROWSER_INDEXED_DB_INDEXED_DB_CONTROL_WRAPPER_H_
#define CONTENT_BROWSER_INDEXED_DB_INDEXED_DB_CONTROL_WRAPPER_H_
#include "base/threading/sequence_bound.h"
#include "components/services/storage/public/mojom/indexed_db_control.mojom.h"
#include "content/browser/indexed_db/indexed_db_context_impl.h"
namespace content {
// All functions should be called on the UI thread.
class CONTENT_EXPORT IndexedDBControlWrapper
: public storage::mojom::IndexedDBControl {
public:
explicit IndexedDBControlWrapper(
const base::FilePath& data_path,
scoped_refptr<storage::SpecialStoragePolicy> special_storage_policy,
scoped_refptr<storage::QuotaManagerProxy> quota_manager_proxy,
base::Clock* clock,
mojo::PendingRemote<storage::mojom::BlobStorageContext>
blob_storage_context,
mojo::PendingRemote<storage::mojom::NativeFileSystemContext>
native_file_system_context,
scoped_refptr<base::SequencedTaskRunner> io_task_runner,
scoped_refptr<base::SequencedTaskRunner> custom_task_runner);
~IndexedDBControlWrapper() override;
// mojom::IndexedDBControl implementation:
void BindIndexedDB(
const url::Origin& origin,
mojo::PendingReceiver<blink::mojom::IDBFactory> receiver) override;
void GetUsage(GetUsageCallback usage_callback) override;
void DeleteForOrigin(const url::Origin& origin,
DeleteForOriginCallback callback) override;
void ForceClose(const url::Origin& origin,
storage::mojom::ForceCloseReason reason,
base::OnceClosure callback) override;
void GetConnectionCount(const url::Origin& origin,
GetConnectionCountCallback callback) override;
void DownloadOriginData(const url::Origin& origin,
DownloadOriginDataCallback callback) override;
void GetAllOriginsDetails(GetAllOriginsDetailsCallback callback) override;
void SetForceKeepSessionState() override;
void ApplyPolicyUpdates(
std::vector<storage::mojom::IndexedDBStoragePolicyUpdatePtr>
policy_updates) override;
void BindTestInterface(
mojo::PendingReceiver<storage::mojom::IndexedDBControlTest> receiver)
override;
void AddObserver(
mojo::PendingRemote<storage::mojom::IndexedDBObserver> observer) override;
// TODO(enne): remove this once IndexedDB moves to storage service.
IndexedDBContextImpl* GetIndexedDBContextInternal() { return context_.get(); }
private:
void OnSpecialStoragePolicyChanged();
void TrackOriginPolicyState(const url::Origin& origin);
bool ShouldPurgeOnShutdown(const GURL& origin);
void BindRemoteIfNeeded();
// Special storage policy may be null.
scoped_refptr<storage::SpecialStoragePolicy> special_storage_policy_;
// Observer for the SpecialStoragePolicy on the IO thread. May be null.
class StoragePolicyObserver;
base::SequenceBound<StoragePolicyObserver> storage_policy_observer_;
mojo::Remote<storage::mojom::IndexedDBControl> indexed_db_control_;
scoped_refptr<IndexedDBContextImpl> context_;
struct OriginState {
// Indicates that storage for this origin should be purged on shutdown.
bool should_purge_on_shutdown = false;
// Indicates the last value for |purge_on_shutdown| communicated to the
// IndexedDB implementation.
bool will_purge_on_shutdown = false;
};
// NOTE: The GURL key is specifically an origin GURL.
// Special storage policy uses GURLs and not Origins, so it's simpler
// to store everything in GURL form.
std::map<GURL, OriginState> origin_state_;
SEQUENCE_CHECKER(sequence_checker_);
base::WeakPtrFactory<IndexedDBControlWrapper> weak_factory_{this};
DISALLOW_COPY_AND_ASSIGN(IndexedDBControlWrapper);
};
} // namespace content
#endif // CONTENT_BROWSER_INDEXED_DB_INDEXED_DB_CONTROL_WRAPPER_H_