Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(441)

Side by Side Diff: components/browser_sync/browser/profile_sync_components_factory_impl.cc

Issue 1421003007: [Sync] Componentize ProfileSyncComponentsFactoryImpl (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix sessions api test Created 5 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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/sync/profile_sync_components_factory_impl.h" 5 #include "components/browser_sync/browser/profile_sync_components_factory_impl.h "
6 6
7 #include "base/command_line.h" 7 #include "base/command_line.h"
8 #include "base/memory/ref_counted.h" 8 #include "base/memory/ref_counted.h"
9 #include "base/prefs/pref_service.h" 9 #include "base/prefs/pref_service.h"
10 #include "build/build_config.h" 10 #include "build/build_config.h"
11 #include "chrome/browser/bookmarks/bookmark_model_factory.h"
12 #include "chrome/browser/profiles/profile.h"
13 #include "chrome/browser/search_engines/template_url_service_factory.h"
14 #include "chrome/browser/sync/glue/theme_data_type_controller.h"
15 #include "chrome/common/channel_info.h"
16 #include "chrome/common/chrome_switches.h"
17 #include "chrome/common/pref_names.h"
18 #include "components/autofill/core/browser/autofill_wallet_data_type_controller. h" 11 #include "components/autofill/core/browser/autofill_wallet_data_type_controller. h"
19 #include "components/autofill/core/browser/webdata/autofill_data_type_controller .h" 12 #include "components/autofill/core/browser/webdata/autofill_data_type_controller .h"
20 #include "components/autofill/core/browser/webdata/autofill_profile_data_type_co ntroller.h" 13 #include "components/autofill/core/browser/webdata/autofill_profile_data_type_co ntroller.h"
21 #include "components/autofill/core/common/autofill_pref_names.h" 14 #include "components/autofill/core/common/autofill_pref_names.h"
22 #include "components/autofill/core/common/autofill_switches.h" 15 #include "components/autofill/core/common/autofill_switches.h"
23 #include "components/browser_sync/browser/profile_sync_service.h" 16 #include "components/browser_sync/browser/profile_sync_service.h"
24 #include "components/browser_sync/common/browser_sync_switches.h" 17 #include "components/browser_sync/common/browser_sync_switches.h"
25 #include "components/dom_distiller/core/dom_distiller_features.h" 18 #include "components/dom_distiller/core/dom_distiller_features.h"
26 #include "components/history/core/browser/history_delete_directives_data_type_co ntroller.h" 19 #include "components/history/core/browser/history_delete_directives_data_type_co ntroller.h"
27 #include "components/history/core/browser/typed_url_change_processor.h" 20 #include "components/history/core/browser/typed_url_change_processor.h"
28 #include "components/history/core/browser/typed_url_data_type_controller.h" 21 #include "components/history/core/browser/typed_url_data_type_controller.h"
29 #include "components/history/core/browser/typed_url_model_associator.h" 22 #include "components/history/core/browser/typed_url_model_associator.h"
30 #include "components/password_manager/sync/browser/password_data_type_controller .h" 23 #include "components/password_manager/sync/browser/password_data_type_controller .h"
31 #include "components/search_engines/search_engine_data_type_controller.h"
32 #include "components/sync_bookmarks/bookmark_change_processor.h" 24 #include "components/sync_bookmarks/bookmark_change_processor.h"
33 #include "components/sync_bookmarks/bookmark_data_type_controller.h" 25 #include "components/sync_bookmarks/bookmark_data_type_controller.h"
34 #include "components/sync_bookmarks/bookmark_model_associator.h" 26 #include "components/sync_bookmarks/bookmark_model_associator.h"
35 #include "components/sync_driver/data_type_manager_impl.h" 27 #include "components/sync_driver/data_type_manager_impl.h"
36 #include "components/sync_driver/device_info_data_type_controller.h" 28 #include "components/sync_driver/device_info_data_type_controller.h"
37 #include "components/sync_driver/glue/chrome_report_unrecoverable_error.h" 29 #include "components/sync_driver/glue/chrome_report_unrecoverable_error.h"
38 #include "components/sync_driver/glue/sync_backend_host.h" 30 #include "components/sync_driver/glue/sync_backend_host.h"
39 #include "components/sync_driver/glue/sync_backend_host_impl.h" 31 #include "components/sync_driver/glue/sync_backend_host_impl.h"
40 #include "components/sync_driver/local_device_info_provider_impl.h" 32 #include "components/sync_driver/local_device_info_provider_impl.h"
41 #include "components/sync_driver/proxy_data_type_controller.h" 33 #include "components/sync_driver/proxy_data_type_controller.h"
42 #include "components/sync_driver/sync_client.h" 34 #include "components/sync_driver/sync_client.h"
43 #include "components/sync_driver/ui_data_type_controller.h" 35 #include "components/sync_driver/ui_data_type_controller.h"
44 #include "components/sync_sessions/session_data_type_controller.h" 36 #include "components/sync_sessions/session_data_type_controller.h"
45 #include "content/public/browser/browser_thread.h"
46 #include "google_apis/gaia/oauth2_token_service.h" 37 #include "google_apis/gaia/oauth2_token_service.h"
47 #include "google_apis/gaia/oauth2_token_service_request.h" 38 #include "google_apis/gaia/oauth2_token_service_request.h"
48 #include "net/url_request/url_request_context_getter.h" 39 #include "net/url_request/url_request_context_getter.h"
49 #include "sync/internal_api/public/attachments/attachment_downloader.h" 40 #include "sync/internal_api/public/attachments/attachment_downloader.h"
50 #include "sync/internal_api/public/attachments/attachment_service.h" 41 #include "sync/internal_api/public/attachments/attachment_service.h"
51 #include "sync/internal_api/public/attachments/attachment_service_impl.h" 42 #include "sync/internal_api/public/attachments/attachment_service_impl.h"
52 #include "sync/internal_api/public/attachments/attachment_uploader_impl.h" 43 #include "sync/internal_api/public/attachments/attachment_uploader_impl.h"
53 #include "ui/base/device_form_factor.h"
54
55 #if defined(ENABLE_APP_LIST)
56 #include "ui/app_list/app_list_switches.h"
57 #endif
58
59 #if defined(ENABLE_EXTENSIONS)
60 #include "chrome/browser/sync/glue/extension_data_type_controller.h"
61 #include "chrome/browser/sync/glue/extension_setting_data_type_controller.h"
62 #endif
63
64 #if defined(ENABLE_SUPERVISED_USERS)
65 #include "chrome/browser/supervised_user/supervised_user_sync_data_type_controll er.h"
66 #endif
67 44
68 using bookmarks::BookmarkModel; 45 using bookmarks::BookmarkModel;
69 using browser_sync::AutofillDataTypeController; 46 using browser_sync::AutofillDataTypeController;
70 using browser_sync::AutofillProfileDataTypeController; 47 using browser_sync::AutofillProfileDataTypeController;
71 using browser_sync::BookmarkChangeProcessor; 48 using browser_sync::BookmarkChangeProcessor;
72 using browser_sync::BookmarkDataTypeController; 49 using browser_sync::BookmarkDataTypeController;
73 using browser_sync::BookmarkModelAssociator; 50 using browser_sync::BookmarkModelAssociator;
74 using browser_sync::ChromeReportUnrecoverableError; 51 using browser_sync::ChromeReportUnrecoverableError;
75 #if defined(ENABLE_EXTENSIONS)
76 using browser_sync::ExtensionDataTypeController;
77 using browser_sync::ExtensionSettingDataTypeController;
78 #endif
79 using browser_sync::HistoryDeleteDirectivesDataTypeController; 52 using browser_sync::HistoryDeleteDirectivesDataTypeController;
80 using browser_sync::PasswordDataTypeController; 53 using browser_sync::PasswordDataTypeController;
81 using browser_sync::SearchEngineDataTypeController;
82 using browser_sync::SessionDataTypeController; 54 using browser_sync::SessionDataTypeController;
83 using browser_sync::SyncBackendHost; 55 using browser_sync::SyncBackendHost;
84 using browser_sync::ThemeDataTypeController;
85 using browser_sync::TypedUrlChangeProcessor; 56 using browser_sync::TypedUrlChangeProcessor;
86 using browser_sync::TypedUrlDataTypeController; 57 using browser_sync::TypedUrlDataTypeController;
87 using browser_sync::TypedUrlModelAssociator; 58 using browser_sync::TypedUrlModelAssociator;
88 using content::BrowserThread;
89 using sync_driver::DataTypeController; 59 using sync_driver::DataTypeController;
90 using sync_driver::DataTypeErrorHandler; 60 using sync_driver::DataTypeErrorHandler;
91 using sync_driver::DataTypeManager; 61 using sync_driver::DataTypeManager;
92 using sync_driver::DataTypeManagerImpl; 62 using sync_driver::DataTypeManagerImpl;
93 using sync_driver::DataTypeManagerObserver; 63 using sync_driver::DataTypeManagerObserver;
94 using sync_driver::DeviceInfoDataTypeController; 64 using sync_driver::DeviceInfoDataTypeController;
95 using sync_driver::ProxyDataTypeController; 65 using sync_driver::ProxyDataTypeController;
96 using sync_driver::UIDataTypeController; 66 using sync_driver::UIDataTypeController;
97 67
98 namespace { 68 namespace {
(...skipping 13 matching lines...) Expand all
112 syncer::ModelTypeSet enabled_types; 82 syncer::ModelTypeSet enabled_types;
113 if (command_line.HasSwitch(autofill::switches::kEnableWalletMetadataSync)) 83 if (command_line.HasSwitch(autofill::switches::kEnableWalletMetadataSync))
114 enabled_types.Put(syncer::AUTOFILL_WALLET_METADATA); 84 enabled_types.Put(syncer::AUTOFILL_WALLET_METADATA);
115 85
116 return enabled_types; 86 return enabled_types;
117 } 87 }
118 88
119 } // namespace 89 } // namespace
120 90
121 ProfileSyncComponentsFactoryImpl::ProfileSyncComponentsFactoryImpl( 91 ProfileSyncComponentsFactoryImpl::ProfileSyncComponentsFactoryImpl(
122 Profile* profile, 92 sync_driver::SyncClient* sync_client,
123 base::CommandLine* command_line, 93 version_info::Channel channel,
94 const std::string& version,
95 bool is_tablet,
96 const base::CommandLine& command_line,
97 const char* history_disabled_pref,
124 const GURL& sync_service_url, 98 const GURL& sync_service_url,
99 const scoped_refptr<base::SingleThreadTaskRunner>& ui_thread,
100 const scoped_refptr<base::SingleThreadTaskRunner>& db_thread,
125 OAuth2TokenService* token_service, 101 OAuth2TokenService* token_service,
126 net::URLRequestContextGetter* url_request_context_getter) 102 net::URLRequestContextGetter* url_request_context_getter)
127 : profile_(profile), 103 : sync_client_(sync_client),
104 channel_(channel),
105 version_(version),
106 is_tablet_(is_tablet),
128 command_line_(command_line), 107 command_line_(command_line),
108 history_disabled_pref_(history_disabled_pref),
129 sync_service_url_(sync_service_url), 109 sync_service_url_(sync_service_url),
110 ui_thread_(ui_thread),
111 db_thread_(db_thread),
130 token_service_(token_service), 112 token_service_(token_service),
131 url_request_context_getter_(url_request_context_getter), 113 url_request_context_getter_(url_request_context_getter),
132 weak_factory_(this) { 114 weak_factory_(this) {
133 DCHECK(token_service_); 115 DCHECK(token_service_);
134 DCHECK(url_request_context_getter_); 116 DCHECK(url_request_context_getter_);
135 } 117 }
136 118
137 ProfileSyncComponentsFactoryImpl::~ProfileSyncComponentsFactoryImpl() { 119 ProfileSyncComponentsFactoryImpl::~ProfileSyncComponentsFactoryImpl() {}
138 }
139 120
140 void ProfileSyncComponentsFactoryImpl::RegisterDataTypes( 121 void ProfileSyncComponentsFactoryImpl::RegisterDataTypes(
141 sync_driver::SyncClient* sync_client) { 122 const RegisterDataTypesMethod& register_platform_types_method) {
142 syncer::ModelTypeSet disabled_types = 123 syncer::ModelTypeSet disabled_types =
143 GetDisabledTypesFromCommandLine(*command_line_); 124 GetDisabledTypesFromCommandLine(command_line_);
144 syncer::ModelTypeSet enabled_types = 125 syncer::ModelTypeSet enabled_types =
145 GetEnabledTypesFromCommandLine(*command_line_); 126 GetEnabledTypesFromCommandLine(command_line_);
146 RegisterCommonDataTypes(disabled_types, enabled_types, sync_client); 127 RegisterCommonDataTypes(disabled_types, enabled_types);
147 #if !defined(OS_ANDROID) 128 if (!register_platform_types_method.is_null())
148 RegisterDesktopDataTypes(disabled_types, enabled_types, sync_client); 129 register_platform_types_method.Run(disabled_types, enabled_types);
149 #endif
150 } 130 }
151 131
152 void ProfileSyncComponentsFactoryImpl::RegisterCommonDataTypes( 132 void ProfileSyncComponentsFactoryImpl::RegisterCommonDataTypes(
153 syncer::ModelTypeSet disabled_types, 133 syncer::ModelTypeSet disabled_types,
154 syncer::ModelTypeSet enabled_types, 134 syncer::ModelTypeSet enabled_types) {
155 sync_driver::SyncClient* sync_client) { 135 sync_driver::SyncService* sync_service = sync_client_->GetSyncService();
156 sync_driver::SyncService* sync_service = sync_client->GetSyncService();
157 base::Closure error_callback = 136 base::Closure error_callback =
158 base::Bind(&ChromeReportUnrecoverableError, chrome::GetChannel()); 137 base::Bind(&ChromeReportUnrecoverableError, channel_);
159 const scoped_refptr<base::SingleThreadTaskRunner> ui_thread =
160 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::UI);
161 const scoped_refptr<base::SingleThreadTaskRunner> db_thread =
162 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::DB);
163 138
164 // TODO(stanisc): can DEVICE_INFO be one of disabled datatypes? 139 // TODO(stanisc): can DEVICE_INFO be one of disabled datatypes?
165 sync_service->RegisterDataTypeController(new DeviceInfoDataTypeController( 140 sync_service->RegisterDataTypeController(new DeviceInfoDataTypeController(
166 ui_thread, error_callback, sync_client, 141 ui_thread_, error_callback, sync_client_,
167 sync_service->GetLocalDeviceInfoProvider())); 142 sync_service->GetLocalDeviceInfoProvider()));
168 143
169 // Autofill sync is enabled by default. Register unless explicitly 144 // Autofill sync is enabled by default. Register unless explicitly
170 // disabled. 145 // disabled.
171 if (!disabled_types.Has(syncer::AUTOFILL)) { 146 if (!disabled_types.Has(syncer::AUTOFILL)) {
172 sync_service->RegisterDataTypeController(new AutofillDataTypeController( 147 sync_service->RegisterDataTypeController(new AutofillDataTypeController(
173 ui_thread, db_thread, error_callback, sync_client)); 148 ui_thread_, db_thread_, error_callback, sync_client_));
174 } 149 }
175 150
176 // Autofill profile sync is enabled by default. Register unless explicitly 151 // Autofill profile sync is enabled by default. Register unless explicitly
177 // disabled. 152 // disabled.
178 if (!disabled_types.Has(syncer::AUTOFILL_PROFILE)) { 153 if (!disabled_types.Has(syncer::AUTOFILL_PROFILE)) {
179 sync_service->RegisterDataTypeController( 154 sync_service->RegisterDataTypeController(
180 new AutofillProfileDataTypeController(ui_thread, db_thread, 155 new AutofillProfileDataTypeController(ui_thread_, db_thread_,
181 error_callback, sync_client)); 156 error_callback, sync_client_));
182 } 157 }
183 158
184 // Wallet data sync is enabled by default, but behind a syncer experiment 159 // Wallet data sync is enabled by default, but behind a syncer experiment
185 // enforced by the datatype controller. Register unless explicitly disabled. 160 // enforced by the datatype controller. Register unless explicitly disabled.
186 bool wallet_disabled = disabled_types.Has(syncer::AUTOFILL_WALLET_DATA); 161 bool wallet_disabled = disabled_types.Has(syncer::AUTOFILL_WALLET_DATA);
187 if (!wallet_disabled) { 162 if (!wallet_disabled) {
188 sync_service->RegisterDataTypeController( 163 sync_service->RegisterDataTypeController(
189 new browser_sync::AutofillWalletDataTypeController( 164 new browser_sync::AutofillWalletDataTypeController(
190 ui_thread, db_thread, error_callback, sync_client, 165 ui_thread_, db_thread_, error_callback, sync_client_,
191 syncer::AUTOFILL_WALLET_DATA)); 166 syncer::AUTOFILL_WALLET_DATA));
192 } 167 }
193 168
194 // Wallet metadata sync depends on Wallet data sync and is disabled by 169 // Wallet metadata sync depends on Wallet data sync and is disabled by
195 // default. Register if Wallet data is syncing and metadata sync is explicitly 170 // default. Register if Wallet data is syncing and metadata sync is explicitly
196 // enabled. 171 // enabled.
197 if (!wallet_disabled && enabled_types.Has(syncer::AUTOFILL_WALLET_METADATA)) { 172 if (!wallet_disabled && enabled_types.Has(syncer::AUTOFILL_WALLET_METADATA)) {
198 sync_service->RegisterDataTypeController( 173 sync_service->RegisterDataTypeController(
199 new browser_sync::AutofillWalletDataTypeController( 174 new browser_sync::AutofillWalletDataTypeController(
200 ui_thread, db_thread, error_callback, sync_client, 175 ui_thread_, db_thread_, error_callback, sync_client_,
201 syncer::AUTOFILL_WALLET_METADATA)); 176 syncer::AUTOFILL_WALLET_METADATA));
202 } 177 }
203 178
204 // Bookmark sync is enabled by default. Register unless explicitly 179 // Bookmark sync is enabled by default. Register unless explicitly
205 // disabled. 180 // disabled.
206 if (!disabled_types.Has(syncer::BOOKMARKS)) { 181 if (!disabled_types.Has(syncer::BOOKMARKS)) {
207 sync_service->RegisterDataTypeController( 182 sync_service->RegisterDataTypeController(new BookmarkDataTypeController(
208 new BookmarkDataTypeController(ui_thread, error_callback, sync_client)); 183 ui_thread_, error_callback, sync_client_));
209 } 184 }
210 185
211 const bool history_disabled = 186 const bool history_disabled =
212 profile_->GetPrefs()->GetBoolean(prefs::kSavingBrowserHistoryDisabled); 187 sync_client_->GetPrefService()->GetBoolean(history_disabled_pref_);
213 // TypedUrl sync is enabled by default. Register unless explicitly disabled, 188 // TypedUrl sync is enabled by default. Register unless explicitly disabled,
214 // or if saving history is disabled. 189 // or if saving history is disabled.
215 if (!disabled_types.Has(syncer::TYPED_URLS) && !history_disabled) { 190 if (!disabled_types.Has(syncer::TYPED_URLS) && !history_disabled) {
216 sync_service->RegisterDataTypeController( 191 sync_service->RegisterDataTypeController(new TypedUrlDataTypeController(
217 new TypedUrlDataTypeController(ui_thread, error_callback, sync_client, 192 ui_thread_, error_callback, sync_client_, history_disabled_pref_));
218 prefs::kSavingBrowserHistoryDisabled));
219 } 193 }
220 194
221 // Delete directive sync is enabled by default. Register unless full history 195 // Delete directive sync is enabled by default. Register unless full history
222 // sync is disabled. 196 // sync is disabled.
223 if (!disabled_types.Has(syncer::HISTORY_DELETE_DIRECTIVES) && 197 if (!disabled_types.Has(syncer::HISTORY_DELETE_DIRECTIVES) &&
224 !history_disabled) { 198 !history_disabled) {
225 sync_service->RegisterDataTypeController( 199 sync_service->RegisterDataTypeController(
226 new HistoryDeleteDirectivesDataTypeController(ui_thread, error_callback, 200 new HistoryDeleteDirectivesDataTypeController(
227 sync_client)); 201 ui_thread_, error_callback, sync_client_));
228 } 202 }
229 203
230 // Session sync is enabled by default. Register unless explicitly disabled. 204 // Session sync is enabled by default. Register unless explicitly disabled.
231 // This is also disabled if the browser history is disabled, because the 205 // This is also disabled if the browser history is disabled, because the
232 // tab sync data is added to the web history on the server. 206 // tab sync data is added to the web history on the server.
233 if (!disabled_types.Has(syncer::PROXY_TABS) && !history_disabled) { 207 if (!disabled_types.Has(syncer::PROXY_TABS) && !history_disabled) {
234 sync_service->RegisterDataTypeController( 208 sync_service->RegisterDataTypeController(
235 new ProxyDataTypeController(ui_thread, syncer::PROXY_TABS)); 209 new ProxyDataTypeController(ui_thread_, syncer::PROXY_TABS));
236 // TODO(zea): remove this once SyncedWindowDelegateGetter is componentized. 210 // TODO(zea): remove this once SyncedWindowDelegateGetter is componentized.
237 // For now, we know that the implementation of SyncService is always a 211 // For now, we know that the implementation of SyncService is always a
238 // ProfileSyncService at this level. 212 // ProfileSyncService at this level.
239 ProfileSyncService* pss = static_cast<ProfileSyncService*>(sync_service); 213 ProfileSyncService* pss = static_cast<ProfileSyncService*>(sync_service);
240 sync_service->RegisterDataTypeController(new SessionDataTypeController( 214 sync_service->RegisterDataTypeController(new SessionDataTypeController(
241 ui_thread, error_callback, sync_client, 215 ui_thread_, error_callback, sync_client_,
242 pss->GetSyncedWindowDelegatesGetter(), 216 pss->GetSyncedWindowDelegatesGetter(),
243 sync_service->GetLocalDeviceInfoProvider(), 217 sync_service->GetLocalDeviceInfoProvider(), history_disabled_pref_));
244 prefs::kSavingBrowserHistoryDisabled));
245 } 218 }
246 219
247 // Favicon sync is enabled by default. Register unless explicitly disabled. 220 // Favicon sync is enabled by default. Register unless explicitly disabled.
248 if (!disabled_types.Has(syncer::FAVICON_IMAGES) && 221 if (!disabled_types.Has(syncer::FAVICON_IMAGES) &&
249 !disabled_types.Has(syncer::FAVICON_TRACKING) && 222 !disabled_types.Has(syncer::FAVICON_TRACKING) && !history_disabled) {
250 !history_disabled) {
251 // crbug/384552. We disable error uploading for this data types for now. 223 // crbug/384552. We disable error uploading for this data types for now.
252 sync_service->RegisterDataTypeController(new UIDataTypeController( 224 sync_service->RegisterDataTypeController(new UIDataTypeController(
253 ui_thread, base::Closure(), syncer::FAVICON_IMAGES, sync_client)); 225 ui_thread_, base::Closure(), syncer::FAVICON_IMAGES, sync_client_));
254 sync_service->RegisterDataTypeController(new UIDataTypeController( 226 sync_service->RegisterDataTypeController(new UIDataTypeController(
255 ui_thread, base::Closure(), syncer::FAVICON_TRACKING, sync_client)); 227 ui_thread_, base::Closure(), syncer::FAVICON_TRACKING, sync_client_));
256 } 228 }
257 229
258 // Password sync is enabled by default. Register unless explicitly 230 // Password sync is enabled by default. Register unless explicitly
259 // disabled. 231 // disabled.
260 if (!disabled_types.Has(syncer::PASSWORDS)) { 232 if (!disabled_types.Has(syncer::PASSWORDS)) {
261 sync_service->RegisterDataTypeController(new PasswordDataTypeController( 233 sync_service->RegisterDataTypeController(new PasswordDataTypeController(
262 ui_thread, error_callback, sync_client, 234 ui_thread_, error_callback, sync_client_,
263 sync_client->GetPasswordStateChangedCallback())); 235 sync_client_->GetPasswordStateChangedCallback()));
264 } 236 }
265 237
266 if (!disabled_types.Has(syncer::PRIORITY_PREFERENCES)) { 238 if (!disabled_types.Has(syncer::PRIORITY_PREFERENCES)) {
267 sync_service->RegisterDataTypeController(new UIDataTypeController( 239 sync_service->RegisterDataTypeController(
268 ui_thread, error_callback, syncer::PRIORITY_PREFERENCES, sync_client)); 240 new UIDataTypeController(ui_thread_, error_callback,
241 syncer::PRIORITY_PREFERENCES, sync_client_));
269 } 242 }
270 243
271 // Article sync is disabled by default. Register only if explicitly enabled. 244 // Article sync is disabled by default. Register only if explicitly enabled.
272 if (dom_distiller::IsEnableSyncArticlesSet()) { 245 if (dom_distiller::IsEnableSyncArticlesSet()) {
273 sync_service->RegisterDataTypeController(new UIDataTypeController( 246 sync_service->RegisterDataTypeController(new UIDataTypeController(
274 ui_thread, error_callback, syncer::ARTICLES, sync_client)); 247 ui_thread_, error_callback, syncer::ARTICLES, sync_client_));
275 } 248 }
276
277 #if defined(ENABLE_SUPERVISED_USERS)
278 sync_service->RegisterDataTypeController(
279 new SupervisedUserSyncDataTypeController(syncer::SUPERVISED_USER_SETTINGS,
280 error_callback, sync_client,
281 profile_));
282 sync_service->RegisterDataTypeController(
283 new SupervisedUserSyncDataTypeController(
284 syncer::SUPERVISED_USER_WHITELISTS, error_callback, sync_client,
285 profile_));
286 #endif
287 }
288
289 void ProfileSyncComponentsFactoryImpl::RegisterDesktopDataTypes(
290 syncer::ModelTypeSet disabled_types,
291 syncer::ModelTypeSet enabled_types,
292 sync_driver::SyncClient* sync_client) {
293 sync_driver::SyncService* sync_service = sync_client->GetSyncService();
294 base::Closure error_callback =
295 base::Bind(&ChromeReportUnrecoverableError, chrome::GetChannel());
296 const scoped_refptr<base::SingleThreadTaskRunner> ui_thread =
297 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::UI);
298
299 #if defined(ENABLE_EXTENSIONS)
300 // App sync is enabled by default. Register unless explicitly
301 // disabled.
302 if (!disabled_types.Has(syncer::APPS)) {
303 sync_service->RegisterDataTypeController(new ExtensionDataTypeController(
304 syncer::APPS, error_callback, sync_client, profile_));
305 }
306
307 // Extension sync is enabled by default. Register unless explicitly
308 // disabled.
309 if (!disabled_types.Has(syncer::EXTENSIONS)) {
310 sync_service->RegisterDataTypeController(new ExtensionDataTypeController(
311 syncer::EXTENSIONS, error_callback, sync_client, profile_));
312 }
313 #endif
314
315 // Preference sync is enabled by default. Register unless explicitly
316 // disabled.
317 if (!disabled_types.Has(syncer::PREFERENCES)) {
318 sync_service->RegisterDataTypeController(new UIDataTypeController(
319 ui_thread, error_callback, syncer::PREFERENCES, sync_client));
320 }
321
322 #if defined(ENABLE_THEMES)
323 // Theme sync is enabled by default. Register unless explicitly disabled.
324 if (!disabled_types.Has(syncer::THEMES)) {
325 sync_service->RegisterDataTypeController(
326 new ThemeDataTypeController(error_callback, sync_client, profile_));
327 }
328 #endif
329
330 // Search Engine sync is enabled by default. Register unless explicitly
331 // disabled.
332 if (!disabled_types.Has(syncer::SEARCH_ENGINES)) {
333 sync_service->RegisterDataTypeController(new SearchEngineDataTypeController(
334 ui_thread, error_callback, sync_client,
335 TemplateURLServiceFactory::GetForProfile(profile_)));
336 }
337
338 #if defined(ENABLE_EXTENSIONS)
339 // Extension setting sync is enabled by default. Register unless explicitly
340 // disabled.
341 if (!disabled_types.Has(syncer::EXTENSION_SETTINGS)) {
342 sync_service->RegisterDataTypeController(
343 new ExtensionSettingDataTypeController(
344 syncer::EXTENSION_SETTINGS, error_callback, sync_client, profile_));
345 }
346
347 // App setting sync is enabled by default. Register unless explicitly
348 // disabled.
349 if (!disabled_types.Has(syncer::APP_SETTINGS)) {
350 sync_service->RegisterDataTypeController(
351 new ExtensionSettingDataTypeController(
352 syncer::APP_SETTINGS, error_callback, sync_client, profile_));
353 }
354 #endif
355
356 #if defined(ENABLE_APP_LIST)
357 if (app_list::switches::IsAppListSyncEnabled()) {
358 sync_service->RegisterDataTypeController(new UIDataTypeController(
359 ui_thread, error_callback, syncer::APP_LIST, sync_client));
360 }
361 #endif
362
363 #if defined(OS_LINUX) || defined(OS_WIN) || defined(OS_CHROMEOS)
364 // Dictionary sync is enabled by default.
365 if (!disabled_types.Has(syncer::DICTIONARY)) {
366 sync_service->RegisterDataTypeController(new UIDataTypeController(
367 ui_thread, error_callback, syncer::DICTIONARY, sync_client));
368 }
369 #endif
370
371 #if defined(ENABLE_SUPERVISED_USERS)
372 sync_service->RegisterDataTypeController(
373 new SupervisedUserSyncDataTypeController(
374 syncer::SUPERVISED_USERS, error_callback, sync_client, profile_));
375 sync_service->RegisterDataTypeController(
376 new SupervisedUserSyncDataTypeController(
377 syncer::SUPERVISED_USER_SHARED_SETTINGS, error_callback, sync_client,
378 profile_));
379 #endif
380
381 #if defined(OS_CHROMEOS)
382 if (command_line_->HasSwitch(switches::kEnableWifiCredentialSync) &&
383 !disabled_types.Has(syncer::WIFI_CREDENTIALS)) {
384 sync_service->RegisterDataTypeController(new UIDataTypeController(
385 ui_thread, error_callback, syncer::WIFI_CREDENTIALS, sync_client));
386 }
387 #endif
388 } 249 }
389 250
390 DataTypeManager* ProfileSyncComponentsFactoryImpl::CreateDataTypeManager( 251 DataTypeManager* ProfileSyncComponentsFactoryImpl::CreateDataTypeManager(
391 const syncer::WeakHandle<syncer::DataTypeDebugInfoListener>& 252 const syncer::WeakHandle<syncer::DataTypeDebugInfoListener>&
392 debug_info_listener, 253 debug_info_listener,
393 const DataTypeController::TypeMap* controllers, 254 const DataTypeController::TypeMap* controllers,
394 const sync_driver::DataTypeEncryptionHandler* encryption_handler, 255 const sync_driver::DataTypeEncryptionHandler* encryption_handler,
395 SyncBackendHost* backend, 256 SyncBackendHost* backend,
396 DataTypeManagerObserver* observer) { 257 DataTypeManagerObserver* observer) {
397 return new DataTypeManagerImpl(debug_info_listener, controllers, 258 return new DataTypeManagerImpl(debug_info_listener, controllers,
398 encryption_handler, backend, observer); 259 encryption_handler, backend, observer);
399 } 260 }
400 261
401 browser_sync::SyncBackendHost* 262 browser_sync::SyncBackendHost*
402 ProfileSyncComponentsFactoryImpl::CreateSyncBackendHost( 263 ProfileSyncComponentsFactoryImpl::CreateSyncBackendHost(
403 const std::string& name, 264 const std::string& name,
404 sync_driver::SyncClient* sync_client,
405 invalidation::InvalidationService* invalidator, 265 invalidation::InvalidationService* invalidator,
406 const base::WeakPtr<sync_driver::SyncPrefs>& sync_prefs, 266 const base::WeakPtr<sync_driver::SyncPrefs>& sync_prefs,
407 const base::FilePath& sync_folder) { 267 const base::FilePath& sync_folder) {
408 return new browser_sync::SyncBackendHostImpl( 268 return new browser_sync::SyncBackendHostImpl(
409 name, sync_client, 269 name, sync_client_, ui_thread_, invalidator, sync_prefs, sync_folder);
410 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::UI),
411 invalidator, sync_prefs, sync_folder);
412 } 270 }
413 271
414 scoped_ptr<sync_driver::LocalDeviceInfoProvider> 272 scoped_ptr<sync_driver::LocalDeviceInfoProvider>
415 ProfileSyncComponentsFactoryImpl::CreateLocalDeviceInfoProvider() { 273 ProfileSyncComponentsFactoryImpl::CreateLocalDeviceInfoProvider() {
416 return scoped_ptr<sync_driver::LocalDeviceInfoProvider>( 274 return scoped_ptr<sync_driver::LocalDeviceInfoProvider>(
417 new browser_sync::LocalDeviceInfoProviderImpl( 275 new browser_sync::LocalDeviceInfoProviderImpl(channel_, version_,
418 chrome::GetChannel(), 276 is_tablet_));
419 chrome::GetVersionString(),
420 ui::GetDeviceFormFactor() == ui::DEVICE_FORM_FACTOR_TABLET));
421 } 277 }
422 278
423 class TokenServiceProvider 279 class TokenServiceProvider
424 : public OAuth2TokenServiceRequest::TokenServiceProvider { 280 : public OAuth2TokenServiceRequest::TokenServiceProvider {
425 public: 281 public:
426 TokenServiceProvider( 282 TokenServiceProvider(
427 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, 283 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner,
428 OAuth2TokenService* token_service); 284 OAuth2TokenService* token_service);
429 285
430 // OAuth2TokenServiceRequest::TokenServiceProvider implementation. 286 // OAuth2TokenServiceRequest::TokenServiceProvider implementation.
431 scoped_refptr<base::SingleThreadTaskRunner> GetTokenServiceTaskRunner() 287 scoped_refptr<base::SingleThreadTaskRunner> GetTokenServiceTaskRunner()
432 override; 288 override;
433 OAuth2TokenService* GetTokenService() override; 289 OAuth2TokenService* GetTokenService() override;
434 290
435 private: 291 private:
436 ~TokenServiceProvider() override; 292 ~TokenServiceProvider() override;
437 293
438 scoped_refptr<base::SingleThreadTaskRunner> task_runner_; 294 scoped_refptr<base::SingleThreadTaskRunner> task_runner_;
439 OAuth2TokenService* token_service_; 295 OAuth2TokenService* token_service_;
440 }; 296 };
441 297
442 TokenServiceProvider::TokenServiceProvider( 298 TokenServiceProvider::TokenServiceProvider(
443 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, 299 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner,
444 OAuth2TokenService* token_service) 300 OAuth2TokenService* token_service)
445 : task_runner_(task_runner), token_service_(token_service) { 301 : task_runner_(task_runner), token_service_(token_service) {}
446 }
447 302
448 TokenServiceProvider::~TokenServiceProvider() { 303 TokenServiceProvider::~TokenServiceProvider() {}
449 }
450 304
451 scoped_refptr<base::SingleThreadTaskRunner> 305 scoped_refptr<base::SingleThreadTaskRunner>
452 TokenServiceProvider::GetTokenServiceTaskRunner() { 306 TokenServiceProvider::GetTokenServiceTaskRunner() {
453 return task_runner_; 307 return task_runner_;
454 } 308 }
455 309
456 OAuth2TokenService* TokenServiceProvider::GetTokenService() { 310 OAuth2TokenService* TokenServiceProvider::GetTokenService() {
457 return token_service_; 311 return token_service_;
458 } 312 }
459 313
460 scoped_ptr<syncer::AttachmentService> 314 scoped_ptr<syncer::AttachmentService>
461 ProfileSyncComponentsFactoryImpl::CreateAttachmentService( 315 ProfileSyncComponentsFactoryImpl::CreateAttachmentService(
462 scoped_ptr<syncer::AttachmentStoreForSync> attachment_store, 316 scoped_ptr<syncer::AttachmentStoreForSync> attachment_store,
463 const syncer::UserShare& user_share, 317 const syncer::UserShare& user_share,
464 const std::string& store_birthday, 318 const std::string& store_birthday,
465 syncer::ModelType model_type, 319 syncer::ModelType model_type,
466 syncer::AttachmentService::Delegate* delegate) { 320 syncer::AttachmentService::Delegate* delegate) {
467 scoped_ptr<syncer::AttachmentUploader> attachment_uploader; 321 scoped_ptr<syncer::AttachmentUploader> attachment_uploader;
468 scoped_ptr<syncer::AttachmentDownloader> attachment_downloader; 322 scoped_ptr<syncer::AttachmentDownloader> attachment_downloader;
469 // Only construct an AttachmentUploader and AttachmentDownload if we have sync 323 // Only construct an AttachmentUploader and AttachmentDownload if we have sync
470 // credentials. We may not have sync credentials because there may not be a 324 // credentials. We may not have sync credentials because there may not be a
471 // signed in sync user (e.g. sync is running in "backup" mode). 325 // signed in sync user (e.g. sync is running in "backup" mode).
472 if (!user_share.sync_credentials.email.empty() && 326 if (!user_share.sync_credentials.email.empty() &&
473 !user_share.sync_credentials.scope_set.empty()) { 327 !user_share.sync_credentials.scope_set.empty()) {
474 const scoped_refptr<base::SingleThreadTaskRunner> ui_thread =
475 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::UI);
476
477 scoped_refptr<OAuth2TokenServiceRequest::TokenServiceProvider> 328 scoped_refptr<OAuth2TokenServiceRequest::TokenServiceProvider>
478 token_service_provider( 329 token_service_provider(
479 new TokenServiceProvider(ui_thread, token_service_)); 330 new TokenServiceProvider(ui_thread_, token_service_));
480 // TODO(maniscalco): Use shared (one per profile) thread-safe instances of 331 // TODO(maniscalco): Use shared (one per profile) thread-safe instances of
481 // AttachmentUploader and AttachmentDownloader instead of creating a new one 332 // AttachmentUploader and AttachmentDownloader instead of creating a new one
482 // per AttachmentService (bug 369536). 333 // per AttachmentService (bug 369536).
483 attachment_uploader.reset(new syncer::AttachmentUploaderImpl( 334 attachment_uploader.reset(new syncer::AttachmentUploaderImpl(
484 sync_service_url_, url_request_context_getter_, 335 sync_service_url_, url_request_context_getter_,
485 user_share.sync_credentials.email, 336 user_share.sync_credentials.email,
486 user_share.sync_credentials.scope_set, token_service_provider, 337 user_share.sync_credentials.scope_set, token_service_provider,
487 store_birthday, model_type)); 338 store_birthday, model_type));
488 339
489 token_service_provider = 340 token_service_provider =
490 new TokenServiceProvider(ui_thread, token_service_); 341 new TokenServiceProvider(ui_thread_, token_service_);
491 attachment_downloader = syncer::AttachmentDownloader::Create( 342 attachment_downloader = syncer::AttachmentDownloader::Create(
492 sync_service_url_, url_request_context_getter_, 343 sync_service_url_, url_request_context_getter_,
493 user_share.sync_credentials.email, 344 user_share.sync_credentials.email,
494 user_share.sync_credentials.scope_set, token_service_provider, 345 user_share.sync_credentials.scope_set, token_service_provider,
495 store_birthday, model_type); 346 store_birthday, model_type);
496 } 347 }
497 348
498 // It is important that the initial backoff delay is relatively large. For 349 // It is important that the initial backoff delay is relatively large. For
499 // whatever reason, the server may fail all requests for a short period of 350 // whatever reason, the server may fail all requests for a short period of
500 // time. When this happens we don't want to overwhelm the server with 351 // time. When this happens we don't want to overwhelm the server with
501 // requests so we use a large initial backoff. 352 // requests so we use a large initial backoff.
502 const base::TimeDelta initial_backoff_delay = 353 const base::TimeDelta initial_backoff_delay =
503 base::TimeDelta::FromMinutes(30); 354 base::TimeDelta::FromMinutes(30);
504 const base::TimeDelta max_backoff_delay = base::TimeDelta::FromHours(4); 355 const base::TimeDelta max_backoff_delay = base::TimeDelta::FromHours(4);
505 scoped_ptr<syncer::AttachmentService> attachment_service( 356 scoped_ptr<syncer::AttachmentService> attachment_service(
506 new syncer::AttachmentServiceImpl( 357 new syncer::AttachmentServiceImpl(
507 attachment_store.Pass(), attachment_uploader.Pass(), 358 attachment_store.Pass(), attachment_uploader.Pass(),
508 attachment_downloader.Pass(), delegate, initial_backoff_delay, 359 attachment_downloader.Pass(), delegate, initial_backoff_delay,
509 max_backoff_delay)); 360 max_backoff_delay));
510 return attachment_service.Pass(); 361 return attachment_service.Pass();
511 } 362 }
512 363
513 sync_driver::SyncApiComponentFactory::SyncComponents 364 sync_driver::SyncApiComponentFactory::SyncComponents
514 ProfileSyncComponentsFactoryImpl::CreateBookmarkSyncComponents( 365 ProfileSyncComponentsFactoryImpl::CreateBookmarkSyncComponents(
515 sync_driver::SyncService* sync_service, 366 sync_driver::SyncService* sync_service,
516 sync_driver::DataTypeErrorHandler* error_handler) { 367 sync_driver::DataTypeErrorHandler* error_handler) {
517 BookmarkModel* bookmark_model = 368 BookmarkModel* bookmark_model =
518 BookmarkModelFactory::GetForProfile(profile_); 369 sync_service->GetSyncClient()->GetBookmarkModel();
519 syncer::UserShare* user_share = sync_service->GetUserShare(); 370 syncer::UserShare* user_share = sync_service->GetUserShare();
520 // TODO(akalin): We may want to propagate this switch up eventually. 371 // TODO(akalin): We may want to propagate this switch up eventually.
521 #if defined(OS_ANDROID) 372 #if defined(OS_ANDROID) || defined(OS_IOS)
522 const bool kExpectMobileBookmarksFolder = true; 373 const bool kExpectMobileBookmarksFolder = true;
523 #else 374 #else
524 const bool kExpectMobileBookmarksFolder = false; 375 const bool kExpectMobileBookmarksFolder = false;
525 #endif 376 #endif
526 BookmarkModelAssociator* model_associator = new BookmarkModelAssociator( 377 BookmarkModelAssociator* model_associator = new BookmarkModelAssociator(
527 bookmark_model, sync_service->GetSyncClient(), user_share, error_handler, 378 bookmark_model, sync_service->GetSyncClient(), user_share, error_handler,
528 kExpectMobileBookmarksFolder); 379 kExpectMobileBookmarksFolder);
529 BookmarkChangeProcessor* change_processor = new BookmarkChangeProcessor( 380 BookmarkChangeProcessor* change_processor = new BookmarkChangeProcessor(
530 sync_service->GetSyncClient(), model_associator, error_handler); 381 sync_service->GetSyncClient(), model_associator, error_handler);
531 return SyncComponents(model_associator, change_processor); 382 return SyncComponents(model_associator, change_processor);
532 } 383 }
533 384
534 sync_driver::SyncApiComponentFactory::SyncComponents 385 sync_driver::SyncApiComponentFactory::SyncComponents
535 ProfileSyncComponentsFactoryImpl::CreateTypedUrlSyncComponents( 386 ProfileSyncComponentsFactoryImpl::CreateTypedUrlSyncComponents(
536 sync_driver::SyncService* sync_service, 387 sync_driver::SyncService* sync_service,
537 history::HistoryBackend* history_backend, 388 history::HistoryBackend* history_backend,
538 sync_driver::DataTypeErrorHandler* error_handler) { 389 sync_driver::DataTypeErrorHandler* error_handler) {
539 DCHECK(!BrowserThread::CurrentlyOn(BrowserThread::UI)); 390 DCHECK(!ui_thread_->BelongsToCurrentThread());
540
541 const scoped_refptr<base::SingleThreadTaskRunner> ui_thread =
542 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::UI);
543 391
544 // TODO(zea): Once TypedURLs are converted to SyncableService, remove 392 // TODO(zea): Once TypedURLs are converted to SyncableService, remove
545 // |sync_service_| member, and make GetSyncService require it be called on 393 // |sync_service_| member, and make GetSyncService require it be called on
546 // the UI thread. 394 // the UI thread.
547 TypedUrlModelAssociator* model_associator = 395 TypedUrlModelAssociator* model_associator =
548 new TypedUrlModelAssociator(sync_service, 396 new TypedUrlModelAssociator(sync_service, history_backend, error_handler);
549 history_backend,
550 error_handler);
551 TypedUrlChangeProcessor* change_processor = new TypedUrlChangeProcessor( 397 TypedUrlChangeProcessor* change_processor = new TypedUrlChangeProcessor(
552 model_associator, history_backend, error_handler, ui_thread); 398 model_associator, history_backend, error_handler, ui_thread_);
553 return SyncComponents(model_associator, change_processor); 399 return SyncComponents(model_associator, change_processor);
554 } 400 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698