// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_SEARCH_ENGINES_DEFAULT_SEARCH_MANAGER_H_
#define COMPONENTS_SEARCH_ENGINES_DEFAULT_SEARCH_MANAGER_H_
#include "base/callback.h"
#include "base/macros.h"
#include "base/memory/scoped_ptr.h"
#include "base/prefs/pref_change_registrar.h"
namespace base {
class DictionaryValue;
}
namespace user_prefs {
class PrefRegistrySyncable;
}
class PrefService;
class PrefValueMap;
struct TemplateURLData;
// DefaultSearchManager handles the loading and writing of the user's default
// search engine selection to and from prefs.
class DefaultSearchManager {
public:
static const char kDefaultSearchProviderDataPrefName[];
static const char kID[];
static const char kShortName[];
static const char kKeyword[];
static const char kPrepopulateID[];
static const char kSyncGUID[];
static const char kURL[];
static const char kSuggestionsURL[];
static const char kInstantURL[];
static const char kImageURL[];
static const char kNewTabURL[];
static const char kFaviconURL[];
static const char kOriginatingURL[];
static const char kSearchURLPostParams[];
static const char kSuggestionsURLPostParams[];
static const char kInstantURLPostParams[];
static const char kImageURLPostParams[];
static const char kSafeForAutoReplace[];
static const char kInputEncodings[];
static const char kDateCreated[];
static const char kLastModified[];
static const char kUsageCount[];
static const char kAlternateURLs[];
static const char kSearchTermsReplacementKey[];
static const char kCreatedByPolicy[];
static const char kDisabledByPolicy[];
enum Source {
FROM_FALLBACK = 0,
FROM_USER,
FROM_EXTENSION,
FROM_POLICY,
};
typedef base::Callback<void(const TemplateURLData*, Source)> ObserverCallback;
DefaultSearchManager(PrefService* pref_service,
const ObserverCallback& change_observer);
~DefaultSearchManager();
// Register prefs needed for tracking the default search provider.
static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry);
// Save default search provider pref values into the map provided.
static void AddPrefValueToMap(base::DictionaryValue* value,
PrefValueMap* pref_value_map);
// Testing code can call this with |disabled| set to true to cause
// GetDefaultSearchEngine() to return NULL instead of
// |fallback_default_search_| in cases where the DSE source is FROM_FALLBACK.
static void SetFallbackSearchEnginesDisabledForTesting(bool disabled);
// Gets a pointer to the current Default Search Engine. If NULL, indicates
// that Default Search is explicitly disabled. |source|, if not NULL, will be
// filled in with the source of the result.
TemplateURLData* GetDefaultSearchEngine(Source* source) const;
// Gets the source of the current Default Search Engine value.
Source GetDefaultSearchEngineSource() const;
// Write default search provider data to |pref_service_|.
void SetUserSelectedDefaultSearchEngine(const TemplateURLData& data);
// Override the default search provider with an extension.
void SetExtensionControlledDefaultSearchEngine(const TemplateURLData& data);
// Clear the extension-provided default search engine. Does not explicitly
// disable Default Search. The new current default search engine will be
// defined by policy, extensions, or pre-populated data.
void ClearExtensionControlledDefaultSearchEngine();
// Clear the user's default search provider choice from |pref_service_|. Does
// not explicitly disable Default Search. The new default search
// engine will be defined by policy, extensions, or pre-populated data.
void ClearUserSelectedDefaultSearchEngine();
private:
// Handles changes to kDefaultSearchProviderData pref. This includes sync and
// policy changes. Calls LoadDefaultSearchEngineFromPrefs() and
// NotifyObserver() if the effective DSE might have changed.
void OnDefaultSearchPrefChanged();
// Handles changes to kSearchProviderOverrides pref. Calls
// LoadPrepopulatedDefaultSearch() and NotifyObserver() if the effective DSE
// might have changed.
void OnOverridesPrefChanged();
// Updates |prefs_default_search_| with values from its corresponding
// pre-populated search provider record, if any.
void MergePrefsDataWithPrepopulated();
// Reads default search provider data from |pref_service_|, updating
// |prefs_default_search_| and |default_search_controlled_by_policy_|.
// Invokes MergePrefsDataWithPrepopulated().
void LoadDefaultSearchEngineFromPrefs();
// Reads pre-populated search providers, which will be built-in or overridden
// by kSearchProviderOverrides. Updates |fallback_default_search_|. Invoke
// MergePrefsDataWithPrepopulated().
void LoadPrepopulatedDefaultSearch();
// Invokes |change_observer_| if it is not NULL.
void NotifyObserver();
PrefService* pref_service_;
const ObserverCallback change_observer_;
PrefChangeRegistrar pref_change_registrar_;
// Default search engine provided by pre-populated data or by the
// |kSearchProviderOverrides| pref. This will be used when no other default
// search engine has been selected.
scoped_ptr<TemplateURLData> fallback_default_search_;
// Default search engine provided by prefs (either user prefs or policy
// prefs). This will be null if no value was set in the pref store.
scoped_ptr<TemplateURLData> extension_default_search_;
// Default search engine provided by extension (usings Settings Override API).
// This will be null if there are no extensions installed which provide
// default search engines.
scoped_ptr<TemplateURLData> prefs_default_search_;
// True if the default search is currently enforced by policy.
bool default_search_controlled_by_policy_;
DISALLOW_COPY_AND_ASSIGN(DefaultSearchManager);
};
#endif // COMPONENTS_SEARCH_ENGINES_DEFAULT_SEARCH_MANAGER_H_