OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CHROME_BROWSER_EXTENSIONS_API_STORAGE_SETTINGS_BACKEND_H_ | 5 #ifndef CHROME_BROWSER_EXTENSIONS_API_STORAGE_SETTINGS_BACKEND_H_ |
6 #define CHROME_BROWSER_EXTENSIONS_API_STORAGE_SETTINGS_BACKEND_H_ | 6 #define CHROME_BROWSER_EXTENSIONS_API_STORAGE_SETTINGS_BACKEND_H_ |
7 | 7 |
8 #include <map> | 8 #include <map> |
9 #include <set> | 9 #include <set> |
10 #include <string> | 10 #include <string> |
(...skipping 22 matching lines...) Expand all Loading... |
33 // Lives entirely on the FILE thread. | 33 // Lives entirely on the FILE thread. |
34 class SettingsBackend : public syncer::SyncableService { | 34 class SettingsBackend : public syncer::SyncableService { |
35 public: | 35 public: |
36 // |storage_factory| is use to create leveldb storage areas. | 36 // |storage_factory| is use to create leveldb storage areas. |
37 // |base_path| is the base of the extension settings directory, so the | 37 // |base_path| is the base of the extension settings directory, so the |
38 // databases will be at base_path/extension_id. | 38 // databases will be at base_path/extension_id. |
39 // |observers| is the list of observers to settings changes. | 39 // |observers| is the list of observers to settings changes. |
40 SettingsBackend( | 40 SettingsBackend( |
41 const scoped_refptr<SettingsStorageFactory>& storage_factory, | 41 const scoped_refptr<SettingsStorageFactory>& storage_factory, |
42 const base::FilePath& base_path, | 42 const base::FilePath& base_path, |
| 43 syncer::ModelType sync_type, |
| 44 const syncer::SyncableService::StartSyncFlare& flare, |
43 const SettingsStorageQuotaEnforcer::Limits& quota, | 45 const SettingsStorageQuotaEnforcer::Limits& quota, |
44 const scoped_refptr<SettingsObserverList>& observers); | 46 const scoped_refptr<SettingsObserverList>& observers); |
45 | 47 |
46 virtual ~SettingsBackend(); | 48 virtual ~SettingsBackend(); |
47 | 49 |
48 // Gets a weak reference to the storage area for |extension_id|. | 50 // Gets a weak reference to the storage area for |extension_id|. |
49 // Must be run on the FILE thread. | 51 // Must be run on the FILE thread. |
50 ValueStore* GetStorage(const std::string& extension_id) const; | 52 ValueStore* GetStorage(const std::string& extension_id) const; |
51 | 53 |
52 // Deletes all setting data for an extension. Call on the FILE thread. | 54 // Deletes all setting data for an extension. Call on the FILE thread. |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
91 | 93 |
92 // The list of observers to settings changes. | 94 // The list of observers to settings changes. |
93 const scoped_refptr<SettingsObserverList> observers_; | 95 const scoped_refptr<SettingsObserverList> observers_; |
94 | 96 |
95 // A cache of ValueStore objects that have already been created. | 97 // A cache of ValueStore objects that have already been created. |
96 // Ensure that there is only ever one created per extension. | 98 // Ensure that there is only ever one created per extension. |
97 typedef std::map<std::string, linked_ptr<SyncableSettingsStorage> > | 99 typedef std::map<std::string, linked_ptr<SyncableSettingsStorage> > |
98 StorageObjMap; | 100 StorageObjMap; |
99 mutable StorageObjMap storage_objs_; | 101 mutable StorageObjMap storage_objs_; |
100 | 102 |
101 // Current sync model type. Will be UNSPECIFIED if sync hasn't been enabled | 103 // Current sync model type. Either EXTENSION_SETTINGS or APP_SETTINGS. |
102 // yet, and either SETTINGS or APP_SETTINGS if it has been. | |
103 syncer::ModelType sync_type_; | 104 syncer::ModelType sync_type_; |
104 | 105 |
105 // Current sync processor, if any. | 106 // Current sync processor, if any. |
106 scoped_ptr<syncer::SyncChangeProcessor> sync_processor_; | 107 scoped_ptr<syncer::SyncChangeProcessor> sync_processor_; |
107 | 108 |
108 // Current sync error handler if any. | 109 // Current sync error handler if any. |
109 scoped_ptr<syncer::SyncErrorFactory> sync_error_factory_; | 110 scoped_ptr<syncer::SyncErrorFactory> sync_error_factory_; |
110 | 111 |
| 112 syncer::SyncableService::StartSyncFlare flare_; |
| 113 |
111 DISALLOW_COPY_AND_ASSIGN(SettingsBackend); | 114 DISALLOW_COPY_AND_ASSIGN(SettingsBackend); |
112 }; | 115 }; |
113 | 116 |
114 } // namespace extensions | 117 } // namespace extensions |
115 | 118 |
116 #endif // CHROME_BROWSER_EXTENSIONS_API_STORAGE_SETTINGS_BACKEND_H_ | 119 #endif // CHROME_BROWSER_EXTENSIONS_API_STORAGE_SETTINGS_BACKEND_H_ |
OLD | NEW |