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 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 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); |
| 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); |
| 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); |
| 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); |
| 141 } | 147 } |
| 142 | 148 |
| 149 void ClearBrowserDataHandler::HandleClearHostedAppData() { | |
|
Evan Stade
2012/06/04 22:03:40
it's confusing to call this Handle... because that
Mike West
2012/06/05 08:55:02
Dropping "Handle" from this and the above "HandleC
| |
| 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/04 22:03:40
I don't think that remover_ can be non-NULL here b
Mike West
2012/06/05 08:55:02
I think you're right. That's the only callsite for
| |
| 156 remover_->RemoveObserver(this); | |
| 157 | |
| 158 int period_selected = prefs->GetInteger(prefs::kDeleteTimePeriod); | |
| 159 // BrowsingDataRemover deletes itself when done. | |
| 160 remover_ = new BrowsingDataRemover(profile, | |
|
markusheintz_
2012/06/04 14:50:52
nit: If I interpret the style guide correctly then
Mike West
2012/06/05 08:55:02
Done.
| |
| 161 static_cast<BrowsingDataRemover::TimePeriod>(period_selected), | |
| 162 base::Time()); | |
| 163 remover_->AddObserver(this); | |
| 164 remover_->Remove(BrowsingDataRemover::REMOVE_SITE_DATA, | |
| 165 BrowsingDataHelper::PROTECTED_WEB); | |
| 166 } | |
| 167 | |
| 143 void ClearBrowserDataHandler::OnBrowsingDataRemoverDone() { | 168 void ClearBrowserDataHandler::OnBrowsingDataRemoverDone() { |
| 144 // No need to remove ourselves as an observer as BrowsingDataRemover deletes | 169 // No need to remove ourselves as an observer as BrowsingDataRemover deletes |
| 145 // itself after we return. | 170 // itself after we return. |
| 146 remover_ = NULL; | 171 remover_ = NULL; |
| 147 web_ui()->CallJavascriptFunction("ClearBrowserDataOverlay.doneClearing"); | 172 |
| 173 if (remove_hosted_app_data_pending_) { | |
| 174 remove_hosted_app_data_pending_ = false; | |
| 175 HandleClearHostedAppData(); | |
|
Evan Stade
2012/06/04 22:03:40
why do you defer this until after the first set of
Mike West
2012/06/05 08:55:02
An excellent question, and one I should have read
Mike West
2012/06/05 08:55:02
It explodes. BRD is actually set up to explicitly
| |
| 176 } else { | |
| 177 web_ui()->CallJavascriptFunction("ClearBrowserDataOverlay.doneClearing"); | |
| 178 } | |
| 148 } | 179 } |
| 149 | 180 |
| 150 } // namespace options2 | 181 } // namespace options2 |
| OLD | NEW |