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() { |