Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(6)

Side by Side Diff: chrome/browser/storage/storage_info_fetcher.cc

Issue 1661533002: Implement deletion of storage per site. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/storage/storage_info_fetcher.h" 5 #include "chrome/browser/storage/storage_info_fetcher.h"
6 6
7 #include "content/public/browser/browser_context.h"
7 #include "content/public/browser/browser_thread.h" 8 #include "content/public/browser/browser_thread.h"
8 9
10 using content::BrowserContext;
9 using content::BrowserThread; 11 using content::BrowserThread;
10 12
11 StorageInfoFetcher::StorageInfoFetcher(storage::QuotaManager* quota_manager) 13 StorageInfoFetcher::StorageInfoFetcher(storage::QuotaManager* quota_manager)
12 : quota_manager_(quota_manager) { 14 : quota_manager_(quota_manager) {
13 } 15 }
14 16
15 StorageInfoFetcher::~StorageInfoFetcher() { 17 StorageInfoFetcher::~StorageInfoFetcher() {
16 } 18 }
17 19
18 void StorageInfoFetcher::Run() { 20 void StorageInfoFetcher::FetchStorageInfo() {
19 // QuotaManager must be called on IO thread, but the callback must then be 21 // QuotaManager must be called on IO thread, but the callback must then be
20 // called on the UI thread. 22 // called on the UI thread.
21 BrowserThread::PostTask( 23 BrowserThread::PostTask(
22 BrowserThread::IO, FROM_HERE, 24 BrowserThread::IO, FROM_HERE,
23 base::Bind(&StorageInfoFetcher::GetUsageInfo, this, 25 base::Bind(&StorageInfoFetcher::GetUsageInfo, this,
24 base::Bind(&StorageInfoFetcher::OnGetUsageInfoInternal, this))); 26 base::Bind(&StorageInfoFetcher::OnGetUsageInfoInternal, this)));
25 } 27 }
26 28
29 void StorageInfoFetcher::ClearStorage(
30 const std::string& host, storage::StorageType type) {
31 BrowserThread::PostTask(
32 BrowserThread::IO, FROM_HERE,
33 base::Bind(&storage::QuotaManager::DeleteHostData,
34 quota_manager_,
35 host,
36 type,
37 storage::QuotaClient::kAllClientsMask,
38 base::Bind(&StorageInfoFetcher::OnUsageCleared,
michaelpg 2016/02/03 18:39:13 unindent
Finnur 2016/02/04 14:56:58 Done.
39 this)));
40 }
41
27 void StorageInfoFetcher::AddObserver(Observer* observer) { 42 void StorageInfoFetcher::AddObserver(Observer* observer) {
28 observers_.AddObserver(observer); 43 observers_.AddObserver(observer);
29 } 44 }
30 45
31 void StorageInfoFetcher::RemoveObserver(Observer* observer) { 46 void StorageInfoFetcher::RemoveObserver(Observer* observer) {
32 observers_.RemoveObserver(observer); 47 observers_.RemoveObserver(observer);
33 } 48 }
34 49
35 void StorageInfoFetcher::GetUsageInfo( 50 void StorageInfoFetcher::GetUsageInfo(
36 const storage::GetUsageInfoCallback& callback) { 51 const storage::GetUsageInfoCallback& callback) {
37 DCHECK_CURRENTLY_ON(content::BrowserThread::IO); 52 DCHECK_CURRENTLY_ON(content::BrowserThread::IO);
38 quota_manager_->GetUsageInfo(callback); 53 quota_manager_->GetUsageInfo(callback);
39 } 54 }
40 55
41 void StorageInfoFetcher::OnGetUsageInfoInternal( 56 void StorageInfoFetcher::OnGetUsageInfoInternal(
42 const storage::UsageInfoEntries& entries) { 57 const storage::UsageInfoEntries& entries) {
43 DCHECK_CURRENTLY_ON(content::BrowserThread::IO); 58 DCHECK_CURRENTLY_ON(content::BrowserThread::IO);
44 59
45 entries_.insert(entries_.begin(), entries.begin(), entries.end()); 60 entries_.insert(entries_.begin(), entries.begin(), entries.end());
46 BrowserThread::PostTask( 61 BrowserThread::PostTask(
47 BrowserThread::UI, FROM_HERE, 62 BrowserThread::UI, FROM_HERE,
48 base::Bind(&StorageInfoFetcher::InvokeCallback, this)); 63 base::Bind(&StorageInfoFetcher::InvokeCallback, this));
49 } 64 }
50 65
66 void StorageInfoFetcher::OnUsageCleared(storage::QuotaStatusCode code) {
67 DCHECK_CURRENTLY_ON(content::BrowserThread::IO);
68
69 FOR_EACH_OBSERVER(Observer, observers_, OnUsageInfoCleared());
70 }
71
51 void StorageInfoFetcher::InvokeCallback() { 72 void StorageInfoFetcher::InvokeCallback() {
52 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); 73 DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
53 74
54 FOR_EACH_OBSERVER(Observer, observers_, OnGetUsageInfo(entries_)); 75 FOR_EACH_OBSERVER(Observer, observers_, OnGetUsageInfo(entries_));
55 } 76 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698