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_ |