| 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/browsing_data/local_data_container.h" | 5 #include "chrome/browser/browsing_data/local_data_container.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/memory/linked_ptr.h" | 8 #include "base/memory/linked_ptr.h" |
| 9 #include "chrome/browser/browsing_data/browsing_data_channel_id_helper.h" | 9 #include "chrome/browser/browsing_data/browsing_data_channel_id_helper.h" |
| 10 #include "chrome/browser/browsing_data/browsing_data_flash_lso_helper.h" | 10 #include "chrome/browser/browsing_data/browsing_data_flash_lso_helper.h" |
| (...skipping 21 matching lines...) Expand all Loading... |
| 32 database_helper_(database_helper), | 32 database_helper_(database_helper), |
| 33 local_storage_helper_(local_storage_helper), | 33 local_storage_helper_(local_storage_helper), |
| 34 session_storage_helper_(session_storage_helper), | 34 session_storage_helper_(session_storage_helper), |
| 35 indexed_db_helper_(indexed_db_helper), | 35 indexed_db_helper_(indexed_db_helper), |
| 36 file_system_helper_(file_system_helper), | 36 file_system_helper_(file_system_helper), |
| 37 quota_helper_(quota_helper), | 37 quota_helper_(quota_helper), |
| 38 channel_id_helper_(channel_id_helper), | 38 channel_id_helper_(channel_id_helper), |
| 39 service_worker_helper_(service_worker_helper), | 39 service_worker_helper_(service_worker_helper), |
| 40 flash_lso_helper_(flash_lso_helper), | 40 flash_lso_helper_(flash_lso_helper), |
| 41 model_(NULL), | 41 model_(NULL), |
| 42 batches_started_(0), |
| 42 weak_ptr_factory_(this) { | 43 weak_ptr_factory_(this) { |
| 43 } | 44 } |
| 44 | 45 |
| 45 LocalDataContainer::~LocalDataContainer() {} | 46 LocalDataContainer::~LocalDataContainer() {} |
| 46 | 47 |
| 47 void LocalDataContainer::Init(CookiesTreeModel* model) { | 48 void LocalDataContainer::Init(CookiesTreeModel* model) { |
| 48 DCHECK(!model_); | 49 DCHECK(!model_); |
| 49 model_ = model; | 50 model_ = model; |
| 50 | 51 |
| 52 batches_started_ = 1; |
| 51 DCHECK(cookie_helper_.get()); | 53 DCHECK(cookie_helper_.get()); |
| 52 cookie_helper_->StartFetching( | 54 cookie_helper_->StartFetching( |
| 53 base::Bind(&LocalDataContainer::OnCookiesModelInfoLoaded, | 55 base::Bind(&LocalDataContainer::OnCookiesModelInfoLoaded, |
| 54 weak_ptr_factory_.GetWeakPtr())); | 56 weak_ptr_factory_.GetWeakPtr())); |
| 55 | 57 |
| 56 if (database_helper_.get()) { | 58 if (database_helper_.get()) { |
| 59 batches_started_++; |
| 57 database_helper_->StartFetching( | 60 database_helper_->StartFetching( |
| 58 base::Bind(&LocalDataContainer::OnDatabaseModelInfoLoaded, | 61 base::Bind(&LocalDataContainer::OnDatabaseModelInfoLoaded, |
| 59 weak_ptr_factory_.GetWeakPtr())); | 62 weak_ptr_factory_.GetWeakPtr())); |
| 60 } | 63 } |
| 61 | 64 |
| 62 if (local_storage_helper_.get()) { | 65 if (local_storage_helper_.get()) { |
| 66 batches_started_++; |
| 63 local_storage_helper_->StartFetching( | 67 local_storage_helper_->StartFetching( |
| 64 base::Bind(&LocalDataContainer::OnLocalStorageModelInfoLoaded, | 68 base::Bind(&LocalDataContainer::OnLocalStorageModelInfoLoaded, |
| 65 weak_ptr_factory_.GetWeakPtr())); | 69 weak_ptr_factory_.GetWeakPtr())); |
| 66 } | 70 } |
| 67 | 71 |
| 68 if (session_storage_helper_.get()) { | 72 if (session_storage_helper_.get()) { |
| 73 batches_started_++; |
| 69 session_storage_helper_->StartFetching( | 74 session_storage_helper_->StartFetching( |
| 70 base::Bind(&LocalDataContainer::OnSessionStorageModelInfoLoaded, | 75 base::Bind(&LocalDataContainer::OnSessionStorageModelInfoLoaded, |
| 71 weak_ptr_factory_.GetWeakPtr())); | 76 weak_ptr_factory_.GetWeakPtr())); |
| 72 } | 77 } |
| 73 | 78 |
| 74 // TODO(michaeln): When all of the UI implementations have been updated, make | 79 // TODO(michaeln): When all of the UI implementations have been updated, make |
| 75 // this a required parameter. | 80 // this a required parameter. |
| 76 if (appcache_helper_.get()) { | 81 if (appcache_helper_.get()) { |
| 82 batches_started_++; |
| 77 appcache_helper_->StartFetching( | 83 appcache_helper_->StartFetching( |
| 78 base::Bind(&LocalDataContainer::OnAppCacheModelInfoLoaded, | 84 base::Bind(&LocalDataContainer::OnAppCacheModelInfoLoaded, |
| 79 weak_ptr_factory_.GetWeakPtr())); | 85 weak_ptr_factory_.GetWeakPtr())); |
| 80 } | 86 } |
| 81 | 87 |
| 82 if (indexed_db_helper_.get()) { | 88 if (indexed_db_helper_.get()) { |
| 89 batches_started_++; |
| 83 indexed_db_helper_->StartFetching( | 90 indexed_db_helper_->StartFetching( |
| 84 base::Bind(&LocalDataContainer::OnIndexedDBModelInfoLoaded, | 91 base::Bind(&LocalDataContainer::OnIndexedDBModelInfoLoaded, |
| 85 weak_ptr_factory_.GetWeakPtr())); | 92 weak_ptr_factory_.GetWeakPtr())); |
| 86 } | 93 } |
| 87 | 94 |
| 88 if (file_system_helper_.get()) { | 95 if (file_system_helper_.get()) { |
| 96 batches_started_++; |
| 89 file_system_helper_->StartFetching( | 97 file_system_helper_->StartFetching( |
| 90 base::Bind(&LocalDataContainer::OnFileSystemModelInfoLoaded, | 98 base::Bind(&LocalDataContainer::OnFileSystemModelInfoLoaded, |
| 91 weak_ptr_factory_.GetWeakPtr())); | 99 weak_ptr_factory_.GetWeakPtr())); |
| 92 } | 100 } |
| 93 | 101 |
| 94 if (quota_helper_.get()) { | 102 if (quota_helper_.get()) { |
| 103 batches_started_++; |
| 95 quota_helper_->StartFetching( | 104 quota_helper_->StartFetching( |
| 96 base::Bind(&LocalDataContainer::OnQuotaModelInfoLoaded, | 105 base::Bind(&LocalDataContainer::OnQuotaModelInfoLoaded, |
| 97 weak_ptr_factory_.GetWeakPtr())); | 106 weak_ptr_factory_.GetWeakPtr())); |
| 98 } | 107 } |
| 99 | 108 |
| 100 if (channel_id_helper_.get()) { | 109 if (channel_id_helper_.get()) { |
| 110 batches_started_++; |
| 101 channel_id_helper_->StartFetching( | 111 channel_id_helper_->StartFetching( |
| 102 base::Bind(&LocalDataContainer::OnChannelIDModelInfoLoaded, | 112 base::Bind(&LocalDataContainer::OnChannelIDModelInfoLoaded, |
| 103 weak_ptr_factory_.GetWeakPtr())); | 113 weak_ptr_factory_.GetWeakPtr())); |
| 104 } | 114 } |
| 105 | 115 |
| 106 if (service_worker_helper_.get()) { | 116 if (service_worker_helper_.get()) { |
| 117 batches_started_++; |
| 107 service_worker_helper_->StartFetching( | 118 service_worker_helper_->StartFetching( |
| 108 base::Bind(&LocalDataContainer::OnServiceWorkerModelInfoLoaded, | 119 base::Bind(&LocalDataContainer::OnServiceWorkerModelInfoLoaded, |
| 109 weak_ptr_factory_.GetWeakPtr())); | 120 weak_ptr_factory_.GetWeakPtr())); |
| 110 } | 121 } |
| 111 | 122 |
| 112 if (flash_lso_helper_.get()) { | 123 if (flash_lso_helper_.get()) { |
| 124 batches_started_++; |
| 113 flash_lso_helper_->StartFetching( | 125 flash_lso_helper_->StartFetching( |
| 114 base::Bind(&LocalDataContainer::OnFlashLSOInfoLoaded, | 126 base::Bind(&LocalDataContainer::OnFlashLSOInfoLoaded, |
| 115 weak_ptr_factory_.GetWeakPtr())); | 127 weak_ptr_factory_.GetWeakPtr())); |
| 116 } | 128 } |
| 129 |
| 130 model_->SetBatchExpectation(batches_started_, true); |
| 117 } | 131 } |
| 118 | 132 |
| 119 void LocalDataContainer::OnAppCacheModelInfoLoaded() { | 133 void LocalDataContainer::OnAppCacheModelInfoLoaded() { |
| 120 using content::AppCacheInfo; | 134 using content::AppCacheInfo; |
| 121 using content::AppCacheInfoCollection; | 135 using content::AppCacheInfoCollection; |
| 122 using content::AppCacheInfoVector; | 136 using content::AppCacheInfoVector; |
| 123 typedef std::map<GURL, AppCacheInfoVector> InfoByOrigin; | 137 typedef std::map<GURL, AppCacheInfoVector> InfoByOrigin; |
| 124 | 138 |
| 125 scoped_refptr<AppCacheInfoCollection> appcache_info = | 139 scoped_refptr<AppCacheInfoCollection> appcache_info = |
| 126 appcache_helper_->info_collection(); | 140 appcache_helper_->info_collection(); |
| 127 if (!appcache_info.get() || appcache_info->infos_by_origin.empty()) | 141 if (!appcache_info.get() || appcache_info->infos_by_origin.empty()) { |
| 142 // This batch has been canceled, so let the model know it won't be arriving. |
| 143 model_->SetBatchExpectation(--batches_started_, false); |
| 128 return; | 144 return; |
| 145 } |
| 129 | 146 |
| 130 for (InfoByOrigin::const_iterator origin = | 147 for (InfoByOrigin::const_iterator origin = |
| 131 appcache_info->infos_by_origin.begin(); | 148 appcache_info->infos_by_origin.begin(); |
| 132 origin != appcache_info->infos_by_origin.end(); ++origin) { | 149 origin != appcache_info->infos_by_origin.end(); ++origin) { |
| 133 std::list<AppCacheInfo>& info_list = appcache_info_[origin->first]; | 150 std::list<AppCacheInfo>& info_list = appcache_info_[origin->first]; |
| 134 info_list.insert( | 151 info_list.insert( |
| 135 info_list.begin(), origin->second.begin(), origin->second.end()); | 152 info_list.begin(), origin->second.begin(), origin->second.end()); |
| 136 } | 153 } |
| 137 | 154 |
| 138 model_->PopulateAppCacheInfo(this); | 155 model_->PopulateAppCacheInfo(this); |
| (...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 202 DCHECK(model_); | 219 DCHECK(model_); |
| 203 model_->PopulateServiceWorkerUsageInfo(this); | 220 model_->PopulateServiceWorkerUsageInfo(this); |
| 204 } | 221 } |
| 205 | 222 |
| 206 void LocalDataContainer::OnFlashLSOInfoLoaded( | 223 void LocalDataContainer::OnFlashLSOInfoLoaded( |
| 207 const FlashLSODomainList& domains) { | 224 const FlashLSODomainList& domains) { |
| 208 flash_lso_domain_list_ = domains; | 225 flash_lso_domain_list_ = domains; |
| 209 DCHECK(model_); | 226 DCHECK(model_); |
| 210 model_->PopulateFlashLSOInfo(this); | 227 model_->PopulateFlashLSOInfo(this); |
| 211 } | 228 } |
| OLD | NEW |