// Copyright (c) 2010 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 CHROME_BROWSER_EXTENSIONS_EXTENSION_PREF_STORE_H_ #define CHROME_BROWSER_EXTENSIONS_EXTENSION_PREF_STORE_H_ #include #include #include #include #include "base/basictypes.h" #include "base/scoped_ptr.h" #include "chrome/common/pref_store.h" class DictionaryValue; class PrefService; class Value; // This PrefStore keeps track of preferences set by extensions: for example, // proxy settings. A stack of relevant extension IDs is stored in order of // their addition to this PrefStore. For each preference, the last-added // enabled extension that tries to set it overrules any others. class ExtensionPrefStore : public PrefStore { public: explicit ExtensionPrefStore(PrefService* pref_service); virtual ~ExtensionPrefStore(); // The PrefService creates the ExtensionPrefStore, so we need to be able to // defer setting the PrefService here until after construction. void SetPrefService(PrefService* pref_service) { pref_service_ = pref_service; } // Begins tracking the preference and value an extension wishes to set. This // must be called each time an extension API tries to set a preference. virtual void InstallExtensionPref(std::string extension_id, const wchar_t* pref_path, Value* pref_value); // Removes an extension and all its preference settings from this PrefStore. // This must be called when an extension is uninstalled or disabled. virtual void UninstallExtension(std::string extension_id); // PrefStore methods: virtual DictionaryValue* prefs() { return prefs_.get(); } virtual PrefReadError ReadPrefs() { return PREF_READ_ERROR_NONE; } protected: // Returns a vector of the extension IDs in the extension_stack_. // This should only be accessed by subclasses for unit-testing. void GetExtensionIDs(std::vector* result); private: // The pref service referring to this pref store. Weak reference. PrefService* pref_service_; // Maps preference paths to their values. typedef std::map PrefValueMap; // Applies the highest-priority extension's setting for the given preference // path, or clears the setting in this PrefStore if no extensions wish to // control it. void UpdateOnePref(const wchar_t* path); // Updates each preference in the |pref_values| list. void UpdatePrefs(const PrefValueMap* pref_values); // A cache of the highest-priority values for each preference that any // extension is controlling, for quick read access. Owns the stored values. scoped_ptr prefs_; // Associates an extension ID with the prefs it sets. struct ExtensionPrefs { std::string extension_id; PrefValueMap* pref_values; }; // A pseudo-stack of extensions and their preferences. Extensions are always // added to the head, but may be removed from the middle. This stack owns // the values in the extensions' PrefValueMaps. typedef std::list ExtensionStack; ExtensionStack extension_stack_; DISALLOW_COPY_AND_ASSIGN(ExtensionPrefStore); }; #endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_PREF_STORE_H_