Chromium Code Reviews| Index: components/search_engines/default_search_manager.cc |
| diff --git a/components/search_engines/default_search_manager.cc b/components/search_engines/default_search_manager.cc |
| index 42b29d29ee731949ac0926c25b1120715a8c5980..a73f0dc8c755cea3d4071deeefa4d4641fb2fc3c 100644 |
| --- a/components/search_engines/default_search_manager.cc |
| +++ b/components/search_engines/default_search_manager.cc |
| @@ -15,7 +15,6 @@ |
| #include "base/compiler_specific.h" |
| #include "base/i18n/case_conversion.h" |
| #include "base/logging.h" |
| -#include "base/strings/string_number_conversions.h" |
| #include "base/strings/string_split.h" |
| #include "base/strings/string_util.h" |
| #include "base/strings/utf_string_conversions.h" |
| @@ -26,6 +25,7 @@ |
| #include "components/search_engines/search_engines_pref_names.h" |
| #include "components/search_engines/template_url_data.h" |
| #include "components/search_engines/template_url_prepopulate_data.h" |
| +#include "components/search_engines/util.h" |
| namespace { |
| @@ -159,71 +159,9 @@ void DefaultSearchManager::SetUserSelectedDefaultSearchEngine( |
| return; |
| } |
| - base::DictionaryValue url_dict; |
| - url_dict.SetString(kID, base::Int64ToString(data.id)); |
| - url_dict.SetString(kShortName, data.short_name()); |
| - url_dict.SetString(kKeyword, data.keyword()); |
| - url_dict.SetInteger(kPrepopulateID, data.prepopulate_id); |
| - url_dict.SetString(kSyncGUID, data.sync_guid); |
| - |
| - url_dict.SetString(kURL, data.url()); |
| - url_dict.SetString(kSuggestionsURL, data.suggestions_url); |
| - url_dict.SetString(kInstantURL, data.instant_url); |
| - url_dict.SetString(kImageURL, data.image_url); |
| - url_dict.SetString(kNewTabURL, data.new_tab_url); |
| - url_dict.SetString(kFaviconURL, data.favicon_url.spec()); |
| - url_dict.SetString(kOriginatingURL, data.originating_url.spec()); |
| - |
| - url_dict.SetString(kSearchURLPostParams, data.search_url_post_params); |
| - url_dict.SetString(kSuggestionsURLPostParams, |
| - data.suggestions_url_post_params); |
| - url_dict.SetString(kInstantURLPostParams, data.instant_url_post_params); |
| - url_dict.SetString(kImageURLPostParams, data.image_url_post_params); |
| - |
| - url_dict.SetBoolean(kSafeForAutoReplace, data.safe_for_autoreplace); |
| - |
| - url_dict.SetString(kDateCreated, |
| - base::Int64ToString(data.date_created.ToInternalValue())); |
| - url_dict.SetString(kLastModified, |
| - base::Int64ToString(data.last_modified.ToInternalValue())); |
| - url_dict.SetInteger(kUsageCount, data.usage_count); |
| - |
| - std::unique_ptr<base::ListValue> alternate_urls(new base::ListValue); |
| - for (std::vector<std::string>::const_iterator it = |
| - data.alternate_urls.begin(); |
| - it != data.alternate_urls.end(); ++it) { |
| - alternate_urls->AppendString(*it); |
| - } |
| - url_dict.Set(kAlternateURLs, alternate_urls.release()); |
| - |
| - std::unique_ptr<base::ListValue> encodings(new base::ListValue); |
| - for (std::vector<std::string>::const_iterator it = |
| - data.input_encodings.begin(); |
| - it != data.input_encodings.end(); ++it) { |
| - encodings->AppendString(*it); |
| - } |
| - url_dict.Set(kInputEncodings, encodings.release()); |
| - |
| - url_dict.SetString(kSearchTermsReplacementKey, |
| - data.search_terms_replacement_key); |
| - |
| - url_dict.SetBoolean(kCreatedByPolicy, data.created_by_policy); |
| - |
| - pref_service_->Set(kDefaultSearchProviderDataPrefName, url_dict); |
| -} |
| - |
| -void DefaultSearchManager::SetExtensionControlledDefaultSearchEngine( |
| - const TemplateURLData& data) { |
| - extension_default_search_.reset(new TemplateURLData(data)); |
| - if (GetDefaultSearchEngineSource() == FROM_EXTENSION) |
| - NotifyObserver(); |
| -} |
| - |
| -void DefaultSearchManager::ClearExtensionControlledDefaultSearchEngine() { |
| - Source old_source = GetDefaultSearchEngineSource(); |
| - extension_default_search_.reset(); |
| - if (old_source == FROM_EXTENSION) |
| - NotifyObserver(); |
| + std::unique_ptr<base::Value> url_dict(TemplateUrlDataToDictionary(data)); |
| + DCHECK(url_dict); |
| + pref_service_->Set(kDefaultSearchProviderDataPrefName, *url_dict); |
| } |
| void DefaultSearchManager::ClearUserSelectedDefaultSearchEngine() { |
| @@ -239,11 +177,11 @@ void DefaultSearchManager::OnDefaultSearchPrefChanged() { |
| Source source = GetDefaultSearchEngineSource(); |
| LoadDefaultSearchEngineFromPrefs(); |
| - // If we were/are FROM_USER or FROM_POLICY the effective DSE may have changed. |
| - if (source != FROM_USER && source != FROM_POLICY) |
| + if (source == FROM_FALLBACK) |
| source = GetDefaultSearchEngineSource(); |
| - if (source == FROM_USER || source == FROM_POLICY) |
| - NotifyObserver(); |
| + // The effective DSE may have changed if it was/become non fallback. |
| + if (source != FROM_FALLBACK) |
|
vasilii
2016/11/07 15:00:05
Why did the conditions here change?
Alexander Yashkin
2016/11/07 19:27:13
Previous check was to notify DefaultSearchManager
|
| + NotifyObserver(); |
| } |
| void DefaultSearchManager::OnOverridesPrefChanged() { |
| @@ -290,6 +228,7 @@ void DefaultSearchManager::LoadDefaultSearchEngineFromPrefs() { |
| return; |
| prefs_default_search_.reset(); |
| + extension_default_search_.reset(); |
| const PrefService::Preference* pref = |
| pref_service_->FindPreference(kDefaultSearchProviderDataPrefName); |
| DCHECK(pref); |
| @@ -314,92 +253,13 @@ void DefaultSearchManager::LoadDefaultSearchEngineFromPrefs() { |
| if (search_url.empty() || keyword.empty()) |
| return; |
| - prefs_default_search_.reset(new TemplateURLData); |
| - prefs_default_search_->SetKeyword(keyword); |
| - prefs_default_search_->SetURL(search_url); |
| - |
| - std::string id; |
| - url_dict->GetString(kID, &id); |
| - base::StringToInt64(id, &prefs_default_search_->id); |
| - base::string16 short_name; |
| - url_dict->GetString(kShortName, &short_name); |
| - prefs_default_search_->SetShortName(short_name); |
| - url_dict->GetInteger(kPrepopulateID, &prefs_default_search_->prepopulate_id); |
| - url_dict->GetString(kSyncGUID, &prefs_default_search_->sync_guid); |
| - |
| - url_dict->GetString(kSuggestionsURL, &prefs_default_search_->suggestions_url); |
| - url_dict->GetString(kInstantURL, &prefs_default_search_->instant_url); |
| - url_dict->GetString(kImageURL, &prefs_default_search_->image_url); |
| - url_dict->GetString(kNewTabURL, &prefs_default_search_->new_tab_url); |
| - |
| - std::string favicon_url; |
| - std::string originating_url; |
| - url_dict->GetString(kFaviconURL, &favicon_url); |
| - url_dict->GetString(kOriginatingURL, &originating_url); |
| - prefs_default_search_->favicon_url = GURL(favicon_url); |
| - prefs_default_search_->originating_url = GURL(originating_url); |
| - |
| - url_dict->GetString(kSearchURLPostParams, |
| - &prefs_default_search_->search_url_post_params); |
| - url_dict->GetString(kSuggestionsURLPostParams, |
| - &prefs_default_search_->suggestions_url_post_params); |
| - url_dict->GetString(kInstantURLPostParams, |
| - &prefs_default_search_->instant_url_post_params); |
| - url_dict->GetString(kImageURLPostParams, |
| - &prefs_default_search_->image_url_post_params); |
| - |
| - url_dict->GetBoolean(kSafeForAutoReplace, |
| - &prefs_default_search_->safe_for_autoreplace); |
| - |
| - std::string date_created_str; |
| - std::string last_modified_str; |
| - url_dict->GetString(kDateCreated, &date_created_str); |
| - url_dict->GetString(kLastModified, &last_modified_str); |
| - |
| - int64_t date_created = 0; |
| - if (base::StringToInt64(date_created_str, &date_created)) { |
| - prefs_default_search_->date_created = |
| - base::Time::FromInternalValue(date_created); |
| - } |
| - |
| - int64_t last_modified = 0; |
| - if (base::StringToInt64(date_created_str, &last_modified)) { |
| - prefs_default_search_->last_modified = |
| - base::Time::FromInternalValue(last_modified); |
| - } |
| - |
| - url_dict->GetInteger(kUsageCount, &prefs_default_search_->usage_count); |
| - |
| - const base::ListValue* alternate_urls = NULL; |
| - if (url_dict->GetList(kAlternateURLs, &alternate_urls)) { |
| - for (base::ListValue::const_iterator it = alternate_urls->begin(); |
| - it != alternate_urls->end(); |
| - ++it) { |
| - std::string alternate_url; |
| - if ((*it)->GetAsString(&alternate_url)) |
| - prefs_default_search_->alternate_urls.push_back(alternate_url); |
| - } |
| - } |
| - |
| - const base::ListValue* encodings = NULL; |
| - if (url_dict->GetList(kInputEncodings, &encodings)) { |
| - for (base::ListValue::const_iterator it = encodings->begin(); |
| - it != encodings->end(); |
| - ++it) { |
| - std::string encoding; |
| - if ((*it)->GetAsString(&encoding)) |
| - prefs_default_search_->input_encodings.push_back(encoding); |
| - } |
| + // Check if default search preference is overriden by extension. |
| + if (pref->IsExtensionControlled()) { |
| + extension_default_search_ = TemplateUrlDataFromDictionary(*url_dict); |
| + } else { |
| + prefs_default_search_ = TemplateUrlDataFromDictionary(*url_dict); |
| + MergePrefsDataWithPrepopulated(); |
| } |
| - |
| - url_dict->GetString(kSearchTermsReplacementKey, |
| - &prefs_default_search_->search_terms_replacement_key); |
| - |
| - url_dict->GetBoolean(kCreatedByPolicy, |
| - &prefs_default_search_->created_by_policy); |
| - |
| - prefs_default_search_->show_in_default_list = true; |
| - MergePrefsDataWithPrepopulated(); |
| } |
| void DefaultSearchManager::LoadPrepopulatedDefaultSearch() { |