OLD | NEW |
---|---|
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/ui/webui/settings/settings_clear_browsing_data_handler. h" | 5 #include "chrome/browser/ui/webui/settings/settings_clear_browsing_data_handler. h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "base/feature_list.h" | 10 #include "base/feature_list.h" |
(...skipping 11 matching lines...) Expand all Loading... | |
22 #include "chrome/browser/engagement/important_sites_util.h" | 22 #include "chrome/browser/engagement/important_sites_util.h" |
23 #include "chrome/browser/history/web_history_service_factory.h" | 23 #include "chrome/browser/history/web_history_service_factory.h" |
24 #include "chrome/browser/sync/profile_sync_service_factory.h" | 24 #include "chrome/browser/sync/profile_sync_service_factory.h" |
25 #include "chrome/common/channel_info.h" | 25 #include "chrome/common/channel_info.h" |
26 #include "chrome/common/chrome_features.h" | 26 #include "chrome/common/chrome_features.h" |
27 #include "chrome/common/pref_names.h" | 27 #include "chrome/common/pref_names.h" |
28 #include "components/browsing_data/core/history_notice_utils.h" | 28 #include "components/browsing_data/core/history_notice_utils.h" |
29 #include "components/browsing_data/core/pref_names.h" | 29 #include "components/browsing_data/core/pref_names.h" |
30 #include "components/prefs/pref_service.h" | 30 #include "components/prefs/pref_service.h" |
31 #include "content/public/browser/browsing_data_filter_builder.h" | 31 #include "content/public/browser/browsing_data_filter_builder.h" |
32 #include "content/public/browser/storage_partition.h" | |
32 #include "content/public/browser/web_ui.h" | 33 #include "content/public/browser/web_ui.h" |
33 #include "ui/base/text/bytes_formatting.h" | 34 #include "ui/base/text/bytes_formatting.h" |
34 | 35 |
35 namespace { | 36 namespace { |
36 | 37 |
37 const int kMaxTimesHistoryNoticeShown = 1; | 38 const int kMaxTimesHistoryNoticeShown = 1; |
38 | 39 |
39 const int kMaxImportantSites = 10; | |
40 | |
41 // TODO(msramek): Get the list of deletion preferences from the JS side. | 40 // TODO(msramek): Get the list of deletion preferences from the JS side. |
42 const char* kCounterPrefs[] = { | 41 const char* kCounterPrefs[] = { |
43 browsing_data::prefs::kDeleteBrowsingHistory, | 42 browsing_data::prefs::kDeleteBrowsingHistory, |
44 browsing_data::prefs::kDeleteCache, | 43 browsing_data::prefs::kDeleteCache, |
45 browsing_data::prefs::kDeleteDownloadHistory, | 44 browsing_data::prefs::kDeleteDownloadHistory, |
46 browsing_data::prefs::kDeleteFormData, | 45 browsing_data::prefs::kDeleteFormData, |
47 browsing_data::prefs::kDeleteHostedAppsData, | 46 browsing_data::prefs::kDeleteHostedAppsData, |
48 browsing_data::prefs::kDeleteMediaLicenses, | 47 browsing_data::prefs::kDeleteMediaLicenses, |
49 browsing_data::prefs::kDeletePasswords, | 48 browsing_data::prefs::kDeletePasswords, |
50 }; | 49 }; |
(...skipping 260 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
311 "History.ClearBrowsingData.ShownHistoryNoticeAfterClearing", show_notice); | 310 "History.ClearBrowsingData.ShownHistoryNoticeAfterClearing", show_notice); |
312 | 311 |
313 ResolveJavascriptCallback(base::Value(webui_callback_id), | 312 ResolveJavascriptCallback(base::Value(webui_callback_id), |
314 base::Value(show_notice)); | 313 base::Value(show_notice)); |
315 task_observer_.reset(); | 314 task_observer_.reset(); |
316 } | 315 } |
317 | 316 |
318 void ClearBrowsingDataHandler::HandleFetchImportantSites( | 317 void ClearBrowsingDataHandler::HandleFetchImportantSites( |
319 const base::ListValue* args) { | 318 const base::ListValue* args) { |
320 AllowJavascript(); | 319 AllowJavascript(); |
321 const base::Value* callback_id; | 320 std::string callback_id; |
322 CHECK(args->Get(0, &callback_id)); | 321 CHECK(args->GetString(0, &callback_id)); |
323 | 322 |
324 Profile* profile = profile_->GetOriginalProfile(); | 323 Profile* profile = profile_->GetOriginalProfile(); |
325 bool flag_enabled = | 324 bool flag_enabled = |
326 base::FeatureList::IsEnabled(features::kImportantSitesInCBD); | 325 base::FeatureList::IsEnabled(features::kImportantSitesInCBD); |
327 bool dialog_disabled = ImportantSitesUtil::IsDialogDisabled(profile); | 326 bool dialog_disabled = ImportantSitesUtil::IsDialogDisabled(profile); |
327 | |
328 if (!flag_enabled || dialog_disabled) { | |
329 std::unique_ptr<base::DictionaryValue> result(new base::DictionaryValue()); | |
dominickn
2017/04/10 05:06:12
auto result = base::MakeUnique<base::DictionaryVal
dullweber
2017/04/10 13:29:39
Done.
| |
330 result->SetBoolean(FLAG_ENABLED_FIELD, flag_enabled); | |
331 result->Set(IMPORTANT_SITES_FIELD, base::MakeUnique<base::ListValue>()); | |
332 ResolveJavascriptCallback(base::Value(callback_id), *result); | |
333 return; | |
334 } | |
335 | |
336 std::vector<ImportantSitesUtil::ImportantDomainInfo> important_sites = | |
337 ImportantSitesUtil::GetImportantRegisterableDomains( | |
338 profile, ImportantSitesUtil::kMaxImportantSites); | |
339 content::StoragePartition* partition = | |
340 content::BrowserContext::GetDefaultStoragePartition(profile); | |
341 storage::QuotaManager* quota_manager = partition->GetQuotaManager(); | |
342 content::DOMStorageContext* dom_storage = partition->GetDOMStorageContext(); | |
343 | |
344 ImportantSitesUtil::PopulateUsage( | |
345 quota_manager, dom_storage, std::move(important_sites), | |
346 base::Bind(&ClearBrowsingDataHandler::OnFetchImportantSitesFinished, | |
347 base::Unretained(this), callback_id)); | |
348 } | |
349 | |
350 void ClearBrowsingDataHandler::OnFetchImportantSitesFinished( | |
351 const std::string& callback_id, | |
352 std::vector<ImportantSitesUtil::ImportantDomainInfo> sites) { | |
328 auto important_sites_list = base::MakeUnique<base::ListValue>(); | 353 auto important_sites_list = base::MakeUnique<base::ListValue>(); |
329 | 354 for (const auto& info : sites) { |
330 if (flag_enabled && !dialog_disabled) { | 355 auto entry = base::MakeUnique<base::DictionaryValue>(); |
331 std::vector<ImportantSitesUtil::ImportantDomainInfo> important_sites = | 356 entry->SetString(REGISTERABLE_DOMAIN_FIELD, info.registerable_domain); |
332 ImportantSitesUtil::GetImportantRegisterableDomains(profile, | 357 entry->SetInteger(REASON_BITFIELD_FIELD, info.reason_bitfield); |
333 kMaxImportantSites); | 358 entry->SetString(EXAMPLE_ORIGIN_FIELD, info.example_origin.spec()); |
334 for (const auto& info : important_sites) { | 359 // Initially all sites are selected for deletion. |
335 auto entry = base::MakeUnique<base::DictionaryValue>(); | 360 entry->SetBoolean(IS_CHECKED_FIELD, true); |
336 entry->SetString(REGISTERABLE_DOMAIN_FIELD, info.registerable_domain); | 361 entry->SetString(STORAGE_SIZE_FIELD, ui::FormatBytes(info.usage)); |
337 entry->SetInteger(REASON_BITFIELD_FIELD, info.reason_bitfield); | 362 bool has_notifications = |
338 entry->SetString(EXAMPLE_ORIGIN_FIELD, info.example_origin.spec()); | 363 (info.reason_bitfield & |
339 // Initially all sites are selected for deletion. | 364 (1 << ImportantSitesUtil::ImportantReason::NOTIFICATIONS)) != 0; |
340 entry->SetBoolean(IS_CHECKED_FIELD, true); | 365 entry->SetBoolean(HAS_NOTIFICATIONS_FIELD, has_notifications); |
341 // TODO(dullweber): Get size. | 366 important_sites_list->Append(std::move(entry)); |
342 entry->SetString(STORAGE_SIZE_FIELD, ui::FormatBytes(0)); | |
343 bool has_notifications = | |
344 (info.reason_bitfield & | |
345 (1 << ImportantSitesUtil::ImportantReason::NOTIFICATIONS)) != 0; | |
346 entry->SetBoolean(HAS_NOTIFICATIONS_FIELD, has_notifications); | |
347 important_sites_list->Append(std::move(entry)); | |
348 } | |
349 } | 367 } |
350 | 368 |
351 std::unique_ptr<base::DictionaryValue> result(new base::DictionaryValue()); | 369 std::unique_ptr<base::DictionaryValue> result(new base::DictionaryValue()); |
352 result->SetBoolean(FLAG_ENABLED_FIELD, flag_enabled); | 370 result->SetBoolean(FLAG_ENABLED_FIELD, true); |
353 result->Set(IMPORTANT_SITES_FIELD, std::move(important_sites_list)); | 371 result->Set(IMPORTANT_SITES_FIELD, std::move(important_sites_list)); |
354 | 372 ResolveJavascriptCallback(base::Value(callback_id), *result); |
355 ResolveJavascriptCallback(*callback_id, *result); | |
356 } | 373 } |
357 | 374 |
358 void ClearBrowsingDataHandler::HandleInitialize(const base::ListValue* args) { | 375 void ClearBrowsingDataHandler::HandleInitialize(const base::ListValue* args) { |
359 AllowJavascript(); | 376 AllowJavascript(); |
360 const base::Value* callback_id; | 377 const base::Value* callback_id; |
361 CHECK(args->Get(0, &callback_id)); | 378 CHECK(args->Get(0, &callback_id)); |
362 | 379 |
363 // Needed because WebUI doesn't handle renderer crashes. See crbug.com/610450. | 380 // Needed because WebUI doesn't handle renderer crashes. See crbug.com/610450. |
364 task_observer_.reset(); | 381 task_observer_.reset(); |
365 | 382 |
(...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
434 | 451 |
435 void ClearBrowsingDataHandler::UpdateCounterText( | 452 void ClearBrowsingDataHandler::UpdateCounterText( |
436 std::unique_ptr<browsing_data::BrowsingDataCounter::Result> result) { | 453 std::unique_ptr<browsing_data::BrowsingDataCounter::Result> result) { |
437 CallJavascriptFunction( | 454 CallJavascriptFunction( |
438 "cr.webUIListenerCallback", base::Value("update-counter-text"), | 455 "cr.webUIListenerCallback", base::Value("update-counter-text"), |
439 base::Value(result->source()->GetPrefName()), | 456 base::Value(result->source()->GetPrefName()), |
440 base::Value(GetChromeCounterTextFromResult(result.get()))); | 457 base::Value(GetChromeCounterTextFromResult(result.get()))); |
441 } | 458 } |
442 | 459 |
443 } // namespace settings | 460 } // namespace settings |
OLD | NEW |