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

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: Address nits 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, this)));
39 }
40
27 void StorageInfoFetcher::AddObserver(Observer* observer) { 41 void StorageInfoFetcher::AddObserver(Observer* observer) {
28 observers_.AddObserver(observer); 42 observers_.AddObserver(observer);
29 } 43 }
30 44
31 void StorageInfoFetcher::RemoveObserver(Observer* observer) { 45 void StorageInfoFetcher::RemoveObserver(Observer* observer) {
32 observers_.RemoveObserver(observer); 46 observers_.RemoveObserver(observer);
33 } 47 }
34 48
35 void StorageInfoFetcher::GetUsageInfo( 49 void StorageInfoFetcher::GetUsageInfo(
36 const storage::GetUsageInfoCallback& callback) { 50 const storage::GetUsageInfoCallback& callback) {
37 DCHECK_CURRENTLY_ON(content::BrowserThread::IO); 51 DCHECK_CURRENTLY_ON(content::BrowserThread::IO);
38 quota_manager_->GetUsageInfo(callback); 52 quota_manager_->GetUsageInfo(callback);
39 } 53 }
40 54
41 void StorageInfoFetcher::OnGetUsageInfoInternal( 55 void StorageInfoFetcher::OnGetUsageInfoInternal(
42 const storage::UsageInfoEntries& entries) { 56 const storage::UsageInfoEntries& entries) {
43 DCHECK_CURRENTLY_ON(content::BrowserThread::IO); 57 DCHECK_CURRENTLY_ON(content::BrowserThread::IO);
44 58
45 entries_.insert(entries_.begin(), entries.begin(), entries.end()); 59 entries_.insert(entries_.begin(), entries.begin(), entries.end());
46 BrowserThread::PostTask( 60 BrowserThread::PostTask(
47 BrowserThread::UI, FROM_HERE, 61 BrowserThread::UI, FROM_HERE,
48 base::Bind(&StorageInfoFetcher::InvokeCallback, this)); 62 base::Bind(&StorageInfoFetcher::InvokeCallback, this));
49 } 63 }
50 64
65 void StorageInfoFetcher::OnUsageCleared(storage::QuotaStatusCode code) {
66 DCHECK_CURRENTLY_ON(content::BrowserThread::IO);
67
68 FOR_EACH_OBSERVER(Observer, observers_, OnUsageInfoCleared(code));
69 }
70
51 void StorageInfoFetcher::InvokeCallback() { 71 void StorageInfoFetcher::InvokeCallback() {
52 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); 72 DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
53 73
54 FOR_EACH_OBSERVER(Observer, observers_, OnGetUsageInfo(entries_)); 74 FOR_EACH_OBSERVER(Observer, observers_, OnGetUsageInfo(entries_));
55 } 75 }
OLDNEW
« no previous file with comments | « chrome/browser/storage/storage_info_fetcher.h ('k') | chrome/browser/ui/webui/settings/site_settings_handler.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698