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

Side by Side Diff: chrome/browser/browsing_data/browsing_data_indexed_db_helper.cc

Issue 124183002: Implement delete methods for the various CannedBrowsingDataHelpers. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase Created 6 years, 11 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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/browsing_data/browsing_data_indexed_db_helper.h" 5 #include "chrome/browser/browsing_data/browsing_data_indexed_db_helper.h"
6 6
7 #include <vector> 7 #include <vector>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/callback.h" 10 #include "base/callback.h"
11 #include "base/compiler_specific.h" 11 #include "base/compiler_specific.h"
12 #include "base/memory/scoped_ptr.h" 12 #include "base/memory/scoped_ptr.h"
13 #include "base/message_loop/message_loop.h"
14 #include "base/strings/string_util.h" 13 #include "base/strings/string_util.h"
15 #include "base/strings/utf_string_conversions.h" 14 #include "base/strings/utf_string_conversions.h"
16 #include "chrome/browser/browsing_data/browsing_data_helper.h" 15 #include "chrome/browser/browsing_data/browsing_data_helper.h"
17 #include "content/public/browser/browser_thread.h" 16 #include "content/public/browser/browser_thread.h"
18 #include "content/public/browser/indexed_db_context.h" 17 #include "content/public/browser/indexed_db_context.h"
19 18
20 using content::BrowserThread; 19 using content::BrowserThread;
21 using content::IndexedDBContext; 20 using content::IndexedDBContext;
22 using content::IndexedDBInfo; 21 using content::IndexedDBInfo;
23 22
24 namespace { 23 BrowsingDataIndexedDBHelper::BrowsingDataIndexedDBHelper(
25
26 class BrowsingDataIndexedDBHelperImpl : public BrowsingDataIndexedDBHelper {
27 public:
28 explicit BrowsingDataIndexedDBHelperImpl(
29 IndexedDBContext* indexed_db_context);
30
31 virtual void StartFetching(
32 const base::Callback<void(const std::list<IndexedDBInfo>&)>&
33 callback) OVERRIDE;
34 virtual void DeleteIndexedDB(const GURL& origin) OVERRIDE;
35
36 private:
37 virtual ~BrowsingDataIndexedDBHelperImpl();
38
39 // Enumerates all indexed database files in the IndexedDB thread.
40 void FetchIndexedDBInfoInIndexedDBThread();
41 // Notifies the completion callback in the UI thread.
42 void NotifyInUIThread();
43 // Delete a single indexed database in the IndexedDB thread.
44 void DeleteIndexedDBInIndexedDBThread(const GURL& origin);
45
46 scoped_refptr<IndexedDBContext> indexed_db_context_;
47
48 // Access to |indexed_db_info_| is triggered indirectly via the UI thread and
49 // guarded by |is_fetching_|. This means |indexed_db_info_| is only accessed
50 // while |is_fetching_| is true. The flag |is_fetching_| is only accessed on
51 // the UI thread.
52 // In the context of this class |indexed_db_info_| is only accessed on the
53 // context's IndexedDB thread.
54 std::list<IndexedDBInfo> indexed_db_info_;
55
56 // This only mutates on the UI thread.
57 base::Callback<void(const std::list<IndexedDBInfo>&)> completion_callback_;
58
59 // Indicates whether or not we're currently fetching information:
60 // it's true when StartFetching() is called in the UI thread, and it's reset
61 // after we notified the callback in the UI thread.
62 // This only mutates on the UI thread.
63 bool is_fetching_;
64
65 DISALLOW_COPY_AND_ASSIGN(BrowsingDataIndexedDBHelperImpl);
66 };
67
68 BrowsingDataIndexedDBHelperImpl::BrowsingDataIndexedDBHelperImpl(
69 IndexedDBContext* indexed_db_context) 24 IndexedDBContext* indexed_db_context)
70 : indexed_db_context_(indexed_db_context), 25 : indexed_db_context_(indexed_db_context),
71 is_fetching_(false) { 26 is_fetching_(false) {
72 DCHECK(indexed_db_context_.get()); 27 DCHECK(indexed_db_context_.get());
73 } 28 }
74 29
75 BrowsingDataIndexedDBHelperImpl::~BrowsingDataIndexedDBHelperImpl() { 30 BrowsingDataIndexedDBHelper::~BrowsingDataIndexedDBHelper() {
76 } 31 }
77 32
78 void BrowsingDataIndexedDBHelperImpl::StartFetching( 33 void BrowsingDataIndexedDBHelper::StartFetching(
79 const base::Callback<void(const std::list<IndexedDBInfo>&)>& callback) { 34 const base::Callback<void(const std::list<IndexedDBInfo>&)>& callback) {
80 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 35 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
81 DCHECK(!is_fetching_); 36 DCHECK(!is_fetching_);
82 DCHECK_EQ(false, callback.is_null()); 37 DCHECK_EQ(false, callback.is_null());
83 38
84 is_fetching_ = true; 39 is_fetching_ = true;
85 completion_callback_ = callback; 40 completion_callback_ = callback;
86 indexed_db_context_->TaskRunner()->PostTask( 41 indexed_db_context_->TaskRunner()->PostTask(
87 FROM_HERE, 42 FROM_HERE,
88 base::Bind( 43 base::Bind(
89 &BrowsingDataIndexedDBHelperImpl::FetchIndexedDBInfoInIndexedDBThread, 44 &BrowsingDataIndexedDBHelper::FetchIndexedDBInfoInIndexedDBThread,
90 this)); 45 this));
91 } 46 }
92 47
93 void BrowsingDataIndexedDBHelperImpl::DeleteIndexedDB( 48 void BrowsingDataIndexedDBHelper::DeleteIndexedDB(
94 const GURL& origin) { 49 const GURL& origin) {
95 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 50 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
96 indexed_db_context_->TaskRunner()->PostTask( 51 indexed_db_context_->TaskRunner()->PostTask(
97 FROM_HERE, 52 FROM_HERE,
98 base::Bind( 53 base::Bind(
99 &BrowsingDataIndexedDBHelperImpl::DeleteIndexedDBInIndexedDBThread, 54 &BrowsingDataIndexedDBHelper::DeleteIndexedDBInIndexedDBThread,
100 this, 55 this,
101 origin)); 56 origin));
102 } 57 }
103 58
104 void BrowsingDataIndexedDBHelperImpl::FetchIndexedDBInfoInIndexedDBThread() { 59 void BrowsingDataIndexedDBHelper::FetchIndexedDBInfoInIndexedDBThread() {
105 DCHECK(indexed_db_context_->TaskRunner()->RunsTasksOnCurrentThread()); 60 DCHECK(indexed_db_context_->TaskRunner()->RunsTasksOnCurrentThread());
106 std::vector<IndexedDBInfo> origins = indexed_db_context_->GetAllOriginsInfo(); 61 std::vector<IndexedDBInfo> origins = indexed_db_context_->GetAllOriginsInfo();
107 for (std::vector<IndexedDBInfo>::const_iterator iter = origins.begin(); 62 for (std::vector<IndexedDBInfo>::const_iterator iter = origins.begin();
108 iter != origins.end(); ++iter) { 63 iter != origins.end(); ++iter) {
109 const IndexedDBInfo& origin = *iter; 64 const IndexedDBInfo& origin = *iter;
110 if (!BrowsingDataHelper::HasWebScheme(origin.origin_)) 65 if (!BrowsingDataHelper::HasWebScheme(origin.origin_))
111 continue; // Non-websafe state is not considered browsing data. 66 continue; // Non-websafe state is not considered browsing data.
112 67
113 indexed_db_info_.push_back(origin); 68 indexed_db_info_.push_back(origin);
114 } 69 }
115 70
116 BrowserThread::PostTask( 71 BrowserThread::PostTask(
117 BrowserThread::UI, FROM_HERE, 72 BrowserThread::UI, FROM_HERE,
118 base::Bind(&BrowsingDataIndexedDBHelperImpl::NotifyInUIThread, this)); 73 base::Bind(&BrowsingDataIndexedDBHelper::NotifyInUIThread, this));
119 } 74 }
120 75
121 void BrowsingDataIndexedDBHelperImpl::NotifyInUIThread() { 76 void BrowsingDataIndexedDBHelper::NotifyInUIThread() {
122 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 77 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
123 DCHECK(is_fetching_); 78 DCHECK(is_fetching_);
124 completion_callback_.Run(indexed_db_info_); 79 completion_callback_.Run(indexed_db_info_);
125 completion_callback_.Reset(); 80 completion_callback_.Reset();
126 is_fetching_ = false; 81 is_fetching_ = false;
127 } 82 }
128 83
129 void BrowsingDataIndexedDBHelperImpl::DeleteIndexedDBInIndexedDBThread( 84 void BrowsingDataIndexedDBHelper::DeleteIndexedDBInIndexedDBThread(
130 const GURL& origin) { 85 const GURL& origin) {
131 DCHECK(indexed_db_context_->TaskRunner()->RunsTasksOnCurrentThread()); 86 DCHECK(indexed_db_context_->TaskRunner()->RunsTasksOnCurrentThread());
132 indexed_db_context_->DeleteForOrigin(origin); 87 indexed_db_context_->DeleteForOrigin(origin);
133 } 88 }
134 89
135 } // namespace
136
137
138 // static
139 BrowsingDataIndexedDBHelper* BrowsingDataIndexedDBHelper::Create(
140 IndexedDBContext* indexed_db_context) {
141 return new BrowsingDataIndexedDBHelperImpl(indexed_db_context);
142 }
143
144 CannedBrowsingDataIndexedDBHelper:: 90 CannedBrowsingDataIndexedDBHelper::
145 PendingIndexedDBInfo::PendingIndexedDBInfo(const GURL& origin, 91 PendingIndexedDBInfo::PendingIndexedDBInfo(const GURL& origin,
146 const base::string16& name) 92 const base::string16& name)
147 : origin(origin), 93 : origin(origin),
148 name(name) { 94 name(name) {
149 } 95 }
150 96
151 CannedBrowsingDataIndexedDBHelper:: 97 CannedBrowsingDataIndexedDBHelper::
152 PendingIndexedDBInfo::~PendingIndexedDBInfo() { 98 PendingIndexedDBInfo::~PendingIndexedDBInfo() {
153 } 99 }
154 100
155 bool CannedBrowsingDataIndexedDBHelper::PendingIndexedDBInfo::operator<( 101 bool CannedBrowsingDataIndexedDBHelper::PendingIndexedDBInfo::operator<(
156 const PendingIndexedDBInfo& other) const { 102 const PendingIndexedDBInfo& other) const {
157 if (origin == other.origin) 103 if (origin == other.origin)
158 return name < other.name; 104 return name < other.name;
159 return origin < other.origin; 105 return origin < other.origin;
160 } 106 }
161 107
162 CannedBrowsingDataIndexedDBHelper::CannedBrowsingDataIndexedDBHelper() 108 CannedBrowsingDataIndexedDBHelper::CannedBrowsingDataIndexedDBHelper(
163 : is_fetching_(false) { 109 content::IndexedDBContext* context)
110 : BrowsingDataIndexedDBHelper(context) {
164 } 111 }
165 112
166 CannedBrowsingDataIndexedDBHelper::~CannedBrowsingDataIndexedDBHelper() {} 113 CannedBrowsingDataIndexedDBHelper::~CannedBrowsingDataIndexedDBHelper() {}
167 114
168 CannedBrowsingDataIndexedDBHelper* CannedBrowsingDataIndexedDBHelper::Clone() { 115 CannedBrowsingDataIndexedDBHelper* CannedBrowsingDataIndexedDBHelper::Clone() {
169 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 116 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
170 CannedBrowsingDataIndexedDBHelper* clone = 117 CannedBrowsingDataIndexedDBHelper* clone =
171 new CannedBrowsingDataIndexedDBHelper(); 118 new CannedBrowsingDataIndexedDBHelper(indexed_db_context_);
172 119
173 clone->pending_indexed_db_info_ = pending_indexed_db_info_; 120 clone->pending_indexed_db_info_ = pending_indexed_db_info_;
174 clone->indexed_db_info_ = indexed_db_info_; 121 clone->indexed_db_info_ = indexed_db_info_;
175 return clone; 122 return clone;
176 } 123 }
177 124
178 void CannedBrowsingDataIndexedDBHelper::AddIndexedDB( 125 void CannedBrowsingDataIndexedDBHelper::AddIndexedDB(
179 const GURL& origin, const base::string16& name) { 126 const GURL& origin, const base::string16& name) {
180 if (!BrowsingDataHelper::HasWebScheme(origin)) 127 if (!BrowsingDataHelper::HasWebScheme(origin))
181 return; // Non-websafe state is not considered browsing data. 128 return; // Non-websafe state is not considered browsing data.
(...skipping 15 matching lines...) Expand all
197 } 144 }
198 145
199 const std::set<CannedBrowsingDataIndexedDBHelper::PendingIndexedDBInfo>& 146 const std::set<CannedBrowsingDataIndexedDBHelper::PendingIndexedDBInfo>&
200 CannedBrowsingDataIndexedDBHelper::GetIndexedDBInfo() const { 147 CannedBrowsingDataIndexedDBHelper::GetIndexedDBInfo() const {
201 return pending_indexed_db_info_; 148 return pending_indexed_db_info_;
202 } 149 }
203 150
204 void CannedBrowsingDataIndexedDBHelper::StartFetching( 151 void CannedBrowsingDataIndexedDBHelper::StartFetching(
205 const base::Callback<void(const std::list<IndexedDBInfo>&)>& callback) { 152 const base::Callback<void(const std::list<IndexedDBInfo>&)>& callback) {
206 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 153 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
207 DCHECK(!is_fetching_); 154 DCHECK(!callback.is_null());
208 DCHECK_EQ(false, callback.is_null());
209 155
210 is_fetching_ = true; 156 std::list<IndexedDBInfo> result;
211 completion_callback_ = callback;
212
213 // We post a task to emulate async fetching behavior.
214 base::MessageLoop::current()->PostTask(
215 FROM_HERE,
216 base::Bind(&CannedBrowsingDataIndexedDBHelper::
217 ConvertPendingInfo,
218 this));
219 }
220
221 void CannedBrowsingDataIndexedDBHelper::ConvertPendingInfo() {
222 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
223 indexed_db_info_.clear();
224 for (std::set<PendingIndexedDBInfo>::const_iterator 157 for (std::set<PendingIndexedDBInfo>::const_iterator
225 pending_info = pending_indexed_db_info_.begin(); 158 pending_info = pending_indexed_db_info_.begin();
226 pending_info != pending_indexed_db_info_.end(); ++pending_info) { 159 pending_info != pending_indexed_db_info_.end(); ++pending_info) {
227 IndexedDBInfo info( 160 IndexedDBInfo info(
228 pending_info->origin, 0, base::Time(), base::FilePath(), 0); 161 pending_info->origin, 0, base::Time(), base::FilePath(), 0);
229 indexed_db_info_.push_back(info); 162 result.push_back(info);
230 } 163 }
231 164
232 completion_callback_.Run(indexed_db_info_); 165 BrowserThread::PostTask(
233 completion_callback_.Reset(); 166 BrowserThread::UI, FROM_HERE, base::Bind(callback, result));
234 is_fetching_ = false;
235 } 167 }
168
169 void CannedBrowsingDataIndexedDBHelper::DeleteIndexedDB(
170 const GURL& origin) {
171 for (std::set<PendingIndexedDBInfo>::iterator it =
172 pending_indexed_db_info_.begin();
173 it != pending_indexed_db_info_.end(); ) {
174 if (it->origin == origin)
175 pending_indexed_db_info_.erase(it++);
176 else
177 ++it;
178 }
179 BrowsingDataIndexedDBHelper::DeleteIndexedDB(origin);
180 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698