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

Side by Side Diff: chrome/browser/search_engines/default_search_manager.cc

Issue 229763005: Store default search provider data in dictionary pref. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Address comments Created 6 years, 8 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
(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 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698