Chromium Code Reviews| Index: chrome/browser/prefs/tracked/protected_pref_store.h |
| diff --git a/chrome/browser/prefs/tracked/protected_pref_store.h b/chrome/browser/prefs/tracked/protected_pref_store.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..d202edf586e5b8abfc6181cff0b0c8e5bad6f204 |
| --- /dev/null |
| +++ b/chrome/browser/prefs/tracked/protected_pref_store.h |
| @@ -0,0 +1,106 @@ |
| +// 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 CHROME_BROWSER_PREFS_TRACKED_PROTECTED_PREF_STORE_H_ |
| +#define CHROME_BROWSER_PREFS_TRACKED_PROTECTED_PREF_STORE_H_ |
| + |
| +#include <set> |
| +#include <vector> |
| + |
| +#include "base/callback.h" |
| +#include "base/compiler_specific.h" |
| +#include "base/macros.h" |
| +#include "base/observer_list.h" |
| +#include "base/prefs/persistent_pref_store.h" |
| +#include "base/strings/string_piece.h" |
| +#include "chrome/browser/prefs/pref_hash_filter.h" |
| + |
| +class PrefHashStore; |
| + |
| + |
| +// Provides a unified PersistentPrefStore implementation that splits its storage |
| +// and retrieval between two underlying PersistentPrefStore instances: one each |
| +// for protected and unprotected preferences. |
| +class ProtectedPrefStore : public PersistentPrefStore { |
| + public: |
| + // Creates an instance that delegates to |protected_pref_store| for the |
| + // preferences named in |protected_pref_names| and to |unprotected_pref_store| |
| + // for all others. If an unprotected preference is present in |
| + // |protected_pref_store| (i.e. because it was previously protected) it will |
| + // be migrated back to |unprotected_pref_store| upon access. |
| + // |on_initialization| will be invoked when both stores have been initialized, |
| + // before observers of the combined store are notified. |
| + ProtectedPrefStore( |
| + const scoped_refptr<PersistentPrefStore>& unprotected_pref_store, |
| + const scoped_refptr<PersistentPrefStore>& protected_pref_store, |
| + const std::set<std::string>& protected_pref_names, |
| + const base::Closure& on_initialization); |
| + |
| + // PrefStore implementation |
| + virtual void AddObserver(Observer* observer) OVERRIDE; |
| + virtual void RemoveObserver(Observer* observer) OVERRIDE; |
| + virtual bool HasObservers() const OVERRIDE; |
| + virtual bool IsInitializationComplete() const OVERRIDE; |
| + virtual bool GetValue(const std::string& key, |
| + const base::Value** result) const OVERRIDE; |
| + |
| + // WriteablePrefStore implementation |
| + virtual void SetValue(const std::string& key, base::Value* value) OVERRIDE; |
| + virtual void RemoveValue(const std::string& key) OVERRIDE; |
| + |
| + // PersistentPrefStore implementation |
| + virtual bool GetMutableValue(const std::string& key, |
| + base::Value** result) OVERRIDE; |
| + virtual void ReportValueChanged(const std::string& key) OVERRIDE; |
| + virtual void SetValueSilently(const std::string& key, |
| + base::Value* value) OVERRIDE; |
| + virtual bool ReadOnly() const OVERRIDE; |
| + virtual PrefReadError GetReadError() const OVERRIDE; |
| + virtual PrefReadError ReadPrefs() OVERRIDE; |
| + virtual void ReadPrefsAsync(ReadErrorDelegate* error_delegate) OVERRIDE; |
| + virtual void CommitPendingWrite() OVERRIDE; |
| + |
| + private: |
| + // Combines events from the underlying stores and reports them to the |
| + // observers of the combined store. |
|
robertshield
2014/03/25 03:05:12
Also document how this invokes the on_initializati
erikwright (departed)
2014/03/25 20:28:26
Done.
|
| + class TeeObserver : public PrefStore::Observer { |
|
robertshield
2014/03/25 03:05:12
Naming is hard. NotificationAggregator maybe? Mayb
erikwright (departed)
2014/03/25 20:28:26
In Unix there is a utility named tee that takes in
|
| + public: |
| + explicit TeeObserver(ProtectedPrefStore* outer); |
|
robertshield
2014/03/25 03:05:12
Should pass just the |observers_| list and the |on
erikwright (departed)
2014/03/25 20:28:26
There are three members of the outer class that ar
erikwright (departed)
2014/03/25 20:41:11
Also, in the current patchset we now access outer_
|
| + |
| + // PrefStore::Observer implementation |
| + virtual void OnPrefValueChanged(const std::string& key) OVERRIDE; |
| + virtual void OnInitializationCompleted(bool succeeded) OVERRIDE; |
| + |
| + private: |
| + ProtectedPrefStore* outer_; |
| + uint8 failed_sub_initializations_; |
| + uint8 successful_sub_initializations_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(TeeObserver); |
| + }; |
| + |
| + virtual ~ProtectedPrefStore(); |
| + |
| + // Returns |protected_pref_store| if |key| is protected or a value is present |
| + // in |protected_pref_store|. This could happen if |key| was previously |
| + // protected. |
| + const PersistentPrefStore* StoreForKey(const std::string& key) const; |
| + |
| + // Returns |protected_pref_store| if |key| is protected. If |key| is |
| + // unprotected but has a value in |protected_pref_store|, moves the value to |
| + // |unprotected_pref_store| before returning |unprotected_pref_store|. |
| + PersistentPrefStore* StoreForKey(const std::string& key); |
| + |
| + scoped_refptr<PersistentPrefStore> unprotected_pref_store_; |
| + scoped_refptr<PersistentPrefStore> protected_pref_store_; |
| + std::set<std::string> protected_preference_names_; |
| + base::Closure on_initialization_; |
| + |
| + ObserverList<PrefStore::Observer, true> observers_; |
| + TeeObserver tee_observer_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(ProtectedPrefStore); |
| +}; |
| + |
| +#endif // CHROME_BROWSER_PREFS_TRACKED_PROTECTED_PREF_STORE_H_ |