Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "chrome/browser/search_engines/default_search_manager.h" | |
| 6 | |
| 7 #include <algorithm> | |
| 8 #include <utility> | |
| 9 | |
| 10 #include "base/compiler_specific.h" | |
| 11 #include "base/i18n/case_conversion.h" | |
| 12 #include "base/prefs/pref_service.h" | |
| 13 #include "base/stl_util.h" | |
| 14 #include "base/strings/string_number_conversions.h" | |
| 15 #include "base/strings/string_split.h" | |
| 16 #include "base/strings/string_util.h" | |
| 17 #include "base/strings/utf_string_conversions.h" | |
| 18 #include "base/time/time.h" | |
| 19 #include "chrome/browser/profiles/profile.h" | |
| 20 #include "chrome/browser/search_engines/template_url.h" | |
| 21 #include "chrome/browser/search_engines/template_url_service.h" | |
| 22 #include "chrome/browser/search_engines/util.h" | |
| 23 #include "chrome/common/pref_names.h" | |
| 24 #include "components/user_prefs/pref_registry_syncable.h" | |
| 25 | |
| 26 namespace { | |
| 27 | |
|
Peter Kasting
2014/04/23 23:36:30
Nit: If you're going to put a blank line here, put
Cait (Slow)
2014/04/24 14:53:39
Done.
| |
| 28 // A dictionary to hold all data related to the Default Search Engine. | |
| 29 // Eventually, this should replace all the data stored in the | |
| 30 // default_search_provider.* prefs. | |
| 31 const char kDefaultSearchProviderData[] = | |
| 32 "default_search_provider.template_url_data"; | |
| 33 } // namespace | |
| 34 | |
| 35 const char* DefaultSearchManager::kID = "id"; | |
| 36 const char* DefaultSearchManager::kShortName = "short_name"; | |
| 37 const char* DefaultSearchManager::kKeyword = "keyword"; | |
| 38 const char* DefaultSearchManager::kPrepopulateID = "prepopulate_id"; | |
| 39 const char* DefaultSearchManager::kSyncGUID = "synced_guid"; | |
| 40 | |
| 41 const char* DefaultSearchManager::kURL = "url"; | |
| 42 const char* DefaultSearchManager::kSuggestionsURL = "suggestions_url"; | |
| 43 const char* DefaultSearchManager::kInstantURL = "instant_url"; | |
| 44 const char* DefaultSearchManager::kImageURL = "image_url"; | |
| 45 const char* DefaultSearchManager::kNewTabURL = "new_tab_url"; | |
| 46 const char* DefaultSearchManager::kFaviconURL = "favicon_url"; | |
| 47 const char* DefaultSearchManager::kOriginatingURL = "originating_url"; | |
| 48 | |
| 49 const char* DefaultSearchManager::kSearchURLPostParams = | |
| 50 "search_url_post_params"; | |
| 51 const char* DefaultSearchManager::kSuggestionsURLPostParams = | |
| 52 "suggestions_url_post_params"; | |
| 53 const char* DefaultSearchManager::kInstantURLPostParams = | |
| 54 "instant_url_post_params"; | |
| 55 const char* DefaultSearchManager::kImageURLPostParams = "image_url_post_params"; | |
| 56 | |
| 57 const char* DefaultSearchManager::kSafeForAutoReplace = "safe_for_autoreplace"; | |
| 58 const char* DefaultSearchManager::kInputEncodings = "input_encodings"; | |
| 59 | |
| 60 const char* DefaultSearchManager::kDateCreated = "date_created"; | |
| 61 const char* DefaultSearchManager::kLastModified = "last_modified"; | |
| 62 | |
| 63 const char* DefaultSearchManager::kUsageCount = "usage_count"; | |
| 64 const char* DefaultSearchManager::kAlternateURLs = "alternate_urls"; | |
| 65 const char* DefaultSearchManager::kSearchTermsReplacementKey = | |
| 66 "search_terms_replacement_key"; | |
| 67 const char* DefaultSearchManager::kCreatedByPolicy = "created_by_policy"; | |
| 68 | |
| 69 DefaultSearchManager::DefaultSearchManager(PrefService* pref_service) | |
| 70 : pref_service_(pref_service) { | |
| 71 DCHECK(pref_service_); | |
| 72 } | |
| 73 | |
| 74 DefaultSearchManager::~DefaultSearchManager() { | |
| 75 } | |
| 76 | |
| 77 // static | |
| 78 void DefaultSearchManager::RegisterProfilePrefs( | |
| 79 user_prefs::PrefRegistrySyncable* registry) { | |
| 80 registry->RegisterDictionaryPref( | |
| 81 kDefaultSearchProviderData, | |
| 82 user_prefs::PrefRegistrySyncable::UNSYNCABLE_PREF); | |
| 83 } | |
| 84 | |
| 85 bool DefaultSearchManager::GetDefaultSearchEngine(TemplateURLData* data) { | |
| 86 const base::DictionaryValue* url_dict = | |
| 87 pref_service_->GetDictionary(kDefaultSearchProviderData); | |
| 88 | |
| 89 if (url_dict->empty()) | |
| 90 return false; | |
| 91 | |
| 92 std::string search_url; | |
| 93 base::string16 keyword; | |
| 94 url_dict->GetString(kURL, &search_url); | |
| 95 url_dict->GetString(kKeyword, &keyword); | |
| 96 DCHECK(!search_url.empty()); | |
| 97 DCHECK(!keyword.empty()); | |
| 98 | |
| 99 if (search_url.empty()) | |
|
Peter Kasting
2014/04/23 23:36:30
Don't handle DCHECK failure. Either these can nev
Cait (Slow)
2014/04/24 14:53:39
Done.
gab
2014/04/24 15:00:44
While I agree that DCHECKs shouldn't be used for t
Peter Kasting
2014/04/24 20:48:46
Then you must not have DCHECKs.
DCHECKs say that
| |
| 100 return false; | |
| 101 if (keyword.empty()) | |
| 102 keyword = TemplateURLService::GenerateKeyword(GURL(search_url)); | |
| 103 data->SetKeyword(keyword); | |
| 104 data->SetURL(search_url); | |
| 105 | |
| 106 std::string id; | |
| 107 url_dict->GetString(kID, &id); | |
| 108 base::StringToInt64(id, &data->id); | |
| 109 url_dict->GetString(kShortName, &data->short_name); | |
| 110 url_dict->GetInteger(kPrepopulateID, &data->prepopulate_id); | |
| 111 url_dict->GetString(kSyncGUID, &data->sync_guid); | |
| 112 | |
| 113 url_dict->GetString(kSuggestionsURL, &data->suggestions_url); | |
| 114 url_dict->GetString(kInstantURL, &data->instant_url); | |
| 115 url_dict->GetString(kImageURL, &data->image_url); | |
| 116 url_dict->GetString(kNewTabURL, &data->new_tab_url); | |
| 117 | |
| 118 std::string favicon_url; | |
| 119 std::string originating_url; | |
| 120 url_dict->GetString(kFaviconURL, &favicon_url); | |
| 121 url_dict->GetString(kOriginatingURL, &originating_url); | |
| 122 data->favicon_url = GURL(favicon_url); | |
| 123 data->originating_url = GURL(originating_url); | |
| 124 | |
| 125 url_dict->GetString(kSearchURLPostParams, &data->search_url_post_params); | |
| 126 url_dict->GetString(kSuggestionsURLPostParams, | |
| 127 &data->suggestions_url_post_params); | |
| 128 url_dict->GetString(kInstantURLPostParams, &data->instant_url_post_params); | |
| 129 url_dict->GetString(kImageURLPostParams, &data->image_url_post_params); | |
| 130 | |
| 131 url_dict->GetBoolean(kSafeForAutoReplace, &data->safe_for_autoreplace); | |
| 132 | |
| 133 double date_created = 0.0; | |
| 134 double last_modified = 0.0; | |
| 135 url_dict->GetDouble(kDateCreated, &date_created); | |
| 136 url_dict->GetDouble(kLastModified, &last_modified); | |
| 137 data->date_created = base::Time::FromInternalValue(date_created); | |
| 138 data->last_modified = base::Time::FromInternalValue(last_modified); | |
| 139 | |
| 140 url_dict->GetInteger(kUsageCount, &data->usage_count); | |
| 141 | |
| 142 const base::ListValue* alternate_urls = new base::ListValue; | |
| 143 url_dict->GetList(kAlternateURLs, &alternate_urls); | |
| 144 data->alternate_urls.clear(); | |
| 145 for (base::ListValue::const_iterator it = alternate_urls->begin(); | |
| 146 it != alternate_urls->end(); | |
| 147 ++it) { | |
|
Peter Kasting
2014/04/23 23:36:30
Nit: It's legal either way, but personally I'd put
Cait (Slow)
2014/04/24 14:53:39
Done.
gab
2014/04/24 15:00:44
I agree, but this is the format `git cl format` ou
Peter Kasting
2014/04/24 20:48:46
There's an easy answer to that: Never run git cl f
gab
2014/04/25 11:23:42
Hmmm... Then what's the point of it..? IMO it shou
Peter Kasting
2014/04/25 17:52:13
See many chromium-dev debate threads about this is
| |
| 148 std::string alternate_url; | |
| 149 if ((*it)->GetAsString(&alternate_url)) | |
| 150 data->alternate_urls.push_back(alternate_url); | |
| 151 } | |
| 152 | |
| 153 const base::ListValue* encodings = new base::ListValue; | |
| 154 url_dict->GetList(kInputEncodings, &encodings); | |
| 155 data->input_encodings.clear(); | |
| 156 for (base::ListValue::const_iterator it = encodings->begin(); | |
| 157 it != encodings->end(); | |
| 158 ++it) { | |
| 159 std::string encoding; | |
| 160 if ((*it)->GetAsString(&encoding)) | |
| 161 data->input_encodings.push_back(encoding); | |
| 162 } | |
| 163 | |
| 164 url_dict->GetString(kSearchTermsReplacementKey, | |
| 165 &data->search_terms_replacement_key); | |
| 166 | |
| 167 url_dict->GetBoolean(kCreatedByPolicy, &data->created_by_policy); | |
| 168 | |
| 169 data->show_in_default_list = true; | |
| 170 | |
| 171 return true; | |
| 172 } | |
| 173 | |
| 174 void DefaultSearchManager::SetUserSelectedDefaultSearchEngine( | |
| 175 const TemplateURLData& data) { | |
| 176 base::DictionaryValue* url_dict = new base::DictionaryValue; | |
| 177 url_dict->SetString(kID, base::Int64ToString(data.id)); | |
| 178 url_dict->SetString(kShortName, data.short_name); | |
| 179 url_dict->SetString(kKeyword, data.keyword()); | |
| 180 url_dict->SetInteger(kPrepopulateID, data.prepopulate_id); | |
| 181 url_dict->SetString(kSyncGUID, data.sync_guid); | |
| 182 | |
| 183 url_dict->SetString(kURL, data.url()); | |
| 184 url_dict->SetString(kSuggestionsURL, data.suggestions_url); | |
| 185 url_dict->SetString(kInstantURL, data.instant_url); | |
| 186 url_dict->SetString(kImageURL, data.image_url); | |
| 187 url_dict->SetString(kNewTabURL, data.new_tab_url); | |
| 188 url_dict->SetString(kFaviconURL, data.favicon_url.spec()); | |
| 189 url_dict->SetString(kOriginatingURL, data.originating_url.spec()); | |
| 190 | |
| 191 url_dict->SetString(kSearchURLPostParams, data.search_url_post_params); | |
| 192 url_dict->SetString(kSuggestionsURLPostParams, | |
| 193 data.suggestions_url_post_params); | |
| 194 url_dict->SetString(kInstantURLPostParams, data.instant_url_post_params); | |
| 195 url_dict->SetString(kImageURLPostParams, data.image_url_post_params); | |
| 196 | |
| 197 url_dict->SetBoolean(kSafeForAutoReplace, data.safe_for_autoreplace); | |
| 198 | |
| 199 url_dict->SetDouble(kDateCreated, data.date_created.ToInternalValue()); | |
| 200 url_dict->SetDouble(kLastModified, data.last_modified.ToInternalValue()); | |
| 201 url_dict->SetInteger(kUsageCount, data.usage_count); | |
| 202 | |
| 203 base::ListValue* alternate_urls = new base::ListValue; | |
| 204 std::vector<std::string>::const_iterator it = data.alternate_urls.begin(); | |
|
Peter Kasting
2014/04/23 23:36:30
Nit: Scope loop variables like this to the loop bo
Cait (Slow)
2014/04/24 14:53:39
Done.
| |
| 205 for (; it != data.alternate_urls.end(); ++it) | |
| 206 alternate_urls->AppendString(*it); | |
| 207 url_dict->Set(kAlternateURLs, alternate_urls); | |
| 208 | |
| 209 base::ListValue* encodings = new base::ListValue; | |
| 210 it = data.input_encodings.begin(); | |
| 211 for (; it != data.input_encodings.end(); ++it) | |
| 212 encodings->AppendString(*it); | |
| 213 url_dict->Set(kInputEncodings, encodings); | |
| 214 | |
| 215 url_dict->SetString(kSearchTermsReplacementKey, | |
| 216 data.search_terms_replacement_key); | |
| 217 | |
| 218 url_dict->SetBoolean(kCreatedByPolicy, data.created_by_policy); | |
| 219 | |
| 220 pref_service_->Set(kDefaultSearchProviderData, *url_dict); | |
| 221 } | |
| OLD | NEW |