Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(56)

Side by Side Diff: chrome/browser/ui/webui/options2/clear_browser_data_handler2.cc

Issue 10502015: Adding "Clear hosted app data" checkbox to browsing data removal UI. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Feedback. Created 8 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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
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
OLDNEW
« no previous file with comments | « chrome/browser/ui/webui/options2/clear_browser_data_handler2.h ('k') | chrome/common/pref_names.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698