Index: chrome/browser/search_engines/default_search_manager.cc |
diff --git a/chrome/browser/search_engines/default_search_manager.cc b/chrome/browser/search_engines/default_search_manager.cc |
index d905a42d293f81e54889dfffe0a638b8e007438f..6566b3b7ebfcb286989edf6f71f84dc2ca4458b3 100644 |
--- a/chrome/browser/search_engines/default_search_manager.cc |
+++ b/chrome/browser/search_engines/default_search_manager.cc |
@@ -30,14 +30,21 @@ |
namespace { |
+bool IsDefaultSearchProviderManaged(PrefService* pref_service) { |
+ const PrefService::Preference* pref = pref_service->FindPreference( |
+ DefaultSearchManager::kDefaultSearchProviderDataPrefName); |
+ DCHECK(pref); |
+ return pref->IsManaged(); |
+} |
+ |
+} // namespace |
+ |
// A dictionary to hold all data related to the Default Search Engine. |
// Eventually, this should replace all the data stored in the |
// default_search_provider.* prefs. |
-const char kDefaultSearchProviderData[] = |
+const char DefaultSearchManager::kDefaultSearchProviderDataPrefName[] = |
"default_search_provider_data.template_url_data"; |
-} // namespace |
- |
const char DefaultSearchManager::kID[] = "id"; |
const char DefaultSearchManager::kShortName[] = "short_name"; |
const char DefaultSearchManager::kKeyword[] = "keyword"; |
@@ -74,20 +81,25 @@ const char DefaultSearchManager::kSearchTermsReplacementKey[] = |
const char DefaultSearchManager::kCreatedByPolicy[] = "created_by_policy"; |
const char DefaultSearchManager::kDisabledByPolicy[] = "disabled_by_policy"; |
-DefaultSearchManager::DefaultSearchManager(PrefService* pref_service) |
- : pref_service_(pref_service), default_search_controlled_by_policy_(false) { |
- DCHECK(pref_service_); |
- pref_change_registrar_.Init(pref_service_); |
- pref_change_registrar_.Add( |
- kDefaultSearchProviderData, |
- base::Bind(&DefaultSearchManager::OnDefaultSearchPrefChanged, |
- base::Unretained(this))); |
- pref_change_registrar_.Add( |
- prefs::kSearchProviderOverrides, |
- base::Bind(&DefaultSearchManager::OnOverridesPrefChanged, |
- base::Unretained(this))); |
- OnDefaultSearchPrefChanged(); |
- OnOverridesPrefChanged(); |
+DefaultSearchManager::DefaultSearchManager( |
+ PrefService* pref_service, |
+ const ObserverCallback& change_observer) |
+ : pref_service_(pref_service), |
+ change_observer_(change_observer), |
+ default_search_controlled_by_policy_(false) { |
+ if (pref_service_) { |
+ pref_change_registrar_.Init(pref_service_); |
+ pref_change_registrar_.Add( |
+ kDefaultSearchProviderDataPrefName, |
+ base::Bind(&DefaultSearchManager::OnDefaultSearchPrefChanged, |
+ base::Unretained(this))); |
+ pref_change_registrar_.Add( |
+ prefs::kSearchProviderOverrides, |
+ base::Bind(&DefaultSearchManager::OnOverridesPrefChanged, |
+ base::Unretained(this))); |
+ } |
+ LoadPrepopulatedDefaultSearch(); |
+ LoadDefaultSearchEngineFromPrefs(); |
} |
DefaultSearchManager::~DefaultSearchManager() { |
@@ -97,41 +109,48 @@ DefaultSearchManager::~DefaultSearchManager() { |
void DefaultSearchManager::RegisterProfilePrefs( |
user_prefs::PrefRegistrySyncable* registry) { |
registry->RegisterDictionaryPref( |
- kDefaultSearchProviderData, |
- user_prefs::PrefRegistrySyncable::UNSYNCABLE_PREF); |
+ kDefaultSearchProviderDataPrefName, |
+ user_prefs::PrefRegistrySyncable::SYNCABLE_PREF); |
} |
// static |
void DefaultSearchManager::AddPrefValueToMap(base::DictionaryValue* value, |
PrefValueMap* pref_value_map) { |
- pref_value_map->SetValue(kDefaultSearchProviderData, value); |
-} |
- |
-DefaultSearchManager::Source |
-DefaultSearchManager::GetDefaultSearchEngineSource() const { |
- if (default_search_controlled_by_policy_) |
- return FROM_POLICY; |
- if (extension_default_search_) |
- return FROM_EXTENSION; |
- if (prefs_default_search_) |
- return FROM_USER; |
- |
- return FROM_FALLBACK; |
+ pref_value_map->SetValue(kDefaultSearchProviderDataPrefName, value); |
} |
-TemplateURLData* DefaultSearchManager::GetDefaultSearchEngine() const { |
- if (default_search_controlled_by_policy_) |
+TemplateURLData* DefaultSearchManager::GetDefaultSearchEngine( |
Peter Kasting
2014/05/03 00:28:18
Given the number of times you call this just to ge
erikwright (departed)
2014/05/05 01:49:38
It makes sense to have a single function calculate
|
+ Source* source) const { |
+ if (default_search_controlled_by_policy_) { |
+ if (source) |
+ *source = FROM_POLICY; |
return prefs_default_search_.get(); |
- if (extension_default_search_) |
+ } |
+ if (extension_default_search_) { |
+ if (source) |
+ *source = FROM_EXTENSION; |
return extension_default_search_.get(); |
- if (prefs_default_search_) |
+ } |
+ if (prefs_default_search_) { |
+ if (source) |
+ *source = FROM_USER; |
return prefs_default_search_.get(); |
+ } |
+ if (source) |
+ *source = FROM_FALLBACK; |
return fallback_default_search_.get(); |
} |
void DefaultSearchManager::SetUserSelectedDefaultSearchEngine( |
const TemplateURLData& data) { |
+ if (!pref_service_) { |
+ prefs_default_search_.reset(new TemplateURLData(data)); |
+ MergePrefsDataWithPrepopulated(); |
+ NotifyObserver(); |
+ return; |
+ } |
+ |
base::DictionaryValue url_dict; |
url_dict.SetString(kID, base::Int64ToString(data.id)); |
url_dict.SetString(kShortName, data.short_name); |
@@ -162,8 +181,7 @@ void DefaultSearchManager::SetUserSelectedDefaultSearchEngine( |
scoped_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) { |
+ it != data.alternate_urls.end(); ++it) { |
alternate_urls->AppendString(*it); |
} |
url_dict.Set(kAlternateURLs, alternate_urls.release()); |
@@ -171,8 +189,7 @@ void DefaultSearchManager::SetUserSelectedDefaultSearchEngine( |
scoped_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) { |
+ it != data.input_encodings.end(); ++it) { |
encodings->AppendString(*it); |
} |
url_dict.Set(kInputEncodings, encodings.release()); |
@@ -182,44 +199,60 @@ void DefaultSearchManager::SetUserSelectedDefaultSearchEngine( |
url_dict.SetBoolean(kCreatedByPolicy, data.created_by_policy); |
- pref_service_->Set(kDefaultSearchProviderData, url_dict); |
+ pref_service_->Set(kDefaultSearchProviderDataPrefName, url_dict); |
} |
void DefaultSearchManager::SetExtensionControlledDefaultSearchEngine( |
TemplateURLData* data) { |
+ DCHECK(data); |
+ Source old_source = FROM_FALLBACK; |
Peter Kasting
2014/05/03 00:28:18
Nit: I think initting this before the call, when t
erikwright (departed)
2014/05/05 01:49:38
Done.
|
+ GetDefaultSearchEngine(&old_source); |
extension_default_search_.reset(data); |
+ if (old_source <= FROM_EXTENSION) |
Peter Kasting
2014/05/03 00:28:18
This implies that the Source values are in sorted
erikwright (departed)
2014/05/05 01:49:38
Done.
|
+ NotifyObserver(); |
} |
void DefaultSearchManager::ClearExtensionControlledDefaultSearchEngine() { |
+ Source old_source = FROM_FALLBACK; |
+ GetDefaultSearchEngine(&old_source); |
extension_default_search_.reset(); |
+ if (old_source == FROM_EXTENSION) |
+ NotifyObserver(); |
} |
void DefaultSearchManager::ClearUserSelectedDefaultSearchEngine() { |
- pref_service_->ClearPref(kDefaultSearchProviderData); |
+ if (pref_service_) { |
+ pref_service_->ClearPref(kDefaultSearchProviderDataPrefName); |
+ } else { |
+ prefs_default_search_.reset(); |
+ NotifyObserver(); |
+ } |
} |
void DefaultSearchManager::OnDefaultSearchPrefChanged() { |
- TemplateURLData* data; |
- if (ReadDefaultSearchEngineFromPrefs(&data)) { |
- prefs_default_search_.reset(data); |
- MergePrefsDataWithPrepopulated(); |
+ Source old_source = FROM_FALLBACK; |
+ GetDefaultSearchEngine(&old_source); |
+ LoadDefaultSearchEngineFromPrefs(); |
+ |
+ if (old_source == FROM_USER || old_source == FROM_POLICY) { |
+ NotifyObserver(); |
} else { |
- prefs_default_search_.reset(); |
+ Source new_source = FROM_FALLBACK; |
+ GetDefaultSearchEngine(&new_source); |
+ if (new_source == FROM_USER || new_source == FROM_POLICY) |
+ NotifyObserver(); |
} |
Peter Kasting
2014/05/03 00:28:18
Nit: Simpler:
Source source;
GetDefaultSearch
erikwright (departed)
2014/05/05 01:49:38
Done.
|
- UpdatePolicyStatus(); |
} |
void DefaultSearchManager::OnOverridesPrefChanged() { |
- scoped_ptr<TemplateURLData> data = |
- TemplateURLPrepopulateData::GetPrepopulatedDefaultSearch(pref_service_); |
- fallback_default_search_ = data.Pass(); |
- MergePrefsDataWithPrepopulated(); |
-} |
+ LoadPrepopulatedDefaultSearch(); |
-void DefaultSearchManager::UpdatePolicyStatus() { |
- const PrefService::Preference* pref = |
- pref_service_->FindPreference(kDefaultSearchProviderData); |
- default_search_controlled_by_policy_ = pref && pref->IsManaged(); |
+ TemplateURLData* effective_data = GetDefaultSearchEngine(NULL); |
+ if (effective_data && effective_data->prepopulate_id) { |
+ // A user-selected, policy-selected or fallback pre-populated engine is |
+ // active and may have changed with this event. |
+ NotifyObserver(); |
+ } |
} |
void DefaultSearchManager::MergePrefsDataWithPrepopulated() { |
@@ -228,8 +261,8 @@ void DefaultSearchManager::MergePrefsDataWithPrepopulated() { |
size_t default_search_index; |
ScopedVector<TemplateURLData> prepopulated_urls = |
- TemplateURLPrepopulateData::GetPrepopulatedEngines(pref_service_, |
- &default_search_index); |
+ TemplateURLPrepopulateData::GetPrepopulatedEngines( |
+ pref_service_, &default_search_index); |
Peter Kasting
2014/05/03 00:28:18
Nit: Indenting is wrong (3 instead of 4) -- I woul
erikwright (departed)
2014/05/05 01:49:38
Done.
|
for (size_t i = 0; i < prepopulated_urls.size(); ++i) { |
if (prepopulated_urls[i]->prepopulate_id == |
@@ -245,101 +278,128 @@ void DefaultSearchManager::MergePrefsDataWithPrepopulated() { |
prepopulated_urls[i]->last_modified = |
prefs_default_search_->last_modified; |
prefs_default_search_.reset(prepopulated_urls[i]); |
- prepopulated_urls.weak_erase(prepopulated_urls.begin() + i); |
Peter Kasting
2014/05/03 00:28:18
Doesn't removing this line result in the URL being
|
return; |
} |
} |
} |
-bool DefaultSearchManager::ReadDefaultSearchEngineFromPrefs( |
- TemplateURLData** dse_data) { |
- const base::DictionaryValue* url_dict = |
- pref_service_->GetDictionary(kDefaultSearchProviderData); |
+void DefaultSearchManager::LoadDefaultSearchEngineFromPrefs() { |
+ if (!pref_service_) |
+ return; |
+ prefs_default_search_.reset(); |
+ default_search_controlled_by_policy_ = |
+ IsDefaultSearchProviderManaged(pref_service_); |
+ |
+ const base::DictionaryValue* url_dict = |
+ pref_service_->GetDictionary(kDefaultSearchProviderDataPrefName); |
if (url_dict->empty()) |
- return false; |
+ return; |
- bool disabled_by_policy = false; |
- if (url_dict->GetBoolean(kDisabledByPolicy, &disabled_by_policy) && |
- disabled_by_policy) { |
- *dse_data = NULL; |
- return true; |
+ if (default_search_controlled_by_policy_) { |
+ bool disabled_by_policy = false; |
+ if (url_dict->GetBoolean(kDisabledByPolicy, &disabled_by_policy) && |
+ disabled_by_policy) { |
Peter Kasting
2014/05/03 00:28:18
Nit: No {}
erikwright (departed)
2014/05/05 01:49:38
Done.
|
+ return; |
+ } |
} |
- TemplateURLData* data = new TemplateURLData(); |
std::string search_url; |
base::string16 keyword; |
url_dict->GetString(kURL, &search_url); |
url_dict->GetString(kKeyword, &keyword); |
- if (search_url.empty()) |
- return false; |
- if (keyword.empty()) |
- keyword = TemplateURLService::GenerateKeyword(GURL(search_url)); |
- data->SetKeyword(keyword); |
- data->SetURL(search_url); |
+ 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, &data->id); |
- url_dict->GetString(kShortName, &data->short_name); |
- url_dict->GetInteger(kPrepopulateID, &data->prepopulate_id); |
- url_dict->GetString(kSyncGUID, &data->sync_guid); |
+ base::StringToInt64(id, &prefs_default_search_->id); |
+ url_dict->GetString(kShortName, &prefs_default_search_->short_name); |
+ url_dict->GetInteger(kPrepopulateID, &prefs_default_search_->prepopulate_id); |
+ url_dict->GetString(kSyncGUID, &prefs_default_search_->sync_guid); |
- url_dict->GetString(kSuggestionsURL, &data->suggestions_url); |
- url_dict->GetString(kInstantURL, &data->instant_url); |
- url_dict->GetString(kImageURL, &data->image_url); |
- url_dict->GetString(kNewTabURL, &data->new_tab_url); |
+ 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); |
- data->favicon_url = GURL(favicon_url); |
- data->originating_url = GURL(originating_url); |
+ prefs_default_search_->favicon_url = GURL(favicon_url); |
+ prefs_default_search_->originating_url = GURL(originating_url); |
- url_dict->GetString(kSearchURLPostParams, &data->search_url_post_params); |
+ url_dict->GetString(kSearchURLPostParams, |
+ &prefs_default_search_->search_url_post_params); |
url_dict->GetString(kSuggestionsURLPostParams, |
- &data->suggestions_url_post_params); |
- url_dict->GetString(kInstantURLPostParams, &data->instant_url_post_params); |
- url_dict->GetString(kImageURLPostParams, &data->image_url_post_params); |
+ &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, &data->safe_for_autoreplace); |
+ url_dict->GetBoolean(kSafeForAutoReplace, |
+ &prefs_default_search_->safe_for_autoreplace); |
double date_created = 0.0; |
double last_modified = 0.0; |
url_dict->GetDouble(kDateCreated, &date_created); |
url_dict->GetDouble(kLastModified, &last_modified); |
- data->date_created = base::Time::FromInternalValue(date_created); |
- data->last_modified = base::Time::FromInternalValue(last_modified); |
- |
- url_dict->GetInteger(kUsageCount, &data->usage_count); |
- |
- const base::ListValue* alternate_urls; |
- url_dict->GetList(kAlternateURLs, &alternate_urls); |
- data->alternate_urls.clear(); |
- for (base::ListValue::const_iterator it = alternate_urls->begin(); |
- it != alternate_urls->end(); ++it) { |
- std::string alternate_url; |
- if ((*it)->GetAsString(&alternate_url)) |
- data->alternate_urls.push_back(alternate_url); |
+ prefs_default_search_->date_created = |
+ base::Time::FromInternalValue(date_created); |
+ 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; |
- url_dict->GetList(kInputEncodings, &encodings); |
- data->input_encodings.clear(); |
- for (base::ListValue::const_iterator it = encodings->begin(); |
- it != encodings->end(); ++it) { |
- std::string encoding; |
- if ((*it)->GetAsString(&encoding)) |
- data->input_encodings.push_back(encoding); |
+ 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); |
+ } |
} |
url_dict->GetString(kSearchTermsReplacementKey, |
- &data->search_terms_replacement_key); |
+ &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(); |
+} |
- url_dict->GetBoolean(kCreatedByPolicy, &data->created_by_policy); |
+void DefaultSearchManager::LoadPrepopulatedDefaultSearch() { |
+ scoped_ptr<TemplateURLData> data = |
+ TemplateURLPrepopulateData::GetPrepopulatedDefaultSearch(pref_service_); |
+ fallback_default_search_ = data.Pass(); |
+ MergePrefsDataWithPrepopulated(); |
+} |
- data->show_in_default_list = true; |
- *dse_data = data; |
- return true; |
+void DefaultSearchManager::NotifyObserver() { |
+ if (!change_observer_.is_null()) { |
+ Source source = FROM_FALLBACK; |
+ TemplateURLData* data = GetDefaultSearchEngine(&source); |
+ change_observer_.Run(data, source); |
+ } |
} |