Index: chrome/browser/sync/profile_sync_components_factory_impl.cc |
diff --git a/chrome/browser/sync/profile_sync_components_factory_impl.cc b/chrome/browser/sync/profile_sync_components_factory_impl.cc |
index 0ca11172e14ab9f27abfb1793f0e7bbecaa74d2d..2c469aca1c60ca259b2ae25d5a28865e9edc1df2 100644 |
--- a/chrome/browser/sync/profile_sync_components_factory_impl.cc |
+++ b/chrome/browser/sync/profile_sync_components_factory_impl.cc |
@@ -95,6 +95,11 @@ |
#include "chrome/browser/spellchecker/spellcheck_service.h" |
#endif |
+#if defined(OS_CHROMEOS) |
+#include "components/wifi_sync/wifi_credential_syncable_service.h" |
+#include "components/wifi_sync/wifi_credential_syncable_service_factory.h" |
+#endif |
+ |
using browser_sync::AutofillDataTypeController; |
using browser_sync::AutofillProfileDataTypeController; |
using browser_sync::BookmarkChangeProcessor; |
@@ -392,6 +397,18 @@ void ProfileSyncComponentsFactoryImpl::RegisterDesktopDataTypes( |
this, |
profile_)); |
#endif |
+ |
+#if defined(OS_CHROMEOS) |
+ if (command_line_->HasSwitch(switches::kEnableWifiCredentialSync) && |
+ !disabled_types.Has(syncer::WIFI_CREDENTIALS)) { |
+ pss->RegisterDataTypeController( |
+ new UIDataTypeController( |
+ BrowserThread::GetMessageLoopProxyForThread(BrowserThread::UI), |
+ base::Bind(&ChromeReportUnrecoverableError), |
+ syncer::WIFI_CREDENTIALS, |
+ this)); |
+ } |
+#endif |
} |
DataTypeManager* ProfileSyncComponentsFactoryImpl::CreateDataTypeManager( |
@@ -528,6 +545,11 @@ base::WeakPtr<syncer::SyncableService> ProfileSyncComponentsFactoryImpl:: |
return base::WeakPtr<syncer::SyncableService>(); |
#endif |
} |
+#if defined(OS_CHROMEOS) |
+ case syncer::WIFI_CREDENTIALS: |
+ return wifi_sync::WifiCredentialSyncableServiceFactory:: |
+ GetForBrowserContext(profile_)->AsWeakPtr(); |
+#endif |
default: |
// The following datatypes still need to be transitioned to the |
// syncer::SyncableService API: |