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 #include "chrome/browser/prefs/chrome_pref_service_factory.h" | 5 #include "chrome/browser/prefs/chrome_pref_service_factory.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/debug/trace_event.h" | 8 #include "base/debug/trace_event.h" |
9 #include "base/file_util.h" | 9 #include "base/file_util.h" |
10 #include "base/files/file_path.h" | 10 #include "base/files/file_path.h" |
11 #include "base/metrics/histogram.h" | 11 #include "base/metrics/histogram.h" |
12 #include "base/prefs/default_pref_store.h" | 12 #include "base/prefs/default_pref_store.h" |
13 #include "base/prefs/json_pref_store.h" | 13 #include "base/prefs/json_pref_store.h" |
14 #include "base/prefs/pref_notifier_impl.h" | 14 #include "base/prefs/pref_notifier_impl.h" |
15 #include "base/prefs/pref_registry.h" | 15 #include "base/prefs/pref_registry.h" |
16 #include "base/prefs/pref_service.h" | 16 #include "base/prefs/pref_service.h" |
17 #include "base/prefs/pref_value_store.h" | 17 #include "base/prefs/pref_value_store.h" |
18 #include "chrome/browser/browser_process.h" | 18 #include "chrome/browser/browser_process.h" |
19 #include "chrome/browser/prefs/command_line_pref_store.h" | 19 #include "chrome/browser/prefs/command_line_pref_store.h" |
20 #include "chrome/browser/prefs/pref_change_reporter.h" | |
21 #include "chrome/browser/prefs/pref_hash_store.h" | |
20 #include "chrome/browser/prefs/pref_model_associator.h" | 22 #include "chrome/browser/prefs/pref_model_associator.h" |
21 #include "chrome/browser/prefs/pref_service_syncable_builder.h" | 23 #include "chrome/browser/prefs/pref_service_syncable_builder.h" |
22 #include "chrome/browser/ui/profile_error_dialog.h" | 24 #include "chrome/browser/ui/profile_error_dialog.h" |
23 #include "components/user_prefs/pref_registry_syncable.h" | 25 #include "components/user_prefs/pref_registry_syncable.h" |
24 #include "content/public/browser/browser_context.h" | 26 #include "content/public/browser/browser_context.h" |
25 #include "content/public/browser/browser_thread.h" | 27 #include "content/public/browser/browser_thread.h" |
26 #include "grit/chromium_strings.h" | 28 #include "grit/chromium_strings.h" |
27 #include "grit/generated_resources.h" | 29 #include "grit/generated_resources.h" |
28 | 30 |
29 #if defined(ENABLE_CONFIGURATION_POLICY) | 31 #if defined(ENABLE_CONFIGURATION_POLICY) |
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
70 #endif | 72 #endif |
71 } | 73 } |
72 } | 74 } |
73 | 75 |
74 void PrepareBuilder( | 76 void PrepareBuilder( |
75 PrefServiceSyncableBuilder* builder, | 77 PrefServiceSyncableBuilder* builder, |
76 const base::FilePath& pref_filename, | 78 const base::FilePath& pref_filename, |
77 base::SequencedTaskRunner* pref_io_task_runner, | 79 base::SequencedTaskRunner* pref_io_task_runner, |
78 policy::PolicyService* policy_service, | 80 policy::PolicyService* policy_service, |
79 ManagedUserSettingsService* managed_user_settings, | 81 ManagedUserSettingsService* managed_user_settings, |
82 scoped_ptr<PrefHashStore> pref_hash_store, | |
80 const scoped_refptr<PrefStore>& extension_prefs, | 83 const scoped_refptr<PrefStore>& extension_prefs, |
81 bool async) { | 84 bool async) { |
82 #if defined(OS_LINUX) | 85 #if defined(OS_LINUX) |
83 // We'd like to see what fraction of our users have the preferences | 86 // We'd like to see what fraction of our users have the preferences |
84 // stored on a network file system, as we've had no end of troubles | 87 // stored on a network file system, as we've had no end of troubles |
85 // with NFS/AFS. | 88 // with NFS/AFS. |
86 // TODO(evanm): remove this once we've collected state. | 89 // TODO(evanm): remove this once we've collected state. |
87 file_util::FileSystemType fstype; | 90 file_util::FileSystemType fstype; |
88 if (file_util::GetFileSystemType(pref_filename.DirName(), &fstype)) { | 91 if (file_util::GetFileSystemType(pref_filename.DirName(), &fstype)) { |
89 UMA_HISTOGRAM_ENUMERATION("PrefService.FileSystemType", | 92 UMA_HISTOGRAM_ENUMERATION("PrefService.FileSystemType", |
(...skipping 19 matching lines...) Expand all Loading... | |
109 builder->WithSupervisedUserPrefs( | 112 builder->WithSupervisedUserPrefs( |
110 new SupervisedUserPrefStore(managed_user_settings)); | 113 new SupervisedUserPrefStore(managed_user_settings)); |
111 } | 114 } |
112 #endif | 115 #endif |
113 | 116 |
114 builder->WithAsync(async); | 117 builder->WithAsync(async); |
115 builder->WithExtensionPrefs(extension_prefs.get()); | 118 builder->WithExtensionPrefs(extension_prefs.get()); |
116 builder->WithCommandLinePrefs( | 119 builder->WithCommandLinePrefs( |
117 new CommandLinePrefStore(CommandLine::ForCurrentProcess())); | 120 new CommandLinePrefStore(CommandLine::ForCurrentProcess())); |
118 builder->WithReadErrorCallback(base::Bind(&HandleReadError)); | 121 builder->WithReadErrorCallback(base::Bind(&HandleReadError)); |
119 builder->WithUserPrefs(new JsonPrefStore(pref_filename, pref_io_task_runner)); | 122 |
123 scoped_refptr<JsonPrefStore> pref_store( | |
124 new JsonPrefStore(pref_filename, pref_io_task_runner)); | |
125 | |
126 ReportPrefStoreChangesToUMA(pref_store.get(), pref_hash_store.Pass()); | |
gab
2013/11/27 23:43:27
Consider a more generic name; this could later be
| |
127 | |
128 builder->WithUserPrefs(pref_store.get()); | |
gab
2013/11/27 23:43:27
FYI, looks like this changed in https://codereview
| |
120 } | 129 } |
121 | 130 |
122 } // namespace | 131 } // namespace |
123 | 132 |
124 namespace chrome_prefs { | 133 namespace chrome_prefs { |
125 | 134 |
126 PrefService* CreateLocalState( | 135 PrefService* CreateLocalState( |
127 const base::FilePath& pref_filename, | 136 const base::FilePath& pref_filename, |
128 base::SequencedTaskRunner* pref_io_task_runner, | 137 base::SequencedTaskRunner* pref_io_task_runner, |
129 policy::PolicyService* policy_service, | 138 policy::PolicyService* policy_service, |
130 const scoped_refptr<PrefRegistry>& pref_registry, | 139 const scoped_refptr<PrefRegistry>& pref_registry, |
131 bool async) { | 140 bool async) { |
132 PrefServiceSyncableBuilder builder; | 141 PrefServiceSyncableBuilder builder; |
133 PrepareBuilder(&builder, | 142 PrepareBuilder(&builder, |
134 pref_filename, | 143 pref_filename, |
135 pref_io_task_runner, | 144 pref_io_task_runner, |
136 policy_service, | 145 policy_service, |
137 NULL, | 146 NULL, |
147 scoped_ptr<PrefHashStore>(), | |
138 NULL, | 148 NULL, |
139 async); | 149 async); |
140 return builder.Create(pref_registry.get()); | 150 return builder.Create(pref_registry.get()); |
141 } | 151 } |
142 | 152 |
143 PrefServiceSyncable* CreateProfilePrefs( | 153 PrefServiceSyncable* CreateProfilePrefs( |
144 const base::FilePath& pref_filename, | 154 const base::FilePath& pref_filename, |
145 base::SequencedTaskRunner* pref_io_task_runner, | 155 base::SequencedTaskRunner* pref_io_task_runner, |
146 policy::PolicyService* policy_service, | 156 policy::PolicyService* policy_service, |
147 ManagedUserSettingsService* managed_user_settings, | 157 ManagedUserSettingsService* managed_user_settings, |
158 scoped_ptr<PrefHashStore> pref_hash_store, | |
148 const scoped_refptr<PrefStore>& extension_prefs, | 159 const scoped_refptr<PrefStore>& extension_prefs, |
149 const scoped_refptr<user_prefs::PrefRegistrySyncable>& pref_registry, | 160 const scoped_refptr<user_prefs::PrefRegistrySyncable>& pref_registry, |
150 bool async) { | 161 bool async) { |
151 TRACE_EVENT0("browser", "chrome_prefs::CreateProfilePrefs"); | 162 TRACE_EVENT0("browser", "chrome_prefs::CreateProfilePrefs"); |
152 PrefServiceSyncableBuilder builder; | 163 PrefServiceSyncableBuilder builder; |
153 PrepareBuilder(&builder, | 164 PrepareBuilder(&builder, |
154 pref_filename, | 165 pref_filename, |
155 pref_io_task_runner, | 166 pref_io_task_runner, |
156 policy_service, | 167 policy_service, |
157 managed_user_settings, | 168 managed_user_settings, |
169 pref_hash_store.Pass(), | |
158 extension_prefs, | 170 extension_prefs, |
159 async); | 171 async); |
160 return builder.CreateSyncable(pref_registry.get()); | 172 return builder.CreateSyncable(pref_registry.get()); |
161 } | 173 } |
162 | 174 |
163 } // namespace chrome_prefs | 175 } // namespace chrome_prefs |
OLD | NEW |