Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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/profile_resetter/resettable_settings_snapshot.h" | 5 #include "chrome/browser/profile_resetter/resettable_settings_snapshot.h" |
| 6 | 6 |
| 7 #include "base/json/json_writer.h" | 7 #include "base/json/json_writer.h" |
| 8 #include "base/prefs/pref_service.h" | 8 #include "base/prefs/pref_service.h" |
| 9 #include "base/strings/utf_string_conversions.h" | |
| 10 #include "base/values.h" | |
| 11 #include "chrome/browser/browser_process.h" | |
| 9 #include "chrome/browser/extensions/extension_service.h" | 12 #include "chrome/browser/extensions/extension_service.h" |
| 10 #include "chrome/browser/feedback/feedback_data.h" | 13 #include "chrome/browser/feedback/feedback_data.h" |
| 11 #include "chrome/browser/feedback/feedback_util.h" | 14 #include "chrome/browser/feedback/feedback_util.h" |
| 12 #include "chrome/browser/profiles/profile.h" | 15 #include "chrome/browser/profiles/profile.h" |
| 13 #include "chrome/browser/search_engines/template_url_service.h" | 16 #include "chrome/browser/search_engines/template_url_service.h" |
| 14 #include "chrome/browser/search_engines/template_url_service_factory.h" | 17 #include "chrome/browser/search_engines/template_url_service_factory.h" |
| 18 #include "chrome/common/chrome_version_info.h" | |
| 15 #include "chrome/common/pref_names.h" | 19 #include "chrome/common/pref_names.h" |
| 20 #include "grit/generated_resources.h" | |
| 21 #include "grit/google_chrome_strings.h" | |
| 22 #include "ui/base/l10n/l10n_util.h" | |
| 16 | 23 |
| 17 namespace { | 24 namespace { |
| 18 | 25 |
| 19 // Feedback bucket label. | 26 // Feedback bucket label. |
| 20 const char kProfileResetFeedbackBucket[] = "ProfileResetReport"; | 27 const char kProfileResetFeedbackBucket[] = "ProfileResetReport"; |
| 21 | 28 |
| 22 // Dictionary keys for feedback report. | 29 // Dictionary keys for feedback report. |
| 23 const char kDefaultSearchEnginePath[] = "default_search_engine"; | 30 const char kDefaultSearchEnginePath[] = "default_search_engine"; |
| 24 const char kEnabledExtensions[] = "enabled_extensions"; | 31 const char kEnabledExtensions[] = "enabled_extensions"; |
| 25 const char kHomepageIsNewTabPage[] = "homepage_is_ntp"; | 32 const char kHomepageIsNewTabPage[] = "homepage_is_ntp"; |
| 26 const char kHomepagePath[] = "homepage"; | 33 const char kHomepagePath[] = "homepage"; |
| 27 const char kStartupTypePath[] = "startup_type"; | 34 const char kStartupTypePath[] = "startup_type"; |
| 28 const char kStartupURLPath[] = "startup_urls"; | 35 const char kStartupURLPath[] = "startup_urls"; |
| 29 | 36 |
| 37 void AddPair(ListValue* list, const string16& key, const string16& value) { | |
| 38 DictionaryValue* results = new DictionaryValue(); | |
| 39 results->SetString("key", key); | |
| 40 results->SetString("value", value); | |
| 41 list->Append(results); | |
| 42 } | |
| 43 | |
| 30 } // namespace | 44 } // namespace |
| 31 | 45 |
| 32 ResettableSettingsSnapshot::ResettableSettingsSnapshot(Profile* profile) | 46 ResettableSettingsSnapshot::ResettableSettingsSnapshot(Profile* profile) |
| 33 : startup_(SessionStartupPref::GetStartupPref(profile)) { | 47 : startup_(SessionStartupPref::GetStartupPref(profile)) { |
| 34 // URLs are always stored sorted. | 48 // URLs are always stored sorted. |
| 35 std::sort(startup_.urls.begin(), startup_.urls.end()); | 49 std::sort(startup_.urls.begin(), startup_.urls.end()); |
| 36 | 50 |
| 37 PrefService* prefs = profile->GetPrefs(); | 51 PrefService* prefs = profile->GetPrefs(); |
| 38 DCHECK(prefs); | 52 DCHECK(prefs); |
| 39 homepage_ = prefs->GetString(prefs::kHomePage); | 53 homepage_ = prefs->GetString(prefs::kHomePage); |
| 40 homepage_is_ntp_ = prefs->GetBoolean(prefs::kHomePageIsNewTabPage); | 54 homepage_is_ntp_ = prefs->GetBoolean(prefs::kHomePageIsNewTabPage); |
| 41 | 55 |
| 42 TemplateURLService* service = | 56 TemplateURLService* service = |
| 43 TemplateURLServiceFactory::GetForProfile(profile); | 57 TemplateURLServiceFactory::GetForProfile(profile); |
| 44 DCHECK(service); | 58 DCHECK(service); |
| 45 TemplateURL* dse = service->GetDefaultSearchProvider(); | 59 TemplateURL* dse = service->GetDefaultSearchProvider(); |
| 46 if (dse) | 60 if (dse) |
| 47 dse_url_ = dse->url(); | 61 dse_url_ = dse->url(); |
| 48 | 62 |
| 49 ExtensionService* extension_service = profile->GetExtensionService(); | 63 ExtensionService* extension_service = profile->GetExtensionService(); |
| 50 DCHECK(extension_service); | 64 DCHECK(extension_service); |
| 51 const ExtensionSet* enabled_ext = extension_service->extensions(); | 65 const ExtensionSet* enabled_ext = extension_service->extensions(); |
| 52 enabled_extensions_.reserve(enabled_ext->size()); | 66 enabled_extensions_.reserve(enabled_ext->size()); |
| 53 | 67 |
| 54 for (ExtensionSet::const_iterator it = enabled_ext->begin(); | 68 for (ExtensionSet::const_iterator it = enabled_ext->begin(); |
| 55 it != enabled_ext->end(); ++it) | 69 it != enabled_ext->end(); ++it) |
| 56 enabled_extensions_.push_back((*it)->id()); | 70 enabled_extensions_.push_back(std::make_pair((*it)->id(), (*it)->name())); |
| 57 | 71 |
| 58 // ExtensionSet is sorted but it seems to be an implementation detail. | 72 // ExtensionSet is sorted but it seems to be an implementation detail. |
| 59 std::sort(enabled_extensions_.begin(), enabled_extensions_.end()); | 73 std::sort(enabled_extensions_.begin(), enabled_extensions_.end()); |
| 60 } | 74 } |
| 61 | 75 |
| 62 ResettableSettingsSnapshot::~ResettableSettingsSnapshot() {} | 76 ResettableSettingsSnapshot::~ResettableSettingsSnapshot() {} |
| 63 | 77 |
| 64 void ResettableSettingsSnapshot::Subtract( | 78 void ResettableSettingsSnapshot::Subtract( |
| 65 const ResettableSettingsSnapshot& snapshot) { | 79 const ResettableSettingsSnapshot& snapshot) { |
| 66 std::vector<GURL> urls; | 80 std::vector<GURL> urls; |
| 67 std::set_difference(startup_.urls.begin(), startup_.urls.end(), | 81 std::set_difference(startup_.urls.begin(), startup_.urls.end(), |
| 68 snapshot.startup_.urls.begin(), | 82 snapshot.startup_.urls.begin(), |
| 69 snapshot.startup_.urls.end(), | 83 snapshot.startup_.urls.end(), |
| 70 std::back_inserter(urls)); | 84 std::back_inserter(urls)); |
| 71 startup_.urls.swap(urls); | 85 startup_.urls.swap(urls); |
| 72 | 86 |
| 73 std::vector<std::string> extensions; | 87 ExtensionList extensions; |
| 74 std::set_difference(enabled_extensions_.begin(), enabled_extensions_.end(), | 88 std::set_difference(enabled_extensions_.begin(), enabled_extensions_.end(), |
| 75 snapshot.enabled_extensions_.begin(), | 89 snapshot.enabled_extensions_.begin(), |
| 76 snapshot.enabled_extensions_.end(), | 90 snapshot.enabled_extensions_.end(), |
| 77 std::back_inserter(extensions)); | 91 std::back_inserter(extensions)); |
| 78 enabled_extensions_.swap(extensions); | 92 enabled_extensions_.swap(extensions); |
| 79 } | 93 } |
| 80 | 94 |
| 81 int ResettableSettingsSnapshot::FindDifferentFields( | 95 int ResettableSettingsSnapshot::FindDifferentFields( |
| 82 const ResettableSettingsSnapshot& snapshot) const { | 96 const ResettableSettingsSnapshot& snapshot) const { |
| 83 int bit_mask = 0; | 97 int bit_mask = 0; |
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 127 dict.SetString(kHomepagePath, snapshot.homepage()); | 141 dict.SetString(kHomepagePath, snapshot.homepage()); |
| 128 | 142 |
| 129 if (field_mask & ResettableSettingsSnapshot::HOMEPAGE_IS_NTP) | 143 if (field_mask & ResettableSettingsSnapshot::HOMEPAGE_IS_NTP) |
| 130 dict.SetBoolean(kHomepageIsNewTabPage, snapshot.homepage_is_ntp()); | 144 dict.SetBoolean(kHomepageIsNewTabPage, snapshot.homepage_is_ntp()); |
| 131 | 145 |
| 132 if (field_mask & ResettableSettingsSnapshot::DSE_URL) | 146 if (field_mask & ResettableSettingsSnapshot::DSE_URL) |
| 133 dict.SetString(kDefaultSearchEnginePath, snapshot.dse_url()); | 147 dict.SetString(kDefaultSearchEnginePath, snapshot.dse_url()); |
| 134 | 148 |
| 135 if (field_mask & ResettableSettingsSnapshot::EXTENSIONS) { | 149 if (field_mask & ResettableSettingsSnapshot::EXTENSIONS) { |
| 136 ListValue* list = new ListValue; | 150 ListValue* list = new ListValue; |
| 137 const std::vector<std::string>& extensions = snapshot.enabled_extensions(); | 151 const ResettableSettingsSnapshot::ExtensionList& extensions = |
| 138 for (std::vector<std::string>::const_iterator i = extensions.begin(); | 152 snapshot.enabled_extensions(); |
| 139 i != extensions.end(); ++i) | 153 for (ResettableSettingsSnapshot::ExtensionList::const_iterator i = |
| 140 list->AppendString(*i); | 154 extensions.begin(); i != extensions.end(); ++i) |
| 155 list->AppendString(i->first + ";" + i->second); | |
|
battre
2013/09/13 08:59:02
One more request: Can you strip quotes (") from i-
vasilii
2013/09/16 13:58:02
Done.
| |
| 141 dict.Set(kEnabledExtensions, list); | 156 dict.Set(kEnabledExtensions, list); |
| 142 } | 157 } |
| 143 | 158 |
| 144 COMPILE_ASSERT(ResettableSettingsSnapshot::ALL_FIELDS == 63, | 159 COMPILE_ASSERT(ResettableSettingsSnapshot::ALL_FIELDS == 63, |
| 145 serialize_new_field_here); | 160 serialize_new_field_here); |
| 146 | 161 |
| 147 std::string json; | 162 std::string json; |
| 148 base::JSONWriter::Write(&dict, &json); | 163 base::JSONWriter::Write(&dict, &json); |
| 149 return json; | 164 return json; |
| 150 } | 165 } |
| 151 | 166 |
| 152 void SendSettingsFeedback(const std::string& report, Profile* profile) { | 167 void SendSettingsFeedback(const std::string& report, Profile* profile) { |
| 153 scoped_refptr<FeedbackData> feedback_data = new FeedbackData(); | 168 scoped_refptr<FeedbackData> feedback_data = new FeedbackData(); |
| 154 feedback_data->set_category_tag(kProfileResetFeedbackBucket); | 169 feedback_data->set_category_tag(kProfileResetFeedbackBucket); |
| 155 feedback_data->set_description(report); | 170 feedback_data->set_description(report); |
| 156 | 171 |
| 157 feedback_data->set_image(scoped_ptr<std::string>(new std::string)); | 172 feedback_data->set_image(scoped_ptr<std::string>(new std::string)); |
| 158 feedback_data->set_profile(profile); | 173 feedback_data->set_profile(profile); |
| 159 | 174 |
| 160 feedback_data->set_page_url(""); | 175 feedback_data->set_page_url(""); |
| 161 feedback_data->set_user_email(""); | 176 feedback_data->set_user_email(""); |
| 162 | 177 |
| 163 feedback_util::SendReport(feedback_data); | 178 feedback_util::SendReport(feedback_data); |
| 164 } | 179 } |
| 180 | |
| 181 ListValue* GetReadableFeedback(Profile* profile) { | |
| 182 DCHECK(profile); | |
| 183 ListValue* list = new ListValue; | |
| 184 AddPair(list, l10n_util::GetStringUTF16(IDS_RESET_PROFILE_SETTINGS_LOCALE), | |
| 185 ASCIIToUTF16(g_browser_process->GetApplicationLocale())); | |
| 186 AddPair(list, | |
| 187 l10n_util::GetStringUTF16(IDS_RESET_PROFILE_SETTINGS_USER_AGENT), | |
| 188 ASCIIToUTF16(content::GetUserAgent(GURL()))); | |
| 189 chrome::VersionInfo version_info; | |
| 190 std::string version = version_info.Version(); | |
| 191 version += chrome::VersionInfo::GetVersionStringModifier(); | |
| 192 AddPair(list, | |
| 193 l10n_util::GetStringUTF16(IDS_PRODUCT_NAME), | |
| 194 ASCIIToUTF16(version)); | |
| 195 | |
| 196 // Add snapshot data. | |
| 197 ResettableSettingsSnapshot snapshot(profile); | |
| 198 const std::vector<GURL>& urls = snapshot.startup_urls(); | |
| 199 std::string startup_urls; | |
| 200 for (std::vector<GURL>::const_iterator i = urls.begin(); | |
| 201 i != urls.end(); ++i) { | |
| 202 (startup_urls += i->host()) += ' '; | |
| 203 } | |
| 204 if (!startup_urls.empty()) { | |
| 205 AddPair(list, | |
| 206 l10n_util::GetStringUTF16(IDS_RESET_PROFILE_SETTINGS_STARTUP_URLS), | |
| 207 ASCIIToUTF16(startup_urls)); | |
| 208 } | |
| 209 | |
| 210 string16 startup_type; | |
| 211 switch (snapshot.startup_type()) { | |
| 212 case SessionStartupPref::DEFAULT: | |
| 213 startup_type = l10n_util::GetStringUTF16(IDS_OPTIONS_STARTUP_SHOW_NEWTAB); | |
| 214 break; | |
| 215 case SessionStartupPref::LAST: | |
| 216 startup_type = l10n_util::GetStringUTF16( | |
| 217 IDS_OPTIONS_STARTUP_RESTORE_LAST_SESSION); | |
| 218 break; | |
| 219 case SessionStartupPref::URLS: | |
| 220 startup_type = l10n_util::GetStringUTF16(IDS_OPTIONS_STARTUP_SHOW_PAGES); | |
| 221 break; | |
| 222 default: | |
| 223 break; | |
| 224 } | |
| 225 AddPair(list, | |
| 226 l10n_util::GetStringUTF16(IDS_RESET_PROFILE_SETTINGS_STARTUP_TYPE), | |
| 227 startup_type); | |
| 228 | |
| 229 if (!snapshot.homepage().empty()) { | |
| 230 AddPair(list, | |
| 231 l10n_util::GetStringUTF16(IDS_RESET_PROFILE_SETTINGS_HOMEPAGE), | |
| 232 ASCIIToUTF16(snapshot.homepage())); | |
| 233 } | |
| 234 | |
| 235 int is_ntp_message_id = snapshot.homepage_is_ntp() ? | |
| 236 IDS_RESET_PROFILE_SETTINGS_HOMEPAGE_IS_NTP_TRUE : | |
| 237 IDS_RESET_PROFILE_SETTINGS_HOMEPAGE_IS_NTP_FALSE; | |
| 238 AddPair(list, | |
| 239 l10n_util::GetStringUTF16(IDS_RESET_PROFILE_SETTINGS_HOMEPAGE_IS_NTP), | |
| 240 l10n_util::GetStringUTF16(is_ntp_message_id)); | |
| 241 | |
| 242 TemplateURLService* service = | |
| 243 TemplateURLServiceFactory::GetForProfile(profile); | |
| 244 DCHECK(service); | |
| 245 TemplateURL* dse = service->GetDefaultSearchProvider(); | |
| 246 if (dse) { | |
| 247 AddPair(list, | |
| 248 l10n_util::GetStringUTF16(IDS_RESET_PROFILE_SETTINGS_DSE), | |
| 249 ASCIIToUTF16(TemplateURLService::GenerateSearchURL(dse).host())); | |
| 250 } | |
| 251 | |
| 252 const ResettableSettingsSnapshot::ExtensionList& extensions = | |
| 253 snapshot.enabled_extensions(); | |
| 254 std::string extension_ids; | |
| 255 for (ResettableSettingsSnapshot::ExtensionList::const_iterator i = | |
| 256 extensions.begin(); i != extensions.end(); ++i) { | |
| 257 (extension_ids += i->second) += '\n'; | |
| 258 } | |
| 259 if (!extension_ids.empty()) { | |
| 260 extension_ids.erase(extension_ids.end() - 1); | |
|
battre
2013/09/12 14:03:14
do you want to do that for startup_urls as well?
vasilii
2013/09/16 13:58:02
Done.
| |
| 261 AddPair(list, | |
| 262 l10n_util::GetStringUTF16(IDS_RESET_PROFILE_SETTINGS_EXTENSIONS), | |
| 263 ASCIIToUTF16(extension_ids)); | |
| 264 } | |
| 265 return list; | |
| 266 } | |
| OLD | NEW |