Chromium Code Reviews| OLD | NEW |
|---|---|
| 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/cookies_tree_model.h" | 5 #include "chrome/browser/cookies_tree_model.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <functional> | 8 #include <functional> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| 11 #include "base/bind.h" | 11 #include "base/bind.h" |
| 12 #include "base/memory/linked_ptr.h" | 12 #include "base/memory/linked_ptr.h" |
| 13 #include "base/string_util.h" | 13 #include "base/string_util.h" |
| 14 #include "base/utf_string_conversions.h" | 14 #include "base/utf_string_conversions.h" |
| 15 #include "chrome/browser/browsing_data_cookie_helper.h" | 15 #include "chrome/browser/browsing_data_cookie_helper.h" |
| 16 #include "chrome/browser/browsing_data_server_bound_cert_helper.h" | 16 #include "chrome/browser/browsing_data_server_bound_cert_helper.h" |
| 17 #include "chrome/browser/content_settings/cookie_settings.h" | 17 #include "chrome/browser/content_settings/cookie_settings.h" |
| 18 #include "chrome/browser/extensions/extension_service.h" | 18 #include "chrome/browser/extensions/extension_service.h" |
| 19 #include "chrome/browser/extensions/extension_special_storage_policy.h" | |
| 19 #include "grit/generated_resources.h" | 20 #include "grit/generated_resources.h" |
| 20 #include "grit/theme_resources.h" | 21 #include "grit/theme_resources.h" |
| 21 #include "grit/theme_resources_standard.h" | 22 #include "grit/theme_resources_standard.h" |
| 22 #include "grit/ui_resources.h" | 23 #include "grit/ui_resources.h" |
| 23 #include "net/base/registry_controlled_domain.h" | 24 #include "net/base/registry_controlled_domain.h" |
| 24 #include "net/cookies/cookie_monster.h" | 25 #include "net/cookies/cookie_monster.h" |
| 25 #include "net/url_request/url_request_context.h" | 26 #include "net/url_request/url_request_context.h" |
| 26 #include "ui/base/l10n/l10n_util.h" | 27 #include "ui/base/l10n/l10n_util.h" |
| 27 #include "ui/base/resource/resource_bundle.h" | 28 #include "ui/base/resource/resource_bundle.h" |
| 28 #include "ui/gfx/image/image_skia.h" | 29 #include "ui/gfx/image/image_skia.h" |
| 29 | 30 |
| 30 static const char kFileOriginNodeName[] = "file://"; | 31 static const char kFileHostNodeName[] = "file://"; |
| 32 | |
| 33 namespace { | |
| 34 | |
| 35 bool TypeIsProtected(CookieTreeNode::DetailedInfo::NodeType type) { | |
| 36 switch (type) { | |
| 37 case CookieTreeNode::DetailedInfo::TYPE_COOKIE: | |
| 38 return false; | |
|
marja
2012/07/09 08:11:43
Hmm, didn't jochen@ just make it so that cookies a
Bernhard Bauer
2012/07/09 09:50:48
Yeah, Clear On Exit does something different from
| |
| 39 case CookieTreeNode::DetailedInfo::TYPE_DATABASE: | |
| 40 return true; | |
| 41 case CookieTreeNode::DetailedInfo::TYPE_LOCAL_STORAGE: | |
| 42 return true; | |
| 43 case CookieTreeNode::DetailedInfo::TYPE_SESSION_STORAGE: | |
| 44 return true; | |
| 45 case CookieTreeNode::DetailedInfo::TYPE_APPCACHE: | |
| 46 return true; | |
| 47 case CookieTreeNode::DetailedInfo::TYPE_INDEXED_DB: | |
| 48 return true; | |
| 49 case CookieTreeNode::DetailedInfo::TYPE_FILE_SYSTEM: | |
| 50 return true; | |
| 51 case CookieTreeNode::DetailedInfo::TYPE_QUOTA: | |
| 52 return true; | |
| 53 case CookieTreeNode::DetailedInfo::TYPE_SERVER_BOUND_CERT: | |
| 54 return false; | |
| 55 default: | |
| 56 break; | |
| 57 } | |
| 58 return false; | |
| 59 } | |
| 60 | |
| 61 } // namespace | |
| 62 | |
| 63 CookieTreeNode::DetailedInfo::DetailedInfo() | |
| 64 : node_type(TYPE_NONE), | |
| 65 cookie(NULL), | |
| 66 database_info(NULL), | |
| 67 local_storage_info(NULL), | |
| 68 session_storage_info(NULL), | |
| 69 appcache_info(NULL), | |
| 70 indexed_db_info(NULL), | |
| 71 file_system_info(NULL), | |
| 72 quota_info(NULL), | |
| 73 server_bound_cert(NULL) {} | |
| 74 | |
| 75 CookieTreeNode::DetailedInfo::~DetailedInfo() {} | |
| 76 | |
| 77 CookieTreeNode::DetailedInfo& CookieTreeNode::DetailedInfo::Init( | |
| 78 NodeType type) { | |
| 79 DCHECK_EQ(TYPE_NONE, node_type); | |
| 80 node_type = type; | |
| 81 return *this; | |
| 82 } | |
| 83 | |
| 84 CookieTreeNode::DetailedInfo& CookieTreeNode::DetailedInfo::InitCookie( | |
| 85 const net::CookieMonster::CanonicalCookie* cookie) { | |
| 86 Init(TYPE_COOKIE); | |
| 87 this->cookie = cookie; | |
| 88 return *this; | |
| 89 } | |
| 90 | |
| 91 CookieTreeNode::DetailedInfo& CookieTreeNode::DetailedInfo::InitDatabase( | |
| 92 const BrowsingDataDatabaseHelper::DatabaseInfo* database_info) { | |
| 93 Init(TYPE_DATABASE); | |
| 94 this->database_info = database_info; | |
| 95 origin = GURL(database_info->origin); | |
| 96 return *this; | |
| 97 } | |
| 98 | |
| 99 CookieTreeNode::DetailedInfo& CookieTreeNode::DetailedInfo::InitLocalStorage( | |
| 100 const BrowsingDataLocalStorageHelper::LocalStorageInfo* | |
| 101 local_storage_info) { | |
| 102 Init(TYPE_LOCAL_STORAGE); | |
| 103 this->local_storage_info = local_storage_info; | |
| 104 origin = local_storage_info->origin_url; | |
| 105 return *this; | |
| 106 } | |
| 107 | |
| 108 CookieTreeNode::DetailedInfo& CookieTreeNode::DetailedInfo::InitSessionStorage( | |
| 109 const BrowsingDataLocalStorageHelper::LocalStorageInfo* | |
| 110 session_storage_info) { | |
| 111 Init(TYPE_SESSION_STORAGE); | |
| 112 this->session_storage_info = session_storage_info; | |
| 113 origin = session_storage_info->origin_url; | |
| 114 return *this; | |
| 115 } | |
| 116 | |
| 117 CookieTreeNode::DetailedInfo& CookieTreeNode::DetailedInfo::InitAppCache( | |
| 118 const GURL& origin, | |
| 119 const appcache::AppCacheInfo* appcache_info) { | |
| 120 Init(TYPE_APPCACHE); | |
| 121 this->appcache_info = appcache_info; | |
| 122 this->origin = origin; | |
| 123 return *this; | |
| 124 } | |
| 125 | |
| 126 CookieTreeNode::DetailedInfo& CookieTreeNode::DetailedInfo::InitIndexedDB( | |
| 127 const BrowsingDataIndexedDBHelper::IndexedDBInfo* indexed_db_info) { | |
| 128 Init(TYPE_INDEXED_DB); | |
| 129 this->indexed_db_info = indexed_db_info; | |
| 130 this->origin = indexed_db_info->origin; | |
| 131 return *this; | |
| 132 } | |
| 133 | |
| 134 CookieTreeNode::DetailedInfo& CookieTreeNode::DetailedInfo::InitFileSystem( | |
| 135 const BrowsingDataFileSystemHelper::FileSystemInfo* file_system_info) { | |
| 136 Init(TYPE_FILE_SYSTEM); | |
| 137 this->file_system_info = file_system_info; | |
| 138 this->origin = file_system_info->origin; | |
| 139 return *this; | |
| 140 } | |
| 141 | |
| 142 CookieTreeNode::DetailedInfo& CookieTreeNode::DetailedInfo::InitQuota( | |
| 143 const BrowsingDataQuotaHelper::QuotaInfo* quota_info) { | |
| 144 Init(TYPE_QUOTA); | |
| 145 this->quota_info = quota_info; | |
| 146 return *this; | |
| 147 } | |
| 148 | |
| 149 CookieTreeNode::DetailedInfo& CookieTreeNode::DetailedInfo::InitServerBoundCert( | |
| 150 const net::ServerBoundCertStore::ServerBoundCert* server_bound_cert) { | |
| 151 Init(TYPE_SERVER_BOUND_CERT); | |
| 152 this->server_bound_cert = server_bound_cert; | |
| 153 return *this; | |
| 154 } | |
| 31 | 155 |
| 32 /////////////////////////////////////////////////////////////////////////////// | 156 /////////////////////////////////////////////////////////////////////////////// |
| 33 // CookieTreeNode, public: | 157 // CookieTreeNode, public: |
| 34 | 158 |
| 35 void CookieTreeNode::DeleteStoredObjects() { | 159 void CookieTreeNode::DeleteStoredObjects() { |
| 36 std::for_each(children().begin(), | 160 std::for_each(children().begin(), |
| 37 children().end(), | 161 children().end(), |
| 38 std::mem_fun(&CookieTreeNode::DeleteStoredObjects)); | 162 std::mem_fun(&CookieTreeNode::DeleteStoredObjects)); |
| 39 } | 163 } |
| 40 | 164 |
| (...skipping 15 matching lines...) Expand all Loading... | |
| 56 | 180 |
| 57 CookieTreeCookieNode::~CookieTreeCookieNode() {} | 181 CookieTreeCookieNode::~CookieTreeCookieNode() {} |
| 58 | 182 |
| 59 void CookieTreeCookieNode::DeleteStoredObjects() { | 183 void CookieTreeCookieNode::DeleteStoredObjects() { |
| 60 // notify CookieMonster that we should delete this cookie | 184 // notify CookieMonster that we should delete this cookie |
| 61 GetModel()->cookie_helper_->DeleteCookie(*cookie_); | 185 GetModel()->cookie_helper_->DeleteCookie(*cookie_); |
| 62 GetModel()->cookie_list_.erase(cookie_); | 186 GetModel()->cookie_list_.erase(cookie_); |
| 63 } | 187 } |
| 64 | 188 |
| 65 CookieTreeNode::DetailedInfo CookieTreeCookieNode::GetDetailedInfo() const { | 189 CookieTreeNode::DetailedInfo CookieTreeCookieNode::GetDetailedInfo() const { |
| 66 return DetailedInfo(parent()->parent()->GetTitle()).InitCookie(&*cookie_); | 190 return DetailedInfo().InitCookie(&*cookie_); |
| 67 } | 191 } |
| 68 | 192 |
| 69 namespace { | 193 namespace { |
| 70 // comparison functor, for use in CookieTreeRootNode | 194 // comparison functor, for use in CookieTreeRootNode |
| 71 class OriginNodeComparator { | 195 class HostNodeComparator { |
| 72 public: | 196 public: |
| 73 bool operator() (const CookieTreeNode* lhs, | 197 bool operator() (const CookieTreeNode* lhs, |
| 74 const CookieTreeNode* rhs) { | 198 const CookieTreeNode* rhs) { |
| 75 // We want to order by registry controlled domain, so we would get | 199 // We want to order by registry controlled domain, so we would get |
| 76 // google.com, ad.google.com, www.google.com, | 200 // google.com, ad.google.com, www.google.com, |
| 77 // microsoft.com, ad.microsoft.com. CanonicalizeHost transforms the origins | 201 // microsoft.com, ad.microsoft.com. CanonicalizeHost transforms the origins |
| 78 // into a form like google.com.www so that string comparisons work. | 202 // into a form like google.com.www so that string comparisons work. |
| 79 return (CanonicalizeHost(lhs->GetTitle()) < | 203 return (CanonicalizeHost(lhs->GetTitle()) < |
| 80 CanonicalizeHost(rhs->GetTitle())); | 204 CanonicalizeHost(rhs->GetTitle())); |
| 81 } | 205 } |
| (...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 140 } | 264 } |
| 141 | 265 |
| 142 void CookieTreeAppCacheNode::DeleteStoredObjects() { | 266 void CookieTreeAppCacheNode::DeleteStoredObjects() { |
| 143 DCHECK(GetModel()->appcache_helper_); | 267 DCHECK(GetModel()->appcache_helper_); |
| 144 GetModel()->appcache_helper_->DeleteAppCacheGroup( | 268 GetModel()->appcache_helper_->DeleteAppCacheGroup( |
| 145 appcache_info_->manifest_url); | 269 appcache_info_->manifest_url); |
| 146 GetModel()->appcache_info_[origin_url_].erase(appcache_info_); | 270 GetModel()->appcache_info_[origin_url_].erase(appcache_info_); |
| 147 } | 271 } |
| 148 | 272 |
| 149 CookieTreeNode::DetailedInfo CookieTreeAppCacheNode::GetDetailedInfo() const { | 273 CookieTreeNode::DetailedInfo CookieTreeAppCacheNode::GetDetailedInfo() const { |
| 150 return DetailedInfo(parent()->parent()->GetTitle()).InitAppCache( | 274 return DetailedInfo().InitAppCache(origin_url_, &*appcache_info_); |
| 151 &*appcache_info_); | |
| 152 } | 275 } |
| 153 | 276 |
| 154 /////////////////////////////////////////////////////////////////////////////// | 277 /////////////////////////////////////////////////////////////////////////////// |
| 155 // CookieTreeDatabaseNode, public: | 278 // CookieTreeDatabaseNode, public: |
| 156 | 279 |
| 157 CookieTreeDatabaseNode::CookieTreeDatabaseNode( | 280 CookieTreeDatabaseNode::CookieTreeDatabaseNode( |
| 158 std::list<BrowsingDataDatabaseHelper::DatabaseInfo>::iterator database_info) | 281 std::list<BrowsingDataDatabaseHelper::DatabaseInfo>::iterator database_info) |
| 159 : CookieTreeNode(database_info->database_name.empty() ? | 282 : CookieTreeNode(database_info->database_name.empty() ? |
| 160 l10n_util::GetStringUTF16(IDS_COOKIES_WEB_DATABASE_UNNAMED_NAME) : | 283 l10n_util::GetStringUTF16(IDS_COOKIES_WEB_DATABASE_UNNAMED_NAME) : |
| 161 UTF8ToUTF16(database_info->database_name)), | 284 UTF8ToUTF16(database_info->database_name)), |
| 162 database_info_(database_info) { | 285 database_info_(database_info) { |
| 163 } | 286 } |
| 164 | 287 |
| 165 CookieTreeDatabaseNode::~CookieTreeDatabaseNode() {} | 288 CookieTreeDatabaseNode::~CookieTreeDatabaseNode() {} |
| 166 | 289 |
| 167 void CookieTreeDatabaseNode::DeleteStoredObjects() { | 290 void CookieTreeDatabaseNode::DeleteStoredObjects() { |
| 168 GetModel()->database_helper_->DeleteDatabase( | 291 GetModel()->database_helper_->DeleteDatabase( |
| 169 database_info_->origin_identifier, database_info_->database_name); | 292 database_info_->origin_identifier, database_info_->database_name); |
| 170 GetModel()->database_info_list_.erase(database_info_); | 293 GetModel()->database_info_list_.erase(database_info_); |
| 171 } | 294 } |
| 172 | 295 |
| 173 CookieTreeNode::DetailedInfo CookieTreeDatabaseNode::GetDetailedInfo() const { | 296 CookieTreeNode::DetailedInfo CookieTreeDatabaseNode::GetDetailedInfo() const { |
| 174 return DetailedInfo(parent()->parent()->GetTitle()).InitDatabase( | 297 return DetailedInfo().InitDatabase(&*database_info_); |
| 175 &*database_info_); | |
| 176 } | 298 } |
| 177 | 299 |
| 178 /////////////////////////////////////////////////////////////////////////////// | 300 /////////////////////////////////////////////////////////////////////////////// |
| 179 // CookieTreeLocalStorageNode, public: | 301 // CookieTreeLocalStorageNode, public: |
| 180 | 302 |
| 181 CookieTreeLocalStorageNode::CookieTreeLocalStorageNode( | 303 CookieTreeLocalStorageNode::CookieTreeLocalStorageNode( |
| 182 std::list<BrowsingDataLocalStorageHelper::LocalStorageInfo>::iterator | 304 std::list<BrowsingDataLocalStorageHelper::LocalStorageInfo>::iterator |
| 183 local_storage_info) | 305 local_storage_info) |
| 184 : CookieTreeNode(UTF8ToUTF16(local_storage_info->origin_url.spec())), | 306 : CookieTreeNode(UTF8ToUTF16(local_storage_info->origin_url.spec())), |
| 185 local_storage_info_(local_storage_info) { | 307 local_storage_info_(local_storage_info) { |
| 186 } | 308 } |
| 187 | 309 |
| 188 CookieTreeLocalStorageNode::~CookieTreeLocalStorageNode() {} | 310 CookieTreeLocalStorageNode::~CookieTreeLocalStorageNode() {} |
| 189 | 311 |
| 190 void CookieTreeLocalStorageNode::DeleteStoredObjects() { | 312 void CookieTreeLocalStorageNode::DeleteStoredObjects() { |
| 191 GetModel()->local_storage_helper_->DeleteOrigin( | 313 GetModel()->local_storage_helper_->DeleteOrigin( |
| 192 local_storage_info_->origin_url); | 314 local_storage_info_->origin_url); |
| 193 GetModel()->local_storage_info_list_.erase(local_storage_info_); | 315 GetModel()->local_storage_info_list_.erase(local_storage_info_); |
| 194 } | 316 } |
| 195 | 317 |
| 196 CookieTreeNode::DetailedInfo | 318 CookieTreeNode::DetailedInfo |
| 197 CookieTreeLocalStorageNode::GetDetailedInfo() const { | 319 CookieTreeLocalStorageNode::GetDetailedInfo() const { |
| 198 return DetailedInfo(parent()->parent()->GetTitle()).InitLocalStorage( | 320 return DetailedInfo().InitLocalStorage( |
| 199 &*local_storage_info_); | 321 &*local_storage_info_); |
| 200 } | 322 } |
| 201 | 323 |
| 202 /////////////////////////////////////////////////////////////////////////////// | 324 /////////////////////////////////////////////////////////////////////////////// |
| 203 // CookieTreeSessionStorageNode, public: | 325 // CookieTreeSessionStorageNode, public: |
| 204 | 326 |
| 205 CookieTreeSessionStorageNode::CookieTreeSessionStorageNode( | 327 CookieTreeSessionStorageNode::CookieTreeSessionStorageNode( |
| 206 std::list<BrowsingDataLocalStorageHelper::LocalStorageInfo>::iterator | 328 std::list<BrowsingDataLocalStorageHelper::LocalStorageInfo>::iterator |
| 207 session_storage_info) | 329 session_storage_info) |
| 208 : CookieTreeNode(UTF8ToUTF16(session_storage_info->origin_url.spec())), | 330 : CookieTreeNode(UTF8ToUTF16(session_storage_info->origin_url.spec())), |
| 209 session_storage_info_(session_storage_info) { | 331 session_storage_info_(session_storage_info) { |
| 210 } | 332 } |
| 211 | 333 |
| 212 CookieTreeSessionStorageNode::~CookieTreeSessionStorageNode() {} | 334 CookieTreeSessionStorageNode::~CookieTreeSessionStorageNode() {} |
| 213 | 335 |
| 214 void CookieTreeSessionStorageNode::DeleteStoredObjects() { | 336 void CookieTreeSessionStorageNode::DeleteStoredObjects() { |
| 215 GetModel()->session_storage_info_list_.erase(session_storage_info_); | 337 GetModel()->session_storage_info_list_.erase(session_storage_info_); |
| 216 } | 338 } |
| 217 | 339 |
| 218 CookieTreeNode::DetailedInfo | 340 CookieTreeNode::DetailedInfo |
| 219 CookieTreeSessionStorageNode::GetDetailedInfo() const { | 341 CookieTreeSessionStorageNode::GetDetailedInfo() const { |
| 220 return DetailedInfo(parent()->parent()->GetTitle()).InitSessionStorage( | 342 return DetailedInfo().InitSessionStorage(&*session_storage_info_); |
| 221 &*session_storage_info_); | |
| 222 } | 343 } |
| 223 | 344 |
| 224 /////////////////////////////////////////////////////////////////////////////// | 345 /////////////////////////////////////////////////////////////////////////////// |
| 225 // CookieTreeIndexedDBNode, public: | 346 // CookieTreeIndexedDBNode, public: |
| 226 | 347 |
| 227 CookieTreeIndexedDBNode::CookieTreeIndexedDBNode( | 348 CookieTreeIndexedDBNode::CookieTreeIndexedDBNode( |
| 228 std::list<BrowsingDataIndexedDBHelper::IndexedDBInfo>::iterator | 349 std::list<BrowsingDataIndexedDBHelper::IndexedDBInfo>::iterator |
| 229 indexed_db_info) | 350 indexed_db_info) |
| 230 : CookieTreeNode(UTF8ToUTF16( | 351 : CookieTreeNode(UTF8ToUTF16( |
| 231 indexed_db_info->origin.spec())), | 352 indexed_db_info->origin.spec())), |
| 232 indexed_db_info_(indexed_db_info) { | 353 indexed_db_info_(indexed_db_info) { |
| 233 } | 354 } |
| 234 | 355 |
| 235 CookieTreeIndexedDBNode::~CookieTreeIndexedDBNode() {} | 356 CookieTreeIndexedDBNode::~CookieTreeIndexedDBNode() {} |
| 236 | 357 |
| 237 void CookieTreeIndexedDBNode::DeleteStoredObjects() { | 358 void CookieTreeIndexedDBNode::DeleteStoredObjects() { |
| 238 GetModel()->indexed_db_helper_->DeleteIndexedDB( | 359 GetModel()->indexed_db_helper_->DeleteIndexedDB( |
| 239 indexed_db_info_->origin); | 360 indexed_db_info_->origin); |
| 240 GetModel()->indexed_db_info_list_.erase(indexed_db_info_); | 361 GetModel()->indexed_db_info_list_.erase(indexed_db_info_); |
| 241 } | 362 } |
| 242 | 363 |
| 243 CookieTreeNode::DetailedInfo CookieTreeIndexedDBNode::GetDetailedInfo() const { | 364 CookieTreeNode::DetailedInfo CookieTreeIndexedDBNode::GetDetailedInfo() const { |
| 244 return DetailedInfo(parent()->parent()->GetTitle()).InitIndexedDB( | 365 return DetailedInfo().InitIndexedDB(&*indexed_db_info_); |
| 245 &*indexed_db_info_); | |
| 246 } | 366 } |
| 247 | 367 |
| 248 /////////////////////////////////////////////////////////////////////////////// | 368 /////////////////////////////////////////////////////////////////////////////// |
| 249 // CookieTreeFileSystemNode, public: | 369 // CookieTreeFileSystemNode, public: |
| 250 | 370 |
| 251 CookieTreeFileSystemNode::CookieTreeFileSystemNode( | 371 CookieTreeFileSystemNode::CookieTreeFileSystemNode( |
| 252 std::list<BrowsingDataFileSystemHelper::FileSystemInfo>::iterator | 372 std::list<BrowsingDataFileSystemHelper::FileSystemInfo>::iterator |
| 253 file_system_info) | 373 file_system_info) |
| 254 : CookieTreeNode(UTF8ToUTF16( | 374 : CookieTreeNode(UTF8ToUTF16( |
| 255 file_system_info->origin.spec())), | 375 file_system_info->origin.spec())), |
| 256 file_system_info_(file_system_info) { | 376 file_system_info_(file_system_info) { |
| 257 } | 377 } |
| 258 | 378 |
| 259 CookieTreeFileSystemNode::~CookieTreeFileSystemNode() {} | 379 CookieTreeFileSystemNode::~CookieTreeFileSystemNode() {} |
| 260 | 380 |
| 261 void CookieTreeFileSystemNode::DeleteStoredObjects() { | 381 void CookieTreeFileSystemNode::DeleteStoredObjects() { |
| 262 GetModel()->file_system_helper_->DeleteFileSystemOrigin( | 382 GetModel()->file_system_helper_->DeleteFileSystemOrigin( |
| 263 file_system_info_->origin); | 383 file_system_info_->origin); |
| 264 GetModel()->file_system_info_list_.erase(file_system_info_); | 384 GetModel()->file_system_info_list_.erase(file_system_info_); |
| 265 } | 385 } |
| 266 | 386 |
| 267 CookieTreeNode::DetailedInfo CookieTreeFileSystemNode::GetDetailedInfo() const { | 387 CookieTreeNode::DetailedInfo CookieTreeFileSystemNode::GetDetailedInfo() const { |
| 268 return DetailedInfo(parent()->parent()->GetTitle()).InitFileSystem( | 388 return DetailedInfo().InitFileSystem(&*file_system_info_); |
| 269 &*file_system_info_); | |
| 270 } | 389 } |
| 271 | 390 |
| 272 /////////////////////////////////////////////////////////////////////////////// | 391 /////////////////////////////////////////////////////////////////////////////// |
| 273 // CookieTreeQuotaNode, public: | 392 // CookieTreeQuotaNode, public: |
| 274 | 393 |
| 275 CookieTreeQuotaNode::CookieTreeQuotaNode( | 394 CookieTreeQuotaNode::CookieTreeQuotaNode( |
| 276 std::list<BrowsingDataQuotaHelper::QuotaInfo>::iterator quota_info) | 395 std::list<BrowsingDataQuotaHelper::QuotaInfo>::iterator quota_info) |
| 277 : CookieTreeNode(UTF8ToUTF16(quota_info->host)), | 396 : CookieTreeNode(UTF8ToUTF16(quota_info->host)), |
| 278 quota_info_(quota_info) { | 397 quota_info_(quota_info) { |
| 279 } | 398 } |
| 280 | 399 |
| 281 CookieTreeQuotaNode::~CookieTreeQuotaNode() {} | 400 CookieTreeQuotaNode::~CookieTreeQuotaNode() {} |
| 282 | 401 |
| 283 void CookieTreeQuotaNode::DeleteStoredObjects() { | 402 void CookieTreeQuotaNode::DeleteStoredObjects() { |
| 284 // Calling this function may cause unexpected over-quota state of origin. | 403 // Calling this function may cause unexpected over-quota state of origin. |
| 285 // However, it'll caused no problem, just prevent usage growth of the origin. | 404 // However, it'll caused no problem, just prevent usage growth of the origin. |
| 286 GetModel()->quota_helper_->RevokeHostQuota(quota_info_->host); | 405 GetModel()->quota_helper_->RevokeHostQuota(quota_info_->host); |
| 287 GetModel()->quota_info_list_.erase(quota_info_); | 406 GetModel()->quota_info_list_.erase(quota_info_); |
| 288 } | 407 } |
| 289 | 408 |
| 290 CookieTreeNode::DetailedInfo CookieTreeQuotaNode::GetDetailedInfo() const { | 409 CookieTreeNode::DetailedInfo CookieTreeQuotaNode::GetDetailedInfo() const { |
| 291 return DetailedInfo(parent()->parent()->GetTitle()).InitQuota( | 410 return DetailedInfo().InitQuota(&*quota_info_); |
| 292 &*quota_info_); | |
| 293 } | 411 } |
| 294 | 412 |
| 295 /////////////////////////////////////////////////////////////////////////////// | 413 /////////////////////////////////////////////////////////////////////////////// |
| 296 // CookieTreeServerBoundCertNode, public: | 414 // CookieTreeServerBoundCertNode, public: |
| 297 | 415 |
| 298 CookieTreeServerBoundCertNode::CookieTreeServerBoundCertNode( | 416 CookieTreeServerBoundCertNode::CookieTreeServerBoundCertNode( |
| 299 net::ServerBoundCertStore::ServerBoundCertList::iterator cert) | 417 net::ServerBoundCertStore::ServerBoundCertList::iterator cert) |
| 300 : CookieTreeNode(ASCIIToUTF16(cert->server_identifier())), | 418 : CookieTreeNode(ASCIIToUTF16(cert->server_identifier())), |
| 301 server_bound_cert_(cert) { | 419 server_bound_cert_(cert) { |
| 302 } | 420 } |
| 303 | 421 |
| 304 CookieTreeServerBoundCertNode::~CookieTreeServerBoundCertNode() {} | 422 CookieTreeServerBoundCertNode::~CookieTreeServerBoundCertNode() {} |
| 305 | 423 |
| 306 void CookieTreeServerBoundCertNode::DeleteStoredObjects() { | 424 void CookieTreeServerBoundCertNode::DeleteStoredObjects() { |
| 307 GetModel()->server_bound_cert_helper_->DeleteServerBoundCert( | 425 GetModel()->server_bound_cert_helper_->DeleteServerBoundCert( |
| 308 server_bound_cert_->server_identifier()); | 426 server_bound_cert_->server_identifier()); |
| 309 GetModel()->server_bound_cert_list_.erase(server_bound_cert_); | 427 GetModel()->server_bound_cert_list_.erase(server_bound_cert_); |
| 310 } | 428 } |
| 311 | 429 |
| 312 CookieTreeNode::DetailedInfo | 430 CookieTreeNode::DetailedInfo |
| 313 CookieTreeServerBoundCertNode::GetDetailedInfo() const { | 431 CookieTreeServerBoundCertNode::GetDetailedInfo() const { |
| 314 return DetailedInfo(parent()->parent()->GetTitle()).InitServerBoundCert( | 432 return DetailedInfo().InitServerBoundCert(&*server_bound_cert_); |
| 315 &*server_bound_cert_); | |
| 316 } | 433 } |
| 317 | 434 |
| 318 /////////////////////////////////////////////////////////////////////////////// | 435 /////////////////////////////////////////////////////////////////////////////// |
| 319 // CookieTreeRootNode, public: | 436 // CookieTreeRootNode, public: |
| 320 | 437 |
| 321 CookieTreeRootNode::CookieTreeRootNode(CookiesTreeModel* model) | 438 CookieTreeRootNode::CookieTreeRootNode(CookiesTreeModel* model) |
| 322 : model_(model) { | 439 : model_(model) { |
| 323 } | 440 } |
| 324 | 441 |
| 325 CookieTreeRootNode::~CookieTreeRootNode() {} | 442 CookieTreeRootNode::~CookieTreeRootNode() {} |
| 326 | 443 |
| 327 CookieTreeOriginNode* CookieTreeRootNode::GetOrCreateOriginNode( | 444 CookieTreeHostNode* CookieTreeRootNode::GetOrCreateHostNode( |
| 328 const GURL& url) { | 445 const GURL& url) { |
| 329 CookieTreeOriginNode origin_node(url); | 446 scoped_ptr<CookieTreeHostNode> host_node(new CookieTreeHostNode(url)); |
| 330 | 447 |
| 331 // First see if there is an existing match. | 448 // First see if there is an existing match. |
| 332 std::vector<CookieTreeNode*>::iterator origin_node_iterator = | 449 std::vector<CookieTreeNode*>::iterator host_node_iterator = |
| 333 std::lower_bound(children().begin(), | 450 std::lower_bound(children().begin(), |
| 334 children().end(), | 451 children().end(), |
| 335 &origin_node, | 452 host_node.get(), |
| 336 OriginNodeComparator()); | 453 HostNodeComparator()); |
| 337 | 454 |
| 338 if (origin_node_iterator != children().end() && | 455 if (host_node_iterator != children().end() && |
| 339 WideToUTF16Hack(CookieTreeOriginNode::TitleForUrl(url)) == | 456 host_node->GetTitle() == (*host_node_iterator)->GetTitle()) { |
| 340 (*origin_node_iterator)->GetTitle()) | 457 return static_cast<CookieTreeHostNode*>(*host_node_iterator); |
| 341 return static_cast<CookieTreeOriginNode*>(*origin_node_iterator); | 458 } |
| 342 // Node doesn't exist, create a new one and insert it into the (ordered) | 459 // Node doesn't exist, create a new one and insert it into the (ordered) |
| 343 // children. | 460 // children. |
| 344 CookieTreeOriginNode* retval = new CookieTreeOriginNode(url); | |
| 345 DCHECK(model_); | 461 DCHECK(model_); |
| 346 model_->Add(this, retval, (origin_node_iterator - children().begin())); | 462 model_->Add(this, host_node.get(), |
| 347 return retval; | 463 (host_node_iterator - children().begin())); |
| 464 return host_node.release(); | |
| 348 } | 465 } |
| 349 | 466 |
| 350 CookiesTreeModel* CookieTreeRootNode::GetModel() const { | 467 CookiesTreeModel* CookieTreeRootNode::GetModel() const { |
| 351 return model_; | 468 return model_; |
| 352 } | 469 } |
| 353 | 470 |
| 354 CookieTreeNode::DetailedInfo CookieTreeRootNode::GetDetailedInfo() const { | 471 CookieTreeNode::DetailedInfo CookieTreeRootNode::GetDetailedInfo() const { |
| 355 return DetailedInfo(string16()).Init(DetailedInfo::TYPE_ROOT); | 472 return DetailedInfo().Init(DetailedInfo::TYPE_ROOT); |
| 356 } | 473 } |
| 357 | 474 |
| 358 /////////////////////////////////////////////////////////////////////////////// | 475 /////////////////////////////////////////////////////////////////////////////// |
| 359 // CookieTreeOriginNode, public: | 476 // CookieTreeHostNode, public: |
| 360 | 477 |
| 361 // static | 478 // static |
| 362 std::wstring CookieTreeOriginNode::TitleForUrl( | 479 string16 CookieTreeHostNode::TitleForUrl( |
| 363 const GURL& url) { | 480 const GURL& url) { |
| 364 return UTF8ToWide(url.SchemeIsFile() ? kFileOriginNodeName : url.host()); | 481 return UTF8ToUTF16(url.SchemeIsFile() ? kFileHostNodeName : url.host()); |
| 365 } | 482 } |
| 366 | 483 |
| 367 CookieTreeOriginNode::CookieTreeOriginNode(const GURL& url) | 484 CookieTreeHostNode::CookieTreeHostNode(const GURL& url) |
| 368 : CookieTreeNode(WideToUTF16Hack(TitleForUrl(url))), | 485 : CookieTreeNode(TitleForUrl(url)), |
| 369 cookies_child_(NULL), | 486 cookies_child_(NULL), |
| 370 databases_child_(NULL), | 487 databases_child_(NULL), |
| 371 local_storages_child_(NULL), | 488 local_storages_child_(NULL), |
| 372 session_storages_child_(NULL), | 489 session_storages_child_(NULL), |
| 373 appcaches_child_(NULL), | 490 appcaches_child_(NULL), |
| 374 indexed_dbs_child_(NULL), | 491 indexed_dbs_child_(NULL), |
| 375 file_systems_child_(NULL), | 492 file_systems_child_(NULL), |
| 376 quota_child_(NULL), | 493 quota_child_(NULL), |
| 377 server_bound_certs_child_(NULL), | 494 server_bound_certs_child_(NULL), |
| 378 url_(url) {} | 495 url_(url) {} |
| 379 | 496 |
| 380 CookieTreeOriginNode::~CookieTreeOriginNode() {} | 497 CookieTreeHostNode::~CookieTreeHostNode() {} |
| 381 | 498 |
| 382 CookieTreeNode::DetailedInfo CookieTreeOriginNode::GetDetailedInfo() const { | 499 CookieTreeNode::DetailedInfo CookieTreeHostNode::GetDetailedInfo() const { |
| 383 return DetailedInfo(GetTitle()).Init(DetailedInfo::TYPE_ORIGIN); | 500 return DetailedInfo().Init(DetailedInfo::TYPE_HOST); |
| 384 } | 501 } |
| 385 | 502 |
| 386 CookieTreeCookiesNode* CookieTreeOriginNode::GetOrCreateCookiesNode() { | 503 CookieTreeCookiesNode* CookieTreeHostNode::GetOrCreateCookiesNode() { |
| 387 if (cookies_child_) | 504 if (cookies_child_) |
| 388 return cookies_child_; | 505 return cookies_child_; |
| 389 cookies_child_ = new CookieTreeCookiesNode; | 506 cookies_child_ = new CookieTreeCookiesNode; |
| 390 AddChildSortedByTitle(cookies_child_); | 507 AddChildSortedByTitle(cookies_child_); |
| 391 return cookies_child_; | 508 return cookies_child_; |
| 392 } | 509 } |
| 393 | 510 |
| 394 CookieTreeDatabasesNode* CookieTreeOriginNode::GetOrCreateDatabasesNode() { | 511 CookieTreeDatabasesNode* CookieTreeHostNode::GetOrCreateDatabasesNode() { |
| 395 if (databases_child_) | 512 if (databases_child_) |
| 396 return databases_child_; | 513 return databases_child_; |
| 397 databases_child_ = new CookieTreeDatabasesNode; | 514 databases_child_ = new CookieTreeDatabasesNode; |
| 398 AddChildSortedByTitle(databases_child_); | 515 AddChildSortedByTitle(databases_child_); |
| 399 return databases_child_; | 516 return databases_child_; |
| 400 } | 517 } |
| 401 | 518 |
| 402 CookieTreeLocalStoragesNode* | 519 CookieTreeLocalStoragesNode* |
| 403 CookieTreeOriginNode::GetOrCreateLocalStoragesNode() { | 520 CookieTreeHostNode::GetOrCreateLocalStoragesNode() { |
| 404 if (local_storages_child_) | 521 if (local_storages_child_) |
| 405 return local_storages_child_; | 522 return local_storages_child_; |
| 406 local_storages_child_ = new CookieTreeLocalStoragesNode; | 523 local_storages_child_ = new CookieTreeLocalStoragesNode; |
| 407 AddChildSortedByTitle(local_storages_child_); | 524 AddChildSortedByTitle(local_storages_child_); |
| 408 return local_storages_child_; | 525 return local_storages_child_; |
| 409 } | 526 } |
| 410 | 527 |
| 411 CookieTreeSessionStoragesNode* | 528 CookieTreeSessionStoragesNode* |
| 412 CookieTreeOriginNode::GetOrCreateSessionStoragesNode() { | 529 CookieTreeHostNode::GetOrCreateSessionStoragesNode() { |
| 413 if (session_storages_child_) | 530 if (session_storages_child_) |
| 414 return session_storages_child_; | 531 return session_storages_child_; |
| 415 session_storages_child_ = new CookieTreeSessionStoragesNode; | 532 session_storages_child_ = new CookieTreeSessionStoragesNode; |
| 416 AddChildSortedByTitle(session_storages_child_); | 533 AddChildSortedByTitle(session_storages_child_); |
| 417 return session_storages_child_; | 534 return session_storages_child_; |
| 418 } | 535 } |
| 419 | 536 |
| 420 CookieTreeAppCachesNode* CookieTreeOriginNode::GetOrCreateAppCachesNode() { | 537 CookieTreeAppCachesNode* CookieTreeHostNode::GetOrCreateAppCachesNode() { |
| 421 if (appcaches_child_) | 538 if (appcaches_child_) |
| 422 return appcaches_child_; | 539 return appcaches_child_; |
| 423 appcaches_child_ = new CookieTreeAppCachesNode; | 540 appcaches_child_ = new CookieTreeAppCachesNode; |
| 424 AddChildSortedByTitle(appcaches_child_); | 541 AddChildSortedByTitle(appcaches_child_); |
| 425 return appcaches_child_; | 542 return appcaches_child_; |
| 426 } | 543 } |
| 427 | 544 |
| 428 CookieTreeIndexedDBsNode* CookieTreeOriginNode::GetOrCreateIndexedDBsNode() { | 545 CookieTreeIndexedDBsNode* CookieTreeHostNode::GetOrCreateIndexedDBsNode() { |
| 429 if (indexed_dbs_child_) | 546 if (indexed_dbs_child_) |
| 430 return indexed_dbs_child_; | 547 return indexed_dbs_child_; |
| 431 indexed_dbs_child_ = new CookieTreeIndexedDBsNode; | 548 indexed_dbs_child_ = new CookieTreeIndexedDBsNode; |
| 432 AddChildSortedByTitle(indexed_dbs_child_); | 549 AddChildSortedByTitle(indexed_dbs_child_); |
| 433 return indexed_dbs_child_; | 550 return indexed_dbs_child_; |
| 434 } | 551 } |
| 435 | 552 |
| 436 CookieTreeFileSystemsNode* CookieTreeOriginNode::GetOrCreateFileSystemsNode() { | 553 CookieTreeFileSystemsNode* CookieTreeHostNode::GetOrCreateFileSystemsNode() { |
| 437 if (file_systems_child_) | 554 if (file_systems_child_) |
| 438 return file_systems_child_; | 555 return file_systems_child_; |
| 439 file_systems_child_ = new CookieTreeFileSystemsNode; | 556 file_systems_child_ = new CookieTreeFileSystemsNode; |
| 440 AddChildSortedByTitle(file_systems_child_); | 557 AddChildSortedByTitle(file_systems_child_); |
| 441 return file_systems_child_; | 558 return file_systems_child_; |
| 442 } | 559 } |
| 443 | 560 |
| 444 CookieTreeQuotaNode* CookieTreeOriginNode::UpdateOrCreateQuotaNode( | 561 CookieTreeQuotaNode* CookieTreeHostNode::UpdateOrCreateQuotaNode( |
| 445 std::list<BrowsingDataQuotaHelper::QuotaInfo>::iterator quota_info) { | 562 std::list<BrowsingDataQuotaHelper::QuotaInfo>::iterator quota_info) { |
| 446 if (quota_child_) | 563 if (quota_child_) |
| 447 return quota_child_; | 564 return quota_child_; |
| 448 quota_child_ = new CookieTreeQuotaNode(quota_info); | 565 quota_child_ = new CookieTreeQuotaNode(quota_info); |
| 449 AddChildSortedByTitle(quota_child_); | 566 AddChildSortedByTitle(quota_child_); |
| 450 return quota_child_; | 567 return quota_child_; |
| 451 } | 568 } |
| 452 | 569 |
| 453 CookieTreeServerBoundCertsNode* | 570 CookieTreeServerBoundCertsNode* |
| 454 CookieTreeOriginNode::GetOrCreateServerBoundCertsNode() { | 571 CookieTreeHostNode::GetOrCreateServerBoundCertsNode() { |
| 455 if (server_bound_certs_child_) | 572 if (server_bound_certs_child_) |
| 456 return server_bound_certs_child_; | 573 return server_bound_certs_child_; |
| 457 server_bound_certs_child_ = new CookieTreeServerBoundCertsNode; | 574 server_bound_certs_child_ = new CookieTreeServerBoundCertsNode; |
| 458 AddChildSortedByTitle(server_bound_certs_child_); | 575 AddChildSortedByTitle(server_bound_certs_child_); |
| 459 return server_bound_certs_child_; | 576 return server_bound_certs_child_; |
| 460 } | 577 } |
| 461 | 578 |
| 462 void CookieTreeOriginNode::CreateContentException( | 579 void CookieTreeHostNode::CreateContentException( |
| 463 CookieSettings* cookie_settings, ContentSetting setting) const { | 580 CookieSettings* cookie_settings, ContentSetting setting) const { |
| 464 DCHECK(setting == CONTENT_SETTING_ALLOW || | 581 DCHECK(setting == CONTENT_SETTING_ALLOW || |
| 465 setting == CONTENT_SETTING_BLOCK || | 582 setting == CONTENT_SETTING_BLOCK || |
| 466 setting == CONTENT_SETTING_SESSION_ONLY); | 583 setting == CONTENT_SETTING_SESSION_ONLY); |
| 467 if (CanCreateContentException()) { | 584 if (CanCreateContentException()) { |
| 468 cookie_settings->ResetCookieSetting( | 585 cookie_settings->ResetCookieSetting( |
| 469 ContentSettingsPattern::FromURLNoWildcard(url_), | 586 ContentSettingsPattern::FromURLNoWildcard(url_), |
| 470 ContentSettingsPattern::Wildcard()); | 587 ContentSettingsPattern::Wildcard()); |
| 471 cookie_settings->SetCookieSetting( | 588 cookie_settings->SetCookieSetting( |
| 472 ContentSettingsPattern::FromURL(url_), | 589 ContentSettingsPattern::FromURL(url_), |
| 473 ContentSettingsPattern::Wildcard(), setting); | 590 ContentSettingsPattern::Wildcard(), setting); |
| 474 } | 591 } |
| 475 } | 592 } |
| 476 | 593 |
| 477 bool CookieTreeOriginNode::CanCreateContentException() const { | 594 bool CookieTreeHostNode::CanCreateContentException() const { |
| 478 return !url_.SchemeIsFile(); | 595 return !url_.SchemeIsFile(); |
| 479 } | 596 } |
| 480 | 597 |
| 481 /////////////////////////////////////////////////////////////////////////////// | 598 /////////////////////////////////////////////////////////////////////////////// |
| 482 // CookieTreeCookiesNode, public: | 599 // CookieTreeCookiesNode, public: |
| 483 | 600 |
| 484 CookieTreeCookiesNode::CookieTreeCookiesNode() | 601 CookieTreeCookiesNode::CookieTreeCookiesNode() |
| 485 : CookieTreeNode(l10n_util::GetStringUTF16(IDS_COOKIES_COOKIES)) { | 602 : CookieTreeNode(l10n_util::GetStringUTF16(IDS_COOKIES_COOKIES)) { |
| 486 } | 603 } |
| 487 | 604 |
| 488 CookieTreeCookiesNode::~CookieTreeCookiesNode() { | 605 CookieTreeCookiesNode::~CookieTreeCookiesNode() { |
| 489 } | 606 } |
| 490 | 607 |
| 491 CookieTreeNode::DetailedInfo CookieTreeCookiesNode::GetDetailedInfo() const { | 608 CookieTreeNode::DetailedInfo CookieTreeCookiesNode::GetDetailedInfo() const { |
| 492 return DetailedInfo(parent()->GetTitle()).Init(DetailedInfo::TYPE_COOKIES); | 609 return DetailedInfo().Init(DetailedInfo::TYPE_COOKIES); |
| 493 } | 610 } |
| 494 | 611 |
| 495 /////////////////////////////////////////////////////////////////////////////// | 612 /////////////////////////////////////////////////////////////////////////////// |
| 496 // CookieTreeAppCachesNode, public: | 613 // CookieTreeAppCachesNode, public: |
| 497 | 614 |
| 498 CookieTreeAppCachesNode::CookieTreeAppCachesNode() | 615 CookieTreeAppCachesNode::CookieTreeAppCachesNode() |
| 499 : CookieTreeNode(l10n_util::GetStringUTF16( | 616 : CookieTreeNode(l10n_util::GetStringUTF16( |
| 500 IDS_COOKIES_APPLICATION_CACHES)) { | 617 IDS_COOKIES_APPLICATION_CACHES)) { |
| 501 } | 618 } |
| 502 | 619 |
| 503 CookieTreeAppCachesNode::~CookieTreeAppCachesNode() {} | 620 CookieTreeAppCachesNode::~CookieTreeAppCachesNode() {} |
| 504 | 621 |
| 505 CookieTreeNode::DetailedInfo CookieTreeAppCachesNode::GetDetailedInfo() const { | 622 CookieTreeNode::DetailedInfo CookieTreeAppCachesNode::GetDetailedInfo() const { |
| 506 return DetailedInfo(parent()->GetTitle()).Init(DetailedInfo::TYPE_APPCACHES); | 623 return DetailedInfo().Init(DetailedInfo::TYPE_APPCACHES); |
| 507 } | 624 } |
| 508 | 625 |
| 509 /////////////////////////////////////////////////////////////////////////////// | 626 /////////////////////////////////////////////////////////////////////////////// |
| 510 // CookieTreeDatabasesNode, public: | 627 // CookieTreeDatabasesNode, public: |
| 511 | 628 |
| 512 CookieTreeDatabasesNode::CookieTreeDatabasesNode() | 629 CookieTreeDatabasesNode::CookieTreeDatabasesNode() |
| 513 : CookieTreeNode(l10n_util::GetStringUTF16(IDS_COOKIES_WEB_DATABASES)) { | 630 : CookieTreeNode(l10n_util::GetStringUTF16(IDS_COOKIES_WEB_DATABASES)) { |
| 514 } | 631 } |
| 515 | 632 |
| 516 CookieTreeDatabasesNode::~CookieTreeDatabasesNode() {} | 633 CookieTreeDatabasesNode::~CookieTreeDatabasesNode() {} |
| 517 | 634 |
| 518 CookieTreeNode::DetailedInfo CookieTreeDatabasesNode::GetDetailedInfo() const { | 635 CookieTreeNode::DetailedInfo CookieTreeDatabasesNode::GetDetailedInfo() const { |
| 519 return DetailedInfo(parent()->GetTitle()).Init(DetailedInfo::TYPE_DATABASES); | 636 return DetailedInfo().Init(DetailedInfo::TYPE_DATABASES); |
| 520 } | 637 } |
| 521 | 638 |
| 522 /////////////////////////////////////////////////////////////////////////////// | 639 /////////////////////////////////////////////////////////////////////////////// |
| 523 // CookieTreeLocalStoragesNode, public: | 640 // CookieTreeLocalStoragesNode, public: |
| 524 | 641 |
| 525 CookieTreeLocalStoragesNode::CookieTreeLocalStoragesNode() | 642 CookieTreeLocalStoragesNode::CookieTreeLocalStoragesNode() |
| 526 : CookieTreeNode(l10n_util::GetStringUTF16(IDS_COOKIES_LOCAL_STORAGE)) { | 643 : CookieTreeNode(l10n_util::GetStringUTF16(IDS_COOKIES_LOCAL_STORAGE)) { |
| 527 } | 644 } |
| 528 | 645 |
| 529 CookieTreeLocalStoragesNode::~CookieTreeLocalStoragesNode() {} | 646 CookieTreeLocalStoragesNode::~CookieTreeLocalStoragesNode() {} |
| 530 | 647 |
| 531 CookieTreeNode::DetailedInfo | 648 CookieTreeNode::DetailedInfo |
| 532 CookieTreeLocalStoragesNode::GetDetailedInfo() const { | 649 CookieTreeLocalStoragesNode::GetDetailedInfo() const { |
| 533 return DetailedInfo(parent()->GetTitle()).Init( | 650 return DetailedInfo().Init(DetailedInfo::TYPE_LOCAL_STORAGES); |
| 534 DetailedInfo::TYPE_LOCAL_STORAGES); | |
| 535 } | 651 } |
| 536 | 652 |
| 537 /////////////////////////////////////////////////////////////////////////////// | 653 /////////////////////////////////////////////////////////////////////////////// |
| 538 // CookieTreeSessionStoragesNode, public: | 654 // CookieTreeSessionStoragesNode, public: |
| 539 | 655 |
| 540 CookieTreeSessionStoragesNode::CookieTreeSessionStoragesNode() | 656 CookieTreeSessionStoragesNode::CookieTreeSessionStoragesNode() |
| 541 : CookieTreeNode(l10n_util::GetStringUTF16(IDS_COOKIES_SESSION_STORAGE)) { | 657 : CookieTreeNode(l10n_util::GetStringUTF16(IDS_COOKIES_SESSION_STORAGE)) { |
| 542 } | 658 } |
| 543 | 659 |
| 544 CookieTreeSessionStoragesNode::~CookieTreeSessionStoragesNode() {} | 660 CookieTreeSessionStoragesNode::~CookieTreeSessionStoragesNode() {} |
| 545 | 661 |
| 546 CookieTreeNode::DetailedInfo | 662 CookieTreeNode::DetailedInfo |
| 547 CookieTreeSessionStoragesNode::GetDetailedInfo() const { | 663 CookieTreeSessionStoragesNode::GetDetailedInfo() const { |
| 548 return DetailedInfo(parent()->GetTitle()).Init( | 664 return DetailedInfo().Init(DetailedInfo::TYPE_SESSION_STORAGES); |
| 549 DetailedInfo::TYPE_SESSION_STORAGES); | |
| 550 } | 665 } |
| 551 | 666 |
| 552 /////////////////////////////////////////////////////////////////////////////// | 667 /////////////////////////////////////////////////////////////////////////////// |
| 553 // CookieTreeIndexedDBsNode, public: | 668 // CookieTreeIndexedDBsNode, public: |
| 554 | 669 |
| 555 CookieTreeIndexedDBsNode::CookieTreeIndexedDBsNode() | 670 CookieTreeIndexedDBsNode::CookieTreeIndexedDBsNode() |
| 556 : CookieTreeNode(l10n_util::GetStringUTF16(IDS_COOKIES_INDEXED_DBS)) { | 671 : CookieTreeNode(l10n_util::GetStringUTF16(IDS_COOKIES_INDEXED_DBS)) { |
| 557 } | 672 } |
| 558 | 673 |
| 559 CookieTreeIndexedDBsNode::~CookieTreeIndexedDBsNode() {} | 674 CookieTreeIndexedDBsNode::~CookieTreeIndexedDBsNode() {} |
| 560 | 675 |
| 561 CookieTreeNode::DetailedInfo | 676 CookieTreeNode::DetailedInfo |
| 562 CookieTreeIndexedDBsNode::GetDetailedInfo() const { | 677 CookieTreeIndexedDBsNode::GetDetailedInfo() const { |
| 563 return DetailedInfo(parent()->GetTitle()).Init( | 678 return DetailedInfo().Init(DetailedInfo::TYPE_INDEXED_DBS); |
| 564 DetailedInfo::TYPE_INDEXED_DBS); | |
| 565 } | 679 } |
| 566 | 680 |
| 567 /////////////////////////////////////////////////////////////////////////////// | 681 /////////////////////////////////////////////////////////////////////////////// |
| 568 // CookieTreeFileSystemsNode, public: | 682 // CookieTreeFileSystemsNode, public: |
| 569 | 683 |
| 570 CookieTreeFileSystemsNode::CookieTreeFileSystemsNode() | 684 CookieTreeFileSystemsNode::CookieTreeFileSystemsNode() |
| 571 : CookieTreeNode(l10n_util::GetStringUTF16(IDS_COOKIES_FILE_SYSTEMS)) { | 685 : CookieTreeNode(l10n_util::GetStringUTF16(IDS_COOKIES_FILE_SYSTEMS)) { |
| 572 } | 686 } |
| 573 | 687 |
| 574 CookieTreeFileSystemsNode::~CookieTreeFileSystemsNode() {} | 688 CookieTreeFileSystemsNode::~CookieTreeFileSystemsNode() {} |
| 575 | 689 |
| 576 CookieTreeNode::DetailedInfo | 690 CookieTreeNode::DetailedInfo |
| 577 CookieTreeFileSystemsNode::GetDetailedInfo() const { | 691 CookieTreeFileSystemsNode::GetDetailedInfo() const { |
| 578 return DetailedInfo(parent()->GetTitle()).Init( | 692 return DetailedInfo().Init(DetailedInfo::TYPE_FILE_SYSTEMS); |
| 579 DetailedInfo::TYPE_FILE_SYSTEMS); | |
| 580 } | 693 } |
| 581 | 694 |
| 582 /////////////////////////////////////////////////////////////////////////////// | 695 /////////////////////////////////////////////////////////////////////////////// |
| 583 // CookieTreeServerBoundCertsNode, public: | 696 // CookieTreeServerBoundCertsNode, public: |
| 584 | 697 |
| 585 CookieTreeServerBoundCertsNode::CookieTreeServerBoundCertsNode() | 698 CookieTreeServerBoundCertsNode::CookieTreeServerBoundCertsNode() |
| 586 : CookieTreeNode( | 699 : CookieTreeNode( |
| 587 l10n_util::GetStringUTF16(IDS_COOKIES_SERVER_BOUND_CERTS)) { | 700 l10n_util::GetStringUTF16(IDS_COOKIES_SERVER_BOUND_CERTS)) { |
| 588 } | 701 } |
| 589 | 702 |
| 590 CookieTreeServerBoundCertsNode::~CookieTreeServerBoundCertsNode() {} | 703 CookieTreeServerBoundCertsNode::~CookieTreeServerBoundCertsNode() {} |
| 591 | 704 |
| 592 CookieTreeNode::DetailedInfo | 705 CookieTreeNode::DetailedInfo |
| 593 CookieTreeServerBoundCertsNode::GetDetailedInfo() const { | 706 CookieTreeServerBoundCertsNode::GetDetailedInfo() const { |
| 594 return DetailedInfo(parent()->GetTitle()).Init( | 707 return DetailedInfo().Init(DetailedInfo::TYPE_SERVER_BOUND_CERTS); |
| 595 DetailedInfo::TYPE_SERVER_BOUND_CERTS); | |
| 596 } | 708 } |
| 597 | 709 |
| 598 /////////////////////////////////////////////////////////////////////////////// | 710 /////////////////////////////////////////////////////////////////////////////// |
| 599 // CookieTreeNode, protected | 711 // CookieTreeNode, protected |
| 600 | 712 |
| 601 bool CookieTreeNode::NodeTitleComparator::operator() ( | 713 bool CookieTreeNode::NodeTitleComparator::operator() ( |
| 602 const CookieTreeNode* lhs, const CookieTreeNode* rhs) { | 714 const CookieTreeNode* lhs, const CookieTreeNode* rhs) { |
| 603 const CookieTreeNode* left = | 715 const CookieTreeNode* left = |
| 604 static_cast<const CookieTreeNode*>(lhs); | 716 static_cast<const CookieTreeNode*>(lhs); |
| 605 const CookieTreeNode* right = | 717 const CookieTreeNode* right = |
| (...skipping 17 matching lines...) Expand all Loading... | |
| 623 CookiesTreeModel::CookiesTreeModel( | 735 CookiesTreeModel::CookiesTreeModel( |
| 624 BrowsingDataCookieHelper* cookie_helper, | 736 BrowsingDataCookieHelper* cookie_helper, |
| 625 BrowsingDataDatabaseHelper* database_helper, | 737 BrowsingDataDatabaseHelper* database_helper, |
| 626 BrowsingDataLocalStorageHelper* local_storage_helper, | 738 BrowsingDataLocalStorageHelper* local_storage_helper, |
| 627 BrowsingDataLocalStorageHelper* session_storage_helper, | 739 BrowsingDataLocalStorageHelper* session_storage_helper, |
| 628 BrowsingDataAppCacheHelper* appcache_helper, | 740 BrowsingDataAppCacheHelper* appcache_helper, |
| 629 BrowsingDataIndexedDBHelper* indexed_db_helper, | 741 BrowsingDataIndexedDBHelper* indexed_db_helper, |
| 630 BrowsingDataFileSystemHelper* file_system_helper, | 742 BrowsingDataFileSystemHelper* file_system_helper, |
| 631 BrowsingDataQuotaHelper* quota_helper, | 743 BrowsingDataQuotaHelper* quota_helper, |
| 632 BrowsingDataServerBoundCertHelper* server_bound_cert_helper, | 744 BrowsingDataServerBoundCertHelper* server_bound_cert_helper, |
| 745 ExtensionSpecialStoragePolicy* special_storage_policy, | |
| 633 bool use_cookie_source) | 746 bool use_cookie_source) |
| 634 : ALLOW_THIS_IN_INITIALIZER_LIST(ui::TreeNodeModel<CookieTreeNode>( | 747 : ALLOW_THIS_IN_INITIALIZER_LIST(ui::TreeNodeModel<CookieTreeNode>( |
| 635 new CookieTreeRootNode(this))), | 748 new CookieTreeRootNode(this))), |
| 636 appcache_helper_(appcache_helper), | 749 appcache_helper_(appcache_helper), |
| 637 cookie_helper_(cookie_helper), | 750 cookie_helper_(cookie_helper), |
| 638 database_helper_(database_helper), | 751 database_helper_(database_helper), |
| 639 local_storage_helper_(local_storage_helper), | 752 local_storage_helper_(local_storage_helper), |
| 640 session_storage_helper_(session_storage_helper), | 753 session_storage_helper_(session_storage_helper), |
| 641 indexed_db_helper_(indexed_db_helper), | 754 indexed_db_helper_(indexed_db_helper), |
| 642 file_system_helper_(file_system_helper), | 755 file_system_helper_(file_system_helper), |
| 643 quota_helper_(quota_helper), | 756 quota_helper_(quota_helper), |
| 644 server_bound_cert_helper_(server_bound_cert_helper), | 757 server_bound_cert_helper_(server_bound_cert_helper), |
| 758 special_storage_policy_(special_storage_policy), | |
| 645 batch_update_(0), | 759 batch_update_(0), |
| 646 use_cookie_source_(use_cookie_source), | 760 use_cookie_source_(use_cookie_source), |
| 647 ALLOW_THIS_IN_INITIALIZER_LIST(weak_ptr_factory_(this)) { | 761 ALLOW_THIS_IN_INITIALIZER_LIST(weak_ptr_factory_(this)) { |
| 648 DCHECK(cookie_helper_); | 762 DCHECK(cookie_helper_); |
| 649 cookie_helper_->StartFetching( | 763 cookie_helper_->StartFetching( |
| 650 base::Bind(&CookiesTreeModel::OnCookiesModelInfoLoaded, | 764 base::Bind(&CookiesTreeModel::OnCookiesModelInfoLoaded, |
| 651 weak_ptr_factory_.GetWeakPtr())); | 765 weak_ptr_factory_.GetWeakPtr())); |
| 652 DCHECK(database_helper_); | 766 DCHECK(database_helper_); |
| 653 database_helper_->StartFetching( | 767 database_helper_->StartFetching( |
| 654 base::Bind(&CookiesTreeModel::OnDatabaseModelInfoLoaded, | 768 base::Bind(&CookiesTreeModel::OnDatabaseModelInfoLoaded, |
| (...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 712 icons->push_back(*ResourceBundle::GetSharedInstance().GetImageSkiaNamed( | 826 icons->push_back(*ResourceBundle::GetSharedInstance().GetImageSkiaNamed( |
| 713 IDR_COOKIE_STORAGE_ICON)); | 827 IDR_COOKIE_STORAGE_ICON)); |
| 714 } | 828 } |
| 715 | 829 |
| 716 // Returns the index of the icon to use for |node|. Return -1 to use the | 830 // Returns the index of the icon to use for |node|. Return -1 to use the |
| 717 // default icon. The index is relative to the list of icons returned from | 831 // default icon. The index is relative to the list of icons returned from |
| 718 // GetIcons. | 832 // GetIcons. |
| 719 int CookiesTreeModel::GetIconIndex(ui::TreeModelNode* node) { | 833 int CookiesTreeModel::GetIconIndex(ui::TreeModelNode* node) { |
| 720 CookieTreeNode* ct_node = static_cast<CookieTreeNode*>(node); | 834 CookieTreeNode* ct_node = static_cast<CookieTreeNode*>(node); |
| 721 switch (ct_node->GetDetailedInfo().node_type) { | 835 switch (ct_node->GetDetailedInfo().node_type) { |
| 722 case CookieTreeNode::DetailedInfo::TYPE_ORIGIN: | 836 case CookieTreeNode::DetailedInfo::TYPE_HOST: |
| 723 return ORIGIN; | 837 return ORIGIN; |
| 724 case CookieTreeNode::DetailedInfo::TYPE_COOKIE: | 838 case CookieTreeNode::DetailedInfo::TYPE_COOKIE: |
| 725 return COOKIE; | 839 return COOKIE; |
| 726 case CookieTreeNode::DetailedInfo::TYPE_DATABASE: | 840 case CookieTreeNode::DetailedInfo::TYPE_DATABASE: |
| 727 return DATABASE; | 841 return DATABASE; |
| 728 case CookieTreeNode::DetailedInfo::TYPE_LOCAL_STORAGE: | 842 case CookieTreeNode::DetailedInfo::TYPE_LOCAL_STORAGE: |
| 729 return DATABASE; // close enough | 843 return DATABASE; // close enough |
| 730 case CookieTreeNode::DetailedInfo::TYPE_SESSION_STORAGE: | 844 case CookieTreeNode::DetailedInfo::TYPE_SESSION_STORAGE: |
| 731 return DATABASE; // ditto | 845 return DATABASE; // ditto |
| 732 case CookieTreeNode::DetailedInfo::TYPE_APPCACHE: | 846 case CookieTreeNode::DetailedInfo::TYPE_APPCACHE: |
| (...skipping 26 matching lines...) Expand all Loading... | |
| 759 void CookiesTreeModel::DeleteCookieNode(CookieTreeNode* cookie_node) { | 873 void CookiesTreeModel::DeleteCookieNode(CookieTreeNode* cookie_node) { |
| 760 if (cookie_node == GetRoot()) | 874 if (cookie_node == GetRoot()) |
| 761 return; | 875 return; |
| 762 cookie_node->DeleteStoredObjects(); | 876 cookie_node->DeleteStoredObjects(); |
| 763 CookieTreeNode* parent_node = cookie_node->parent(); | 877 CookieTreeNode* parent_node = cookie_node->parent(); |
| 764 delete Remove(parent_node, cookie_node); | 878 delete Remove(parent_node, cookie_node); |
| 765 if (parent_node->empty()) | 879 if (parent_node->empty()) |
| 766 DeleteCookieNode(parent_node); | 880 DeleteCookieNode(parent_node); |
| 767 } | 881 } |
| 768 | 882 |
| 769 void CookiesTreeModel::UpdateSearchResults(const std::wstring& filter) { | 883 void CookiesTreeModel::UpdateSearchResults(const string16& filter) { |
| 770 CookieTreeNode* root = GetRoot(); | 884 CookieTreeNode* root = GetRoot(); |
| 771 int num_children = root->child_count(); | 885 int num_children = root->child_count(); |
| 772 NotifyObserverBeginBatch(); | 886 NotifyObserverBeginBatch(); |
| 773 for (int i = num_children - 1; i >= 0; --i) | 887 for (int i = num_children - 1; i >= 0; --i) |
| 774 delete Remove(root, root->GetChild(i)); | 888 delete Remove(root, root->GetChild(i)); |
| 775 PopulateCookieInfoWithFilter(filter); | 889 PopulateCookieInfoWithFilter(filter); |
| 776 PopulateDatabaseInfoWithFilter(filter); | 890 PopulateDatabaseInfoWithFilter(filter); |
| 777 PopulateLocalStorageInfoWithFilter(filter); | 891 PopulateLocalStorageInfoWithFilter(filter); |
| 778 PopulateSessionStorageInfoWithFilter(filter); | 892 PopulateSessionStorageInfoWithFilter(filter); |
| 779 PopulateAppCacheInfoWithFilter(filter); | 893 PopulateAppCacheInfoWithFilter(filter); |
| 780 PopulateIndexedDBInfoWithFilter(filter); | 894 PopulateIndexedDBInfoWithFilter(filter); |
| 781 PopulateFileSystemInfoWithFilter(filter); | 895 PopulateFileSystemInfoWithFilter(filter); |
| 782 PopulateQuotaInfoWithFilter(filter); | 896 PopulateQuotaInfoWithFilter(filter); |
| 783 PopulateServerBoundCertInfoWithFilter(filter); | 897 PopulateServerBoundCertInfoWithFilter(filter); |
| 784 NotifyObserverTreeNodeChanged(root); | 898 NotifyObserverTreeNodeChanged(root); |
| 785 NotifyObserverEndBatch(); | 899 NotifyObserverEndBatch(); |
| 786 } | 900 } |
| 787 | 901 |
| 902 const ExtensionSet* CookiesTreeModel::ExtensionsProtectingNode( | |
| 903 const CookieTreeNode& cookie_node) { | |
| 904 if (!special_storage_policy_) | |
| 905 return NULL; | |
| 906 | |
| 907 CookieTreeNode::DetailedInfo info = cookie_node.GetDetailedInfo(); | |
| 908 | |
| 909 if (!TypeIsProtected(info.node_type)) | |
| 910 return NULL; | |
| 911 | |
| 912 DCHECK(!info.origin.is_empty()); | |
| 913 return special_storage_policy_->ExtensionsProtectingOrigin(info.origin); | |
| 914 } | |
| 915 | |
| 788 void CookiesTreeModel::AddCookiesTreeObserver(Observer* observer) { | 916 void CookiesTreeModel::AddCookiesTreeObserver(Observer* observer) { |
| 789 cookies_observer_list_.AddObserver(observer); | 917 cookies_observer_list_.AddObserver(observer); |
| 790 // Call super so that TreeNodeModel can notify, too. | 918 // Call super so that TreeNodeModel can notify, too. |
| 791 ui::TreeNodeModel<CookieTreeNode>::AddObserver(observer); | 919 ui::TreeNodeModel<CookieTreeNode>::AddObserver(observer); |
| 792 } | 920 } |
| 793 | 921 |
| 794 void CookiesTreeModel::RemoveCookiesTreeObserver(Observer* observer) { | 922 void CookiesTreeModel::RemoveCookiesTreeObserver(Observer* observer) { |
| 795 cookies_observer_list_.RemoveObserver(observer); | 923 cookies_observer_list_.RemoveObserver(observer); |
| 796 // Call super so that TreeNodeModel doesn't have dead pointers. | 924 // Call super so that TreeNodeModel doesn't have dead pointers. |
| 797 ui::TreeNodeModel<CookieTreeNode>::RemoveObserver(observer); | 925 ui::TreeNodeModel<CookieTreeNode>::RemoveObserver(observer); |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 809 return; | 937 return; |
| 810 | 938 |
| 811 for (InfoByOrigin::const_iterator origin = | 939 for (InfoByOrigin::const_iterator origin = |
| 812 appcache_info->infos_by_origin.begin(); | 940 appcache_info->infos_by_origin.begin(); |
| 813 origin != appcache_info->infos_by_origin.end(); ++origin) { | 941 origin != appcache_info->infos_by_origin.end(); ++origin) { |
| 814 std::list<AppCacheInfo>& info_list = appcache_info_[origin->first]; | 942 std::list<AppCacheInfo>& info_list = appcache_info_[origin->first]; |
| 815 info_list.insert( | 943 info_list.insert( |
| 816 info_list.begin(), origin->second.begin(), origin->second.end()); | 944 info_list.begin(), origin->second.begin(), origin->second.end()); |
| 817 } | 945 } |
| 818 | 946 |
| 819 PopulateAppCacheInfoWithFilter(std::wstring()); | 947 PopulateAppCacheInfoWithFilter(string16()); |
| 820 } | 948 } |
| 821 | 949 |
| 822 void CookiesTreeModel::PopulateAppCacheInfoWithFilter( | 950 void CookiesTreeModel::PopulateAppCacheInfoWithFilter( |
| 823 const std::wstring& filter) { | 951 const string16& filter) { |
| 824 using appcache::AppCacheInfo; | 952 using appcache::AppCacheInfo; |
| 825 typedef std::map<GURL, std::list<AppCacheInfo> > InfoByOrigin; | 953 typedef std::map<GURL, std::list<AppCacheInfo> > InfoByOrigin; |
| 826 | 954 |
| 827 if (appcache_info_.empty()) | 955 if (appcache_info_.empty()) |
| 828 return; | 956 return; |
| 829 | 957 |
| 830 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); | 958 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); |
| 831 NotifyObserverBeginBatch(); | 959 NotifyObserverBeginBatch(); |
| 832 for (InfoByOrigin::iterator origin = appcache_info_.begin(); | 960 for (InfoByOrigin::iterator origin = appcache_info_.begin(); |
| 833 origin != appcache_info_.end(); ++origin) { | 961 origin != appcache_info_.end(); ++origin) { |
| 834 std::wstring origin_node_name = UTF8ToWide(origin->first.host()); | 962 string16 host_node_name = UTF8ToUTF16(origin->first.host()); |
| 835 if (filter.empty() || | 963 if (filter.empty() || |
| 836 (origin_node_name.find(filter) != std::wstring::npos)) { | 964 (host_node_name.find(filter) != std::string::npos)) { |
| 837 CookieTreeOriginNode* origin_node = | 965 CookieTreeHostNode* host_node = |
| 838 root->GetOrCreateOriginNode(origin->first); | 966 root->GetOrCreateHostNode(origin->first); |
| 839 CookieTreeAppCachesNode* appcaches_node = | 967 CookieTreeAppCachesNode* appcaches_node = |
| 840 origin_node->GetOrCreateAppCachesNode(); | 968 host_node->GetOrCreateAppCachesNode(); |
| 841 | 969 |
| 842 for (std::list<AppCacheInfo>::iterator info = origin->second.begin(); | 970 for (std::list<AppCacheInfo>::iterator info = origin->second.begin(); |
| 843 info != origin->second.end(); ++info) { | 971 info != origin->second.end(); ++info) { |
| 844 appcaches_node->AddAppCacheNode( | 972 appcaches_node->AddAppCacheNode( |
| 845 new CookieTreeAppCacheNode(origin->first, info)); | 973 new CookieTreeAppCacheNode(origin->first, info)); |
| 846 } | 974 } |
| 847 } | 975 } |
| 848 } | 976 } |
| 849 NotifyObserverTreeNodeChanged(root); | 977 NotifyObserverTreeNodeChanged(root); |
| 850 NotifyObserverEndBatch(); | 978 NotifyObserverEndBatch(); |
| 851 } | 979 } |
| 852 | 980 |
| 853 void CookiesTreeModel::OnCookiesModelInfoLoaded( | 981 void CookiesTreeModel::OnCookiesModelInfoLoaded( |
| 854 const net::CookieList& cookie_list) { | 982 const net::CookieList& cookie_list) { |
| 855 cookie_list_.insert(cookie_list_.begin(), | 983 cookie_list_.insert(cookie_list_.begin(), |
| 856 cookie_list.begin(), | 984 cookie_list.begin(), |
| 857 cookie_list.end()); | 985 cookie_list.end()); |
| 858 PopulateCookieInfoWithFilter(std::wstring()); | 986 PopulateCookieInfoWithFilter(string16()); |
| 859 } | 987 } |
| 860 | 988 |
| 861 void CookiesTreeModel::PopulateCookieInfoWithFilter( | 989 void CookiesTreeModel::PopulateCookieInfoWithFilter( |
| 862 const std::wstring& filter) { | 990 const string16& filter) { |
| 863 // mmargh mmargh mmargh! delicious! | 991 // mmargh mmargh mmargh! delicious! |
| 864 | 992 |
| 865 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); | 993 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); |
| 866 NotifyObserverBeginBatch(); | 994 NotifyObserverBeginBatch(); |
| 867 for (CookieList::iterator it = cookie_list_.begin(); | 995 for (CookieList::iterator it = cookie_list_.begin(); |
| 868 it != cookie_list_.end(); ++it) { | 996 it != cookie_list_.end(); ++it) { |
| 869 std::string source_string = it->Source(); | 997 std::string source_string = it->Source(); |
| 870 if (source_string.empty() || !use_cookie_source_) { | 998 if (source_string.empty() || !use_cookie_source_) { |
| 871 std::string domain = it->Domain(); | 999 std::string domain = it->Domain(); |
| 872 if (domain.length() > 1 && domain[0] == '.') | 1000 if (domain.length() > 1 && domain[0] == '.') |
| 873 domain = domain.substr(1); | 1001 domain = domain.substr(1); |
| 874 | 1002 |
| 875 // We treat secure cookies just the same as normal ones. | 1003 // We treat secure cookies just the same as normal ones. |
| 876 source_string = std::string(chrome::kHttpScheme) + | 1004 source_string = std::string(chrome::kHttpScheme) + |
| 877 content::kStandardSchemeSeparator + domain + "/"; | 1005 content::kStandardSchemeSeparator + domain + "/"; |
| 878 } | 1006 } |
| 879 | 1007 |
| 880 GURL source(source_string); | 1008 GURL source(source_string); |
| 881 if (!filter.size() || | 1009 if (!filter.size() || |
| 882 (CookieTreeOriginNode::TitleForUrl(source).find(filter) != | 1010 (CookieTreeHostNode::TitleForUrl(source).find(filter) != |
| 883 std::string::npos)) { | 1011 std::string::npos)) { |
| 884 CookieTreeOriginNode* origin_node = | 1012 CookieTreeHostNode* host_node = |
| 885 root->GetOrCreateOriginNode(source); | 1013 root->GetOrCreateHostNode(source); |
| 886 CookieTreeCookiesNode* cookies_node = | 1014 CookieTreeCookiesNode* cookies_node = |
| 887 origin_node->GetOrCreateCookiesNode(); | 1015 host_node->GetOrCreateCookiesNode(); |
| 888 CookieTreeCookieNode* new_cookie = new CookieTreeCookieNode(it); | 1016 CookieTreeCookieNode* new_cookie = new CookieTreeCookieNode(it); |
| 889 cookies_node->AddCookieNode(new_cookie); | 1017 cookies_node->AddCookieNode(new_cookie); |
| 890 } | 1018 } |
| 891 } | 1019 } |
| 892 NotifyObserverTreeNodeChanged(root); | 1020 NotifyObserverTreeNodeChanged(root); |
| 893 NotifyObserverEndBatch(); | 1021 NotifyObserverEndBatch(); |
| 894 } | 1022 } |
| 895 | 1023 |
| 896 void CookiesTreeModel::OnDatabaseModelInfoLoaded( | 1024 void CookiesTreeModel::OnDatabaseModelInfoLoaded( |
| 897 const DatabaseInfoList& database_info) { | 1025 const DatabaseInfoList& database_info) { |
| 898 database_info_list_ = database_info; | 1026 database_info_list_ = database_info; |
| 899 PopulateDatabaseInfoWithFilter(std::wstring()); | 1027 PopulateDatabaseInfoWithFilter(string16()); |
| 900 } | 1028 } |
| 901 | 1029 |
| 902 void CookiesTreeModel::PopulateDatabaseInfoWithFilter( | 1030 void CookiesTreeModel::PopulateDatabaseInfoWithFilter( |
| 903 const std::wstring& filter) { | 1031 const string16& filter) { |
| 904 if (database_info_list_.empty()) | 1032 if (database_info_list_.empty()) |
| 905 return; | 1033 return; |
| 906 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); | 1034 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); |
| 907 NotifyObserverBeginBatch(); | 1035 NotifyObserverBeginBatch(); |
| 908 for (DatabaseInfoList::iterator database_info = database_info_list_.begin(); | 1036 for (DatabaseInfoList::iterator database_info = database_info_list_.begin(); |
| 909 database_info != database_info_list_.end(); | 1037 database_info != database_info_list_.end(); |
| 910 ++database_info) { | 1038 ++database_info) { |
| 911 GURL origin(database_info->origin); | 1039 GURL origin(database_info->origin); |
| 912 | 1040 |
| 913 if (!filter.size() || | 1041 if (!filter.size() || |
| 914 (CookieTreeOriginNode::TitleForUrl(origin).find(filter) != | 1042 (CookieTreeHostNode::TitleForUrl(origin).find(filter) != |
| 915 std::wstring::npos)) { | 1043 std::string::npos)) { |
| 916 CookieTreeOriginNode* origin_node = | 1044 CookieTreeHostNode* host_node = |
| 917 root->GetOrCreateOriginNode(origin); | 1045 root->GetOrCreateHostNode(origin); |
| 918 CookieTreeDatabasesNode* databases_node = | 1046 CookieTreeDatabasesNode* databases_node = |
| 919 origin_node->GetOrCreateDatabasesNode(); | 1047 host_node->GetOrCreateDatabasesNode(); |
| 920 databases_node->AddDatabaseNode( | 1048 databases_node->AddDatabaseNode( |
| 921 new CookieTreeDatabaseNode(database_info)); | 1049 new CookieTreeDatabaseNode(database_info)); |
| 922 } | 1050 } |
| 923 } | 1051 } |
| 924 NotifyObserverTreeNodeChanged(root); | 1052 NotifyObserverTreeNodeChanged(root); |
| 925 NotifyObserverEndBatch(); | 1053 NotifyObserverEndBatch(); |
| 926 } | 1054 } |
| 927 | 1055 |
| 928 void CookiesTreeModel::OnLocalStorageModelInfoLoaded( | 1056 void CookiesTreeModel::OnLocalStorageModelInfoLoaded( |
| 929 const LocalStorageInfoList& local_storage_info) { | 1057 const LocalStorageInfoList& local_storage_info) { |
| 930 local_storage_info_list_ = local_storage_info; | 1058 local_storage_info_list_ = local_storage_info; |
| 931 PopulateLocalStorageInfoWithFilter(std::wstring()); | 1059 PopulateLocalStorageInfoWithFilter(string16()); |
| 932 } | 1060 } |
| 933 | 1061 |
| 934 void CookiesTreeModel::PopulateLocalStorageInfoWithFilter( | 1062 void CookiesTreeModel::PopulateLocalStorageInfoWithFilter( |
| 935 const std::wstring& filter) { | 1063 const string16& filter) { |
| 936 if (local_storage_info_list_.empty()) | 1064 if (local_storage_info_list_.empty()) |
| 937 return; | 1065 return; |
| 938 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); | 1066 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); |
| 939 NotifyObserverBeginBatch(); | 1067 NotifyObserverBeginBatch(); |
| 940 for (LocalStorageInfoList::iterator local_storage_info = | 1068 for (LocalStorageInfoList::iterator local_storage_info = |
| 941 local_storage_info_list_.begin(); | 1069 local_storage_info_list_.begin(); |
| 942 local_storage_info != local_storage_info_list_.end(); | 1070 local_storage_info != local_storage_info_list_.end(); |
| 943 ++local_storage_info) { | 1071 ++local_storage_info) { |
| 944 const GURL& origin(local_storage_info->origin_url); | 1072 const GURL& origin(local_storage_info->origin_url); |
| 945 | 1073 |
| 946 if (!filter.size() || | 1074 if (!filter.size() || |
| 947 (CookieTreeOriginNode::TitleForUrl(origin).find(filter) != | 1075 (CookieTreeHostNode::TitleForUrl(origin).find(filter) != |
| 948 std::wstring::npos)) { | 1076 std::string::npos)) { |
| 949 CookieTreeOriginNode* origin_node = | 1077 CookieTreeHostNode* host_node = |
| 950 root->GetOrCreateOriginNode(origin); | 1078 root->GetOrCreateHostNode(origin); |
| 951 CookieTreeLocalStoragesNode* local_storages_node = | 1079 CookieTreeLocalStoragesNode* local_storages_node = |
| 952 origin_node->GetOrCreateLocalStoragesNode(); | 1080 host_node->GetOrCreateLocalStoragesNode(); |
| 953 local_storages_node->AddLocalStorageNode( | 1081 local_storages_node->AddLocalStorageNode( |
| 954 new CookieTreeLocalStorageNode(local_storage_info)); | 1082 new CookieTreeLocalStorageNode(local_storage_info)); |
| 955 } | 1083 } |
| 956 } | 1084 } |
| 957 NotifyObserverTreeNodeChanged(root); | 1085 NotifyObserverTreeNodeChanged(root); |
| 958 NotifyObserverEndBatch(); | 1086 NotifyObserverEndBatch(); |
| 959 } | 1087 } |
| 960 | 1088 |
| 961 void CookiesTreeModel::OnSessionStorageModelInfoLoaded( | 1089 void CookiesTreeModel::OnSessionStorageModelInfoLoaded( |
| 962 const LocalStorageInfoList& session_storage_info) { | 1090 const LocalStorageInfoList& session_storage_info) { |
| 963 session_storage_info_list_ = session_storage_info; | 1091 session_storage_info_list_ = session_storage_info; |
| 964 PopulateSessionStorageInfoWithFilter(std::wstring()); | 1092 PopulateSessionStorageInfoWithFilter(string16()); |
| 965 } | 1093 } |
| 966 | 1094 |
| 967 void CookiesTreeModel::PopulateSessionStorageInfoWithFilter( | 1095 void CookiesTreeModel::PopulateSessionStorageInfoWithFilter( |
| 968 const std::wstring& filter) { | 1096 const string16& filter) { |
| 969 if (session_storage_info_list_.empty()) | 1097 if (session_storage_info_list_.empty()) |
| 970 return; | 1098 return; |
| 971 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); | 1099 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); |
| 972 NotifyObserverBeginBatch(); | 1100 NotifyObserverBeginBatch(); |
| 973 for (LocalStorageInfoList::iterator session_storage_info = | 1101 for (LocalStorageInfoList::iterator session_storage_info = |
| 974 session_storage_info_list_.begin(); | 1102 session_storage_info_list_.begin(); |
| 975 session_storage_info != session_storage_info_list_.end(); | 1103 session_storage_info != session_storage_info_list_.end(); |
| 976 ++session_storage_info) { | 1104 ++session_storage_info) { |
| 977 const GURL& origin = session_storage_info->origin_url; | 1105 const GURL& origin = session_storage_info->origin_url; |
| 978 if (!filter.size() || | 1106 if (!filter.size() || |
| 979 (CookieTreeOriginNode::TitleForUrl(origin).find(filter) != | 1107 (CookieTreeHostNode::TitleForUrl(origin).find(filter) != |
| 980 std::wstring::npos)) { | 1108 std::string::npos)) { |
| 981 CookieTreeOriginNode* origin_node = | 1109 CookieTreeHostNode* host_node = |
| 982 root->GetOrCreateOriginNode(origin); | 1110 root->GetOrCreateHostNode(origin); |
| 983 CookieTreeSessionStoragesNode* session_storages_node = | 1111 CookieTreeSessionStoragesNode* session_storages_node = |
| 984 origin_node->GetOrCreateSessionStoragesNode(); | 1112 host_node->GetOrCreateSessionStoragesNode(); |
| 985 session_storages_node->AddSessionStorageNode( | 1113 session_storages_node->AddSessionStorageNode( |
| 986 new CookieTreeSessionStorageNode(session_storage_info)); | 1114 new CookieTreeSessionStorageNode(session_storage_info)); |
| 987 } | 1115 } |
| 988 } | 1116 } |
| 989 NotifyObserverTreeNodeChanged(root); | 1117 NotifyObserverTreeNodeChanged(root); |
| 990 NotifyObserverEndBatch(); | 1118 NotifyObserverEndBatch(); |
| 991 } | 1119 } |
| 992 | 1120 |
| 993 void CookiesTreeModel::OnIndexedDBModelInfoLoaded( | 1121 void CookiesTreeModel::OnIndexedDBModelInfoLoaded( |
| 994 const IndexedDBInfoList& indexed_db_info) { | 1122 const IndexedDBInfoList& indexed_db_info) { |
| 995 indexed_db_info_list_ = indexed_db_info; | 1123 indexed_db_info_list_ = indexed_db_info; |
| 996 PopulateIndexedDBInfoWithFilter(std::wstring()); | 1124 PopulateIndexedDBInfoWithFilter(string16()); |
| 997 } | 1125 } |
| 998 | 1126 |
| 999 void CookiesTreeModel::PopulateIndexedDBInfoWithFilter( | 1127 void CookiesTreeModel::PopulateIndexedDBInfoWithFilter( |
| 1000 const std::wstring& filter) { | 1128 const string16& filter) { |
| 1001 if (indexed_db_info_list_.empty()) | 1129 if (indexed_db_info_list_.empty()) |
| 1002 return; | 1130 return; |
| 1003 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); | 1131 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); |
| 1004 NotifyObserverBeginBatch(); | 1132 NotifyObserverBeginBatch(); |
| 1005 for (IndexedDBInfoList::iterator indexed_db_info = | 1133 for (IndexedDBInfoList::iterator indexed_db_info = |
| 1006 indexed_db_info_list_.begin(); | 1134 indexed_db_info_list_.begin(); |
| 1007 indexed_db_info != indexed_db_info_list_.end(); | 1135 indexed_db_info != indexed_db_info_list_.end(); |
| 1008 ++indexed_db_info) { | 1136 ++indexed_db_info) { |
| 1009 const GURL& origin = indexed_db_info->origin; | 1137 const GURL& origin = indexed_db_info->origin; |
| 1010 | 1138 |
| 1011 if (!filter.size() || | 1139 if (!filter.size() || |
| 1012 (CookieTreeOriginNode::TitleForUrl(origin).find(filter) != | 1140 (CookieTreeHostNode::TitleForUrl(origin).find(filter) != |
| 1013 std::wstring::npos)) { | 1141 std::string::npos)) { |
| 1014 CookieTreeOriginNode* origin_node = | 1142 CookieTreeHostNode* host_node = |
| 1015 root->GetOrCreateOriginNode(origin); | 1143 root->GetOrCreateHostNode(origin); |
| 1016 CookieTreeIndexedDBsNode* indexed_dbs_node = | 1144 CookieTreeIndexedDBsNode* indexed_dbs_node = |
| 1017 origin_node->GetOrCreateIndexedDBsNode(); | 1145 host_node->GetOrCreateIndexedDBsNode(); |
| 1018 indexed_dbs_node->AddIndexedDBNode( | 1146 indexed_dbs_node->AddIndexedDBNode( |
| 1019 new CookieTreeIndexedDBNode(indexed_db_info)); | 1147 new CookieTreeIndexedDBNode(indexed_db_info)); |
| 1020 } | 1148 } |
| 1021 } | 1149 } |
| 1022 NotifyObserverTreeNodeChanged(root); | 1150 NotifyObserverTreeNodeChanged(root); |
| 1023 NotifyObserverEndBatch(); | 1151 NotifyObserverEndBatch(); |
| 1024 } | 1152 } |
| 1025 | 1153 |
| 1026 void CookiesTreeModel::OnFileSystemModelInfoLoaded( | 1154 void CookiesTreeModel::OnFileSystemModelInfoLoaded( |
| 1027 const FileSystemInfoList& file_system_info) { | 1155 const FileSystemInfoList& file_system_info) { |
| 1028 file_system_info_list_ = file_system_info; | 1156 file_system_info_list_ = file_system_info; |
| 1029 PopulateFileSystemInfoWithFilter(std::wstring()); | 1157 PopulateFileSystemInfoWithFilter(string16()); |
| 1030 } | 1158 } |
| 1031 | 1159 |
| 1032 void CookiesTreeModel::PopulateFileSystemInfoWithFilter( | 1160 void CookiesTreeModel::PopulateFileSystemInfoWithFilter( |
| 1033 const std::wstring& filter) { | 1161 const string16& filter) { |
| 1034 if (file_system_info_list_.empty()) | 1162 if (file_system_info_list_.empty()) |
| 1035 return; | 1163 return; |
| 1036 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); | 1164 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); |
| 1037 NotifyObserverBeginBatch(); | 1165 NotifyObserverBeginBatch(); |
| 1038 for (FileSystemInfoList::iterator file_system_info = | 1166 for (FileSystemInfoList::iterator file_system_info = |
| 1039 file_system_info_list_.begin(); | 1167 file_system_info_list_.begin(); |
| 1040 file_system_info != file_system_info_list_.end(); | 1168 file_system_info != file_system_info_list_.end(); |
| 1041 ++file_system_info) { | 1169 ++file_system_info) { |
| 1042 GURL origin(file_system_info->origin); | 1170 GURL origin(file_system_info->origin); |
| 1043 | 1171 |
| 1044 if (!filter.size() || | 1172 if (!filter.size() || |
| 1045 (CookieTreeOriginNode::TitleForUrl(origin).find(filter) != | 1173 (CookieTreeHostNode::TitleForUrl(origin).find(filter) != |
| 1046 std::wstring::npos)) { | 1174 std::string::npos)) { |
| 1047 CookieTreeOriginNode* origin_node = | 1175 CookieTreeHostNode* host_node = |
| 1048 root->GetOrCreateOriginNode(origin); | 1176 root->GetOrCreateHostNode(origin); |
| 1049 CookieTreeFileSystemsNode* file_systems_node = | 1177 CookieTreeFileSystemsNode* file_systems_node = |
| 1050 origin_node->GetOrCreateFileSystemsNode(); | 1178 host_node->GetOrCreateFileSystemsNode(); |
| 1051 file_systems_node->AddFileSystemNode( | 1179 file_systems_node->AddFileSystemNode( |
| 1052 new CookieTreeFileSystemNode(file_system_info)); | 1180 new CookieTreeFileSystemNode(file_system_info)); |
| 1053 } | 1181 } |
| 1054 } | 1182 } |
| 1055 NotifyObserverTreeNodeChanged(root); | 1183 NotifyObserverTreeNodeChanged(root); |
| 1056 NotifyObserverEndBatch(); | 1184 NotifyObserverEndBatch(); |
| 1057 } | 1185 } |
| 1058 | 1186 |
| 1059 void CookiesTreeModel::OnQuotaModelInfoLoaded( | 1187 void CookiesTreeModel::OnQuotaModelInfoLoaded( |
| 1060 const QuotaInfoArray& quota_info) { | 1188 const QuotaInfoArray& quota_info) { |
| 1061 quota_info_list_ = quota_info; | 1189 quota_info_list_ = quota_info; |
| 1062 PopulateQuotaInfoWithFilter(std::wstring()); | 1190 PopulateQuotaInfoWithFilter(string16()); |
| 1063 } | 1191 } |
| 1064 | 1192 |
| 1065 void CookiesTreeModel::PopulateQuotaInfoWithFilter( | 1193 void CookiesTreeModel::PopulateQuotaInfoWithFilter( |
| 1066 const std::wstring& filter) { | 1194 const string16& filter) { |
| 1067 if (quota_info_list_.empty()) | 1195 if (quota_info_list_.empty()) |
| 1068 return; | 1196 return; |
| 1069 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); | 1197 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); |
| 1070 NotifyObserverBeginBatch(); | 1198 NotifyObserverBeginBatch(); |
| 1071 for (QuotaInfoArray::iterator quota_info = quota_info_list_.begin(); | 1199 for (QuotaInfoArray::iterator quota_info = quota_info_list_.begin(); |
| 1072 quota_info != quota_info_list_.end(); | 1200 quota_info != quota_info_list_.end(); |
| 1073 ++quota_info) { | 1201 ++quota_info) { |
| 1074 if (!filter.size() || | 1202 if (!filter.size() || |
| 1075 (UTF8ToWide(quota_info->host).find(filter) != std::wstring::npos)) { | 1203 (UTF8ToUTF16(quota_info->host).find(filter) != std::string::npos)) { |
| 1076 CookieTreeOriginNode* origin_node = | 1204 CookieTreeHostNode* host_node = |
| 1077 root->GetOrCreateOriginNode(GURL("http://" + quota_info->host)); | 1205 root->GetOrCreateHostNode(GURL("http://" + quota_info->host)); |
| 1078 origin_node->UpdateOrCreateQuotaNode(quota_info); | 1206 host_node->UpdateOrCreateQuotaNode(quota_info); |
| 1079 } | 1207 } |
| 1080 } | 1208 } |
| 1081 NotifyObserverTreeNodeChanged(root); | 1209 NotifyObserverTreeNodeChanged(root); |
| 1082 NotifyObserverEndBatch(); | 1210 NotifyObserverEndBatch(); |
| 1083 } | 1211 } |
| 1084 | 1212 |
| 1085 void CookiesTreeModel::OnServerBoundCertModelInfoLoaded( | 1213 void CookiesTreeModel::OnServerBoundCertModelInfoLoaded( |
| 1086 const ServerBoundCertList& cert_list) { | 1214 const ServerBoundCertList& cert_list) { |
| 1087 server_bound_cert_list_ = cert_list; | 1215 server_bound_cert_list_ = cert_list; |
| 1088 PopulateServerBoundCertInfoWithFilter(std::wstring()); | 1216 PopulateServerBoundCertInfoWithFilter(string16()); |
| 1089 } | 1217 } |
| 1090 | 1218 |
| 1091 void CookiesTreeModel::PopulateServerBoundCertInfoWithFilter( | 1219 void CookiesTreeModel::PopulateServerBoundCertInfoWithFilter( |
| 1092 const std::wstring& filter) { | 1220 const string16& filter) { |
| 1093 if (server_bound_cert_list_.empty()) | 1221 if (server_bound_cert_list_.empty()) |
| 1094 return; | 1222 return; |
| 1095 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); | 1223 CookieTreeRootNode* root = static_cast<CookieTreeRootNode*>(GetRoot()); |
| 1096 NotifyObserverBeginBatch(); | 1224 NotifyObserverBeginBatch(); |
| 1097 for (ServerBoundCertList::iterator cert_info = | 1225 for (ServerBoundCertList::iterator cert_info = |
| 1098 server_bound_cert_list_.begin(); | 1226 server_bound_cert_list_.begin(); |
| 1099 cert_info != server_bound_cert_list_.end(); | 1227 cert_info != server_bound_cert_list_.end(); |
| 1100 ++cert_info) { | 1228 ++cert_info) { |
| 1101 GURL origin(cert_info->server_identifier()); | 1229 GURL origin(cert_info->server_identifier()); |
| 1102 if (!origin.is_valid()) { | 1230 if (!origin.is_valid()) { |
| 1103 // Domain Bound Cert. Make a valid URL to satisfy the | 1231 // Domain Bound Cert. Make a valid URL to satisfy the |
| 1104 // CookieTreeRootNode::GetOrCreateOriginNode interface. | 1232 // CookieTreeRootNode::GetOrCreateHostNode interface. |
| 1105 origin = GURL(std::string(chrome::kHttpsScheme) + | 1233 origin = GURL(std::string(chrome::kHttpsScheme) + |
| 1106 content::kStandardSchemeSeparator + | 1234 content::kStandardSchemeSeparator + |
| 1107 cert_info->server_identifier() + "/"); | 1235 cert_info->server_identifier() + "/"); |
| 1108 } | 1236 } |
| 1109 std::wstring title = CookieTreeOriginNode::TitleForUrl(origin); | 1237 string16 title = CookieTreeHostNode::TitleForUrl(origin); |
| 1110 | 1238 |
| 1111 if (!filter.size() || title.find(filter) != std::wstring::npos) { | 1239 if (!filter.size() || title.find(filter) != std::string::npos) { |
| 1112 CookieTreeOriginNode* origin_node = | 1240 CookieTreeHostNode* host_node = |
| 1113 root->GetOrCreateOriginNode(origin); | 1241 root->GetOrCreateHostNode(origin); |
| 1114 CookieTreeServerBoundCertsNode* server_bound_certs_node = | 1242 CookieTreeServerBoundCertsNode* server_bound_certs_node = |
| 1115 origin_node->GetOrCreateServerBoundCertsNode(); | 1243 host_node->GetOrCreateServerBoundCertsNode(); |
| 1116 server_bound_certs_node->AddServerBoundCertNode( | 1244 server_bound_certs_node->AddServerBoundCertNode( |
| 1117 new CookieTreeServerBoundCertNode(cert_info)); | 1245 new CookieTreeServerBoundCertNode(cert_info)); |
| 1118 } | 1246 } |
| 1119 } | 1247 } |
| 1120 NotifyObserverTreeNodeChanged(root); | 1248 NotifyObserverTreeNodeChanged(root); |
| 1121 NotifyObserverEndBatch(); | 1249 NotifyObserverEndBatch(); |
| 1122 } | 1250 } |
| 1123 | 1251 |
| 1124 void CookiesTreeModel::NotifyObserverBeginBatch() { | 1252 void CookiesTreeModel::NotifyObserverBeginBatch() { |
| 1125 // Only notify the model once if we're batching in a nested manner. | 1253 // Only notify the model once if we're batching in a nested manner. |
| 1126 if (batch_update_++ == 0) { | 1254 if (batch_update_++ == 0) { |
| 1127 FOR_EACH_OBSERVER(Observer, | 1255 FOR_EACH_OBSERVER(Observer, |
| 1128 cookies_observer_list_, | 1256 cookies_observer_list_, |
| 1129 TreeModelBeginBatch(this)); | 1257 TreeModelBeginBatch(this)); |
| 1130 } | 1258 } |
| 1131 } | 1259 } |
| 1132 | 1260 |
| 1133 void CookiesTreeModel::NotifyObserverEndBatch() { | 1261 void CookiesTreeModel::NotifyObserverEndBatch() { |
| 1134 // Only notify the observers if this is the outermost call to EndBatch() if | 1262 // Only notify the observers if this is the outermost call to EndBatch() if |
| 1135 // called in a nested manner. | 1263 // called in a nested manner. |
| 1136 if (--batch_update_ == 0) { | 1264 if (--batch_update_ == 0) { |
| 1137 FOR_EACH_OBSERVER(Observer, | 1265 FOR_EACH_OBSERVER(Observer, |
| 1138 cookies_observer_list_, | 1266 cookies_observer_list_, |
| 1139 TreeModelEndBatch(this)); | 1267 TreeModelEndBatch(this)); |
| 1140 } | 1268 } |
| 1141 } | 1269 } |
| OLD | NEW |