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/ui/webui/options2/clear_browser_data_handler2.h" | 5 #include "chrome/browser/ui/webui/options2/clear_browser_data_handler2.h" |
| 6 | 6 |
| 7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
| 8 #include "base/bind.h" | 8 #include "base/bind.h" |
| 9 #include "base/bind_helpers.h" | 9 #include "base/bind_helpers.h" |
| 10 #include "base/string16.h" | 10 #include "base/string16.h" |
| 11 #include "base/values.h" | 11 #include "base/values.h" |
| 12 #include "chrome/browser/browser_process.h" | 12 #include "chrome/browser/browser_process.h" |
| 13 #include "chrome/browser/browsing_data_helper.h" | 13 #include "chrome/browser/browsing_data_helper.h" |
| 14 #include "chrome/browser/browsing_data_remover.h" | 14 #include "chrome/browser/browsing_data_remover.h" |
| 15 #include "chrome/browser/prefs/pref_service.h" | 15 #include "chrome/browser/prefs/pref_service.h" |
| 16 #include "chrome/browser/profiles/profile.h" | 16 #include "chrome/browser/profiles/profile.h" |
| 17 #include "chrome/common/pref_names.h" | 17 #include "chrome/common/pref_names.h" |
| 18 #include "content/public/browser/notification_details.h" | 18 #include "content/public/browser/notification_details.h" |
| 19 #include "content/public/browser/web_ui.h" | 19 #include "content/public/browser/web_ui.h" |
| 20 #include "grit/chromium_strings.h" | 20 #include "grit/chromium_strings.h" |
| 21 #include "grit/generated_resources.h" | 21 #include "grit/generated_resources.h" |
| 22 #include "grit/locale_settings.h" | 22 #include "grit/locale_settings.h" |
| 23 #include "ui/base/l10n/l10n_util.h" | 23 #include "ui/base/l10n/l10n_util.h" |
| 24 | 24 |
| 25 namespace options2 { | 25 namespace options2 { |
| 26 | 26 |
| 27 ClearBrowserDataHandler::ClearBrowserDataHandler() : remover_(NULL) { | 27 ClearBrowserDataHandler::ClearBrowserDataHandler() |
| 28 : remover_(NULL), | |
| 29 remove_hosted_app_data_pending_(false) { | |
| 28 } | 30 } |
| 29 | 31 |
| 30 ClearBrowserDataHandler::~ClearBrowserDataHandler() { | 32 ClearBrowserDataHandler::~ClearBrowserDataHandler() { |
| 31 if (remover_) | 33 if (remover_) |
| 32 remover_->RemoveObserver(this); | 34 remover_->RemoveObserver(this); |
| 33 } | 35 } |
| 34 | 36 |
| 35 void ClearBrowserDataHandler::InitializeHandler() { | 37 void ClearBrowserDataHandler::InitializeHandler() { |
| 36 clear_plugin_lso_data_enabled_.Init(prefs::kClearPluginLSODataEnabled, | 38 clear_plugin_lso_data_enabled_.Init(prefs::kClearPluginLSODataEnabled, |
| 37 Profile::FromWebUI(web_ui())->GetPrefs(), | 39 Profile::FromWebUI(web_ui())->GetPrefs(), |
| 38 NULL); | 40 NULL); |
| 39 } | 41 } |
| 40 | 42 |
| 41 void ClearBrowserDataHandler::GetLocalizedValues( | 43 void ClearBrowserDataHandler::GetLocalizedValues( |
| 42 DictionaryValue* localized_strings) { | 44 DictionaryValue* localized_strings) { |
| 43 DCHECK(localized_strings); | 45 DCHECK(localized_strings); |
| 44 | 46 |
| 45 static OptionsStringResource resources[] = { | 47 static OptionsStringResource resources[] = { |
| 46 { "clearBrowserDataLabel", IDS_CLEAR_BROWSING_DATA_LABEL }, | 48 { "clearBrowserDataLabel", IDS_CLEAR_BROWSING_DATA_LABEL }, |
| 47 { "deleteBrowsingHistoryCheckbox", IDS_DEL_BROWSING_HISTORY_CHKBOX }, | 49 { "deleteBrowsingHistoryCheckbox", IDS_DEL_BROWSING_HISTORY_CHKBOX }, |
| 48 { "deleteDownloadHistoryCheckbox", IDS_DEL_DOWNLOAD_HISTORY_CHKBOX }, | 50 { "deleteDownloadHistoryCheckbox", IDS_DEL_DOWNLOAD_HISTORY_CHKBOX }, |
| 49 { "deleteCacheCheckbox", IDS_DEL_CACHE_CHKBOX }, | 51 { "deleteCacheCheckbox", IDS_DEL_CACHE_CHKBOX }, |
| 50 { "deleteCookiesCheckbox", IDS_DEL_COOKIES_CHKBOX }, | 52 { "deleteCookiesCheckbox", IDS_DEL_COOKIES_CHKBOX }, |
| 51 { "deleteCookiesFlashCheckbox", IDS_DEL_COOKIES_FLASH_CHKBOX }, | 53 { "deleteCookiesFlashCheckbox", IDS_DEL_COOKIES_FLASH_CHKBOX }, |
| 52 { "deletePasswordsCheckbox", IDS_DEL_PASSWORDS_CHKBOX }, | 54 { "deletePasswordsCheckbox", IDS_DEL_PASSWORDS_CHKBOX }, |
| 53 { "deleteFormDataCheckbox", IDS_DEL_FORM_DATA_CHKBOX }, | 55 { "deleteFormDataCheckbox", IDS_DEL_FORM_DATA_CHKBOX }, |
| 56 { "deleteHostedAppsDataCheckbox", IDS_DEL_HOSTED_APPS_DATA_CHKBOX }, | |
| 54 { "deauthorizeContentLicensesCheckbox", | 57 { "deauthorizeContentLicensesCheckbox", |
| 55 IDS_DEAUTHORIZE_CONTENT_LICENSES_CHKBOX }, | 58 IDS_DEAUTHORIZE_CONTENT_LICENSES_CHKBOX }, |
| 56 { "clearBrowserDataCommit", IDS_CLEAR_BROWSING_DATA_COMMIT }, | 59 { "clearBrowserDataCommit", IDS_CLEAR_BROWSING_DATA_COMMIT }, |
| 57 { "flash_storage_url", IDS_FLASH_STORAGE_URL }, | 60 { "flash_storage_url", IDS_FLASH_STORAGE_URL }, |
| 58 }; | 61 }; |
| 59 | 62 |
| 60 RegisterStrings(localized_strings, resources, arraysize(resources)); | 63 RegisterStrings(localized_strings, resources, arraysize(resources)); |
| 61 RegisterTitle(localized_strings, "clearBrowserDataOverlay", | 64 RegisterTitle(localized_strings, "clearBrowserDataOverlay", |
| 62 IDS_CLEAR_BROWSING_DATA_TITLE); | 65 IDS_CLEAR_BROWSING_DATA_TITLE); |
| 63 | 66 |
| (...skipping 21 matching lines...) Expand all Loading... | |
| 85 option->Append(Value::CreateIntegerValue(i)); | 88 option->Append(Value::CreateIntegerValue(i)); |
| 86 option->Append(Value::CreateStringValue(label_string)); | 89 option->Append(Value::CreateStringValue(label_string)); |
| 87 time_list->Append(option); | 90 time_list->Append(option); |
| 88 } | 91 } |
| 89 localized_strings->Set("clearBrowserDataTimeList", time_list); | 92 localized_strings->Set("clearBrowserDataTimeList", time_list); |
| 90 } | 93 } |
| 91 | 94 |
| 92 void ClearBrowserDataHandler::RegisterMessages() { | 95 void ClearBrowserDataHandler::RegisterMessages() { |
| 93 // Setup handlers specific to this panel. | 96 // Setup handlers specific to this panel. |
| 94 web_ui()->RegisterMessageCallback("performClearBrowserData", | 97 web_ui()->RegisterMessageCallback("performClearBrowserData", |
| 95 base::Bind(&ClearBrowserDataHandler::HandleClearBrowserData, | 98 base::Bind(&ClearBrowserDataHandler::ClearBrowserData, |
| 96 base::Unretained(this))); | 99 base::Unretained(this))); |
| 97 } | 100 } |
| 98 | 101 |
| 99 void ClearBrowserDataHandler::HandleClearBrowserData(const ListValue* value) { | 102 void ClearBrowserDataHandler::ClearBrowserData(const ListValue* value) { |
|
Evan Stade
2012/06/05 18:07:45
this one actually does handle a chrome.send messag
Mike West
2012/06/11 09:35:44
Done.
| |
| 100 Profile* profile = Profile::FromWebUI(web_ui()); | 103 Profile* profile = Profile::FromWebUI(web_ui()); |
| 101 PrefService* prefs = profile->GetPrefs(); | 104 PrefService* prefs = profile->GetPrefs(); |
| 102 | 105 |
| 103 int remove_mask = 0; | 106 int remove_mask = 0; |
| 104 if (prefs->GetBoolean(prefs::kDeleteBrowsingHistory)) | 107 if (prefs->GetBoolean(prefs::kDeleteBrowsingHistory)) |
| 105 remove_mask |= BrowsingDataRemover::REMOVE_HISTORY; | 108 remove_mask |= BrowsingDataRemover::REMOVE_HISTORY; |
| 106 if (prefs->GetBoolean(prefs::kDeleteDownloadHistory)) | 109 if (prefs->GetBoolean(prefs::kDeleteDownloadHistory)) |
| 107 remove_mask |= BrowsingDataRemover::REMOVE_DOWNLOADS; | 110 remove_mask |= BrowsingDataRemover::REMOVE_DOWNLOADS; |
| 108 if (prefs->GetBoolean(prefs::kDeleteCache)) | 111 if (prefs->GetBoolean(prefs::kDeleteCache)) |
| 109 remove_mask |= BrowsingDataRemover::REMOVE_CACHE; | 112 remove_mask |= BrowsingDataRemover::REMOVE_CACHE; |
| 110 if (prefs->GetBoolean(prefs::kDeleteCookies)) { | 113 if (prefs->GetBoolean(prefs::kDeleteCookies)) { |
| 111 int site_data_mask = BrowsingDataRemover::REMOVE_SITE_DATA; | 114 int site_data_mask = BrowsingDataRemover::REMOVE_SITE_DATA; |
| 112 // Don't try to clear LSO data if it's not supported. | 115 // Don't try to clear LSO data if it's not supported. |
| 113 if (!*clear_plugin_lso_data_enabled_) | 116 if (!*clear_plugin_lso_data_enabled_) |
| 114 site_data_mask &= ~BrowsingDataRemover::REMOVE_PLUGIN_DATA; | 117 site_data_mask &= ~BrowsingDataRemover::REMOVE_PLUGIN_DATA; |
| 115 remove_mask |= site_data_mask; | 118 remove_mask |= site_data_mask; |
| 116 } | 119 } |
| 117 if (prefs->GetBoolean(prefs::kDeletePasswords)) | 120 if (prefs->GetBoolean(prefs::kDeletePasswords)) |
| 118 remove_mask |= BrowsingDataRemover::REMOVE_PASSWORDS; | 121 remove_mask |= BrowsingDataRemover::REMOVE_PASSWORDS; |
| 119 if (prefs->GetBoolean(prefs::kDeleteFormData)) | 122 if (prefs->GetBoolean(prefs::kDeleteFormData)) |
| 120 remove_mask |= BrowsingDataRemover::REMOVE_FORM_DATA; | 123 remove_mask |= BrowsingDataRemover::REMOVE_FORM_DATA; |
| 121 if (prefs->GetBoolean(prefs::kDeauthorizeContentLicenses)) | 124 if (prefs->GetBoolean(prefs::kDeauthorizeContentLicenses)) |
| 122 remove_mask |= BrowsingDataRemover::REMOVE_CONTENT_LICENSES; | 125 remove_mask |= BrowsingDataRemover::REMOVE_CONTENT_LICENSES; |
| 123 | 126 |
| 127 remove_hosted_app_data_pending_ = | |
| 128 prefs->GetBoolean(prefs::kDeleteHostedAppsData); | |
| 129 | |
| 124 int period_selected = prefs->GetInteger(prefs::kDeleteTimePeriod); | 130 int period_selected = prefs->GetInteger(prefs::kDeleteTimePeriod); |
|
Evan Stade
2012/06/05 18:07:45
this should be declared where it's used.
Mike West
2012/06/11 09:35:44
Done.
| |
| 125 | 131 |
| 126 base::FundamentalValue state(true); | 132 base::FundamentalValue state(true); |
| 127 web_ui()->CallJavascriptFunction("ClearBrowserDataOverlay.setClearingState", | 133 web_ui()->CallJavascriptFunction("ClearBrowserDataOverlay.setClearingState", |
| 128 state); | 134 state); |
|
Evan Stade
2012/06/05 18:07:45
(read this comment after the one right below)
OK,
Mike West
2012/06/11 09:35:44
Good catch. I've moved this out into the JavaScrip
| |
| 129 | 135 |
| 130 // If we are still observing a previous data remover, we need to stop | 136 // If we are still observing a previous data remover, we need to stop |
| 131 // observing. | 137 // observing. |
| 132 if (remover_) | 138 if (remover_) |
| 133 remover_->RemoveObserver(this); | 139 remover_->RemoveObserver(this); |
|
Evan Stade
2012/06/05 18:07:45
I don't really like this pattern. How would (Handl
Mike West
2012/06/11 09:35:44
If `remover_` is non-NULL, then something unexpect
| |
| 134 | 140 |
| 135 // BrowsingDataRemover deletes itself when done. | 141 // BrowsingDataRemover deletes itself when done. |
| 136 remover_ = new BrowsingDataRemover(profile, | 142 remover_ = new BrowsingDataRemover(profile, |
| 137 static_cast<BrowsingDataRemover::TimePeriod>(period_selected), | 143 static_cast<BrowsingDataRemover::TimePeriod>(period_selected), |
| 138 base::Time()); | 144 base::Time()); |
| 139 remover_->AddObserver(this); | 145 remover_->AddObserver(this); |
| 140 remover_->Remove(remove_mask, BrowsingDataHelper::UNPROTECTED_WEB); | 146 remover_->Remove(remove_mask, BrowsingDataHelper::UNPROTECTED_WEB); |
|
Evan Stade
2012/06/05 18:07:45
it seems that remove_mask can be 0 here, in which
battre
2012/06/07 21:17:24
We rely on the callback even if remove_mask is 0 h
Evan Stade
2012/06/07 21:50:21
yea, I can see that. Doesn't mean it makes sense.
Mike West
2012/06/11 09:35:44
You're right. I've added a skip. I've also handled
| |
| 141 } | 147 } |
| 142 | 148 |
| 149 void ClearBrowserDataHandler::ClearHostedAppData() { | |
| 150 Profile* profile = Profile::FromWebUI(web_ui()); | |
| 151 PrefService* prefs = profile->GetPrefs(); | |
| 152 | |
| 153 // If we are still observing a previous data remover, we need to stop | |
| 154 // observing. | |
| 155 if (remover_) | |
|
Evan Stade
2012/06/05 18:07:45
this is still here. intentional?
battre
2012/06/07 21:17:24
This was just for defensive programming. There is
Evan Stade
2012/06/07 21:50:21
then DCHECK(!remover_) is more appropriate
Mike West
2012/06/11 09:35:44
Done.
| |
| 156 remover_->RemoveObserver(this); | |
| 157 | |
| 158 int period_selected = prefs->GetInteger(prefs::kDeleteTimePeriod); | |
| 159 // BrowsingDataRemover deletes itself when done. | |
| 160 remover_ = new BrowsingDataRemover( | |
| 161 profile, | |
| 162 static_cast<BrowsingDataRemover::TimePeriod>(period_selected), | |
| 163 base::Time()); | |
| 164 remover_->AddObserver(this); | |
| 165 remover_->Remove(BrowsingDataRemover::REMOVE_SITE_DATA, | |
| 166 BrowsingDataHelper::PROTECTED_WEB); | |
| 167 } | |
| 168 | |
| 143 void ClearBrowserDataHandler::OnBrowsingDataRemoverDone() { | 169 void ClearBrowserDataHandler::OnBrowsingDataRemoverDone() { |
| 144 // No need to remove ourselves as an observer as BrowsingDataRemover deletes | 170 // No need to remove ourselves as an observer as BrowsingDataRemover deletes |
| 145 // itself after we return. | 171 // itself after we return. |
| 146 remover_ = NULL; | 172 remover_ = NULL; |
| 147 web_ui()->CallJavascriptFunction("ClearBrowserDataOverlay.doneClearing"); | 173 |
| 174 if (remove_hosted_app_data_pending_) { | |
| 175 remove_hosted_app_data_pending_ = false; | |
| 176 ClearHostedAppData(); | |
| 177 } else { | |
| 178 web_ui()->CallJavascriptFunction("ClearBrowserDataOverlay.doneClearing"); | |
| 179 } | |
| 148 } | 180 } |
| 149 | 181 |
| 150 } // namespace options2 | 182 } // namespace options2 |
| OLD | NEW |