OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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_service.h" | 5 #include "chrome/browser/sync/profile_sync_service.h" |
6 | 6 |
7 #include <map> | 7 #include <map> |
8 #include <set> | 8 #include <set> |
9 | 9 |
10 #include "app/l10n_util.h" | 10 #include "app/l10n_util.h" |
11 #include "base/basictypes.h" | 11 #include "base/basictypes.h" |
12 #include "base/callback.h" | 12 #include "base/callback.h" |
13 #include "base/command_line.h" | 13 #include "base/command_line.h" |
14 #include "base/logging.h" | 14 #include "base/logging.h" |
15 #include "base/metrics/histogram.h" | 15 #include "base/metrics/histogram.h" |
16 #include "base/stl_util-inl.h" | 16 #include "base/stl_util-inl.h" |
17 #include "base/string16.h" | 17 #include "base/string16.h" |
18 #include "base/string_number_conversions.h" | 18 #include "base/string_number_conversions.h" |
19 #include "base/string_util.h" | 19 #include "base/string_util.h" |
20 #include "base/task.h" | 20 #include "base/task.h" |
21 #include "base/utf_string_conversions.h" | 21 #include "base/utf_string_conversions.h" |
22 #include "chrome/browser/browser_thread.h" | 22 #include "chrome/browser/browser_thread.h" |
23 #include "chrome/browser/history/history_types.h" | 23 #include "chrome/browser/history/history_types.h" |
24 #include "chrome/browser/platform_util.h" | 24 #include "chrome/browser/platform_util.h" |
25 #include "chrome/browser/prefs/pref_service.h" | 25 #include "chrome/browser/prefs/pref_service.h" |
26 #include "chrome/browser/profiles/profile.h" | 26 #include "chrome/browser/profiles/profile.h" |
27 #include "chrome/browser/net/gaia/token_service.h" | 27 #include "chrome/browser/net/gaia/token_service.h" |
| 28 #include "chrome/browser/sync/glue/autofill_profile_data_type_controller.h" |
28 #include "chrome/browser/sync/glue/change_processor.h" | 29 #include "chrome/browser/sync/glue/change_processor.h" |
29 #include "chrome/browser/sync/glue/data_type_controller.h" | 30 #include "chrome/browser/sync/glue/data_type_controller.h" |
30 #include "chrome/browser/sync/glue/data_type_manager.h" | 31 #include "chrome/browser/sync/glue/data_type_manager.h" |
31 #include "chrome/browser/sync/glue/session_data_type_controller.h" | 32 #include "chrome/browser/sync/glue/session_data_type_controller.h" |
32 #include "chrome/browser/sync/profile_sync_factory.h" | 33 #include "chrome/browser/sync/profile_sync_factory.h" |
33 #include "chrome/browser/sync/signin_manager.h" | 34 #include "chrome/browser/sync/signin_manager.h" |
34 #include "chrome/browser/sync/token_migrator.h" | 35 #include "chrome/browser/sync/token_migrator.h" |
35 #include "chrome/common/chrome_switches.h" | 36 #include "chrome/common/chrome_switches.h" |
36 #include "chrome/common/net/gaia/gaia_constants.h" | 37 #include "chrome/common/net/gaia/gaia_constants.h" |
37 #include "chrome/common/notification_details.h" | 38 #include "chrome/common/notification_details.h" |
(...skipping 324 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
362 pref_service->RegisterBooleanPref(prefs::kSyncAutofill, enable_by_default); | 363 pref_service->RegisterBooleanPref(prefs::kSyncAutofill, enable_by_default); |
363 pref_service->RegisterBooleanPref(prefs::kSyncThemes, enable_by_default); | 364 pref_service->RegisterBooleanPref(prefs::kSyncThemes, enable_by_default); |
364 pref_service->RegisterBooleanPref(prefs::kSyncTypedUrls, enable_by_default); | 365 pref_service->RegisterBooleanPref(prefs::kSyncTypedUrls, enable_by_default); |
365 pref_service->RegisterBooleanPref(prefs::kSyncExtensions, enable_by_default); | 366 pref_service->RegisterBooleanPref(prefs::kSyncExtensions, enable_by_default); |
366 pref_service->RegisterBooleanPref(prefs::kSyncApps, enable_by_default); | 367 pref_service->RegisterBooleanPref(prefs::kSyncApps, enable_by_default); |
367 pref_service->RegisterBooleanPref(prefs::kSyncSessions, enable_by_default); | 368 pref_service->RegisterBooleanPref(prefs::kSyncSessions, enable_by_default); |
368 pref_service->RegisterBooleanPref(prefs::kKeepEverythingSynced, | 369 pref_service->RegisterBooleanPref(prefs::kKeepEverythingSynced, |
369 enable_by_default); | 370 enable_by_default); |
370 pref_service->RegisterBooleanPref(prefs::kSyncManaged, false); | 371 pref_service->RegisterBooleanPref(prefs::kSyncManaged, false); |
371 pref_service->RegisterStringPref(prefs::kEncryptionBootstrapToken, ""); | 372 pref_service->RegisterStringPref(prefs::kEncryptionBootstrapToken, ""); |
| 373 |
| 374 pref_service->RegisterBooleanPref(prefs::kSyncAutofillProfile, |
| 375 enable_by_default); |
372 } | 376 } |
373 | 377 |
374 void ProfileSyncService::ClearPreferences() { | 378 void ProfileSyncService::ClearPreferences() { |
375 PrefService* pref_service = profile_->GetPrefs(); | 379 PrefService* pref_service = profile_->GetPrefs(); |
376 pref_service->ClearPref(prefs::kSyncLastSyncedTime); | 380 pref_service->ClearPref(prefs::kSyncLastSyncedTime); |
377 pref_service->ClearPref(prefs::kSyncHasSetupCompleted); | 381 pref_service->ClearPref(prefs::kSyncHasSetupCompleted); |
378 pref_service->ClearPref(prefs::kEncryptionBootstrapToken); | 382 pref_service->ClearPref(prefs::kEncryptionBootstrapToken); |
379 | 383 |
380 // TODO(nick): The current behavior does not clear e.g. prefs::kSyncBookmarks. | 384 // TODO(nick): The current behavior does not clear e.g. prefs::kSyncBookmarks. |
381 // Is that really what we want? | 385 // Is that really what we want? |
(...skipping 162 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
544 syncable::ModelType data_type) { | 548 syncable::ModelType data_type) { |
545 switch (data_type) { | 549 switch (data_type) { |
546 case syncable::BOOKMARKS: | 550 case syncable::BOOKMARKS: |
547 return prefs::kSyncBookmarks; | 551 return prefs::kSyncBookmarks; |
548 case syncable::PASSWORDS: | 552 case syncable::PASSWORDS: |
549 return prefs::kSyncPasswords; | 553 return prefs::kSyncPasswords; |
550 case syncable::PREFERENCES: | 554 case syncable::PREFERENCES: |
551 return prefs::kSyncPreferences; | 555 return prefs::kSyncPreferences; |
552 case syncable::AUTOFILL: | 556 case syncable::AUTOFILL: |
553 return prefs::kSyncAutofill; | 557 return prefs::kSyncAutofill; |
| 558 case syncable::AUTOFILL_PROFILE: |
| 559 return prefs::kSyncAutofillProfile; |
| 560 break; |
554 case syncable::THEMES: | 561 case syncable::THEMES: |
555 return prefs::kSyncThemes; | 562 return prefs::kSyncThemes; |
556 case syncable::TYPED_URLS: | 563 case syncable::TYPED_URLS: |
557 return prefs::kSyncTypedUrls; | 564 return prefs::kSyncTypedUrls; |
558 case syncable::EXTENSIONS: | 565 case syncable::EXTENSIONS: |
559 return prefs::kSyncExtensions; | 566 return prefs::kSyncExtensions; |
560 case syncable::APPS: | 567 case syncable::APPS: |
561 return prefs::kSyncApps; | 568 return prefs::kSyncApps; |
562 case syncable::SESSIONS: | 569 case syncable::SESSIONS: |
563 return prefs::kSyncSessions; | 570 return prefs::kSyncSessions; |
(...skipping 309 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
873 GetRegisteredDataTypes(®istered_types); | 880 GetRegisteredDataTypes(®istered_types); |
874 for (int i = 0; i < syncable::MODEL_TYPE_COUNT; ++i) { | 881 for (int i = 0; i < syncable::MODEL_TYPE_COUNT; ++i) { |
875 syncable::ModelType model_type = syncable::ModelTypeFromInt(i); | 882 syncable::ModelType model_type = syncable::ModelTypeFromInt(i); |
876 if (!registered_types.count(model_type)) | 883 if (!registered_types.count(model_type)) |
877 continue; | 884 continue; |
878 const char* pref_name = GetPrefNameForDataType(model_type); | 885 const char* pref_name = GetPrefNameForDataType(model_type); |
879 if (!pref_name) | 886 if (!pref_name) |
880 continue; | 887 continue; |
881 profile_->GetPrefs()->SetBoolean(pref_name, | 888 profile_->GetPrefs()->SetBoolean(pref_name, |
882 preferred_types.count(model_type) != 0); | 889 preferred_types.count(model_type) != 0); |
| 890 if (syncable::AUTOFILL == model_type) { |
| 891 profile_->GetPrefs()->SetBoolean(prefs::kSyncAutofillProfile, |
| 892 preferred_types.count(model_type) != 0); |
| 893 } |
883 } | 894 } |
884 | 895 |
885 // If we haven't initialized yet, don't configure the DTM as it could cause | 896 // If we haven't initialized yet, don't configure the DTM as it could cause |
886 // association to start before a Directory has even been created. | 897 // association to start before a Directory has even been created. |
887 if (backend_initialized_) | 898 if (backend_initialized_) |
888 ConfigureDataTypeManager(); | 899 ConfigureDataTypeManager(); |
889 } | 900 } |
890 | 901 |
891 void ProfileSyncService::GetPreferredDataTypes( | 902 void ProfileSyncService::GetPreferredDataTypes( |
892 syncable::ModelTypeSet* preferred_types) const { | 903 syncable::ModelTypeSet* preferred_types) const { |
893 preferred_types->clear(); | 904 preferred_types->clear(); |
894 | |
895 // Filter out any datatypes which aren't registered, or for which | |
896 // the preference can't be read. | |
897 syncable::ModelTypeSet registered_types; | |
898 GetRegisteredDataTypes(®istered_types); | |
899 if (profile_->GetPrefs()->GetBoolean(prefs::kKeepEverythingSynced)) { | 905 if (profile_->GetPrefs()->GetBoolean(prefs::kKeepEverythingSynced)) { |
900 *preferred_types = registered_types; | 906 GetRegisteredDataTypes(preferred_types); |
901 } else { | 907 } else { |
| 908 // Filter out any datatypes which aren't registered, or for which |
| 909 // the preference can't be read. |
| 910 syncable::ModelTypeSet registered_types; |
| 911 GetRegisteredDataTypes(®istered_types); |
902 for (int i = 0; i < syncable::MODEL_TYPE_COUNT; ++i) { | 912 for (int i = 0; i < syncable::MODEL_TYPE_COUNT; ++i) { |
903 syncable::ModelType model_type = syncable::ModelTypeFromInt(i); | 913 syncable::ModelType model_type = syncable::ModelTypeFromInt(i); |
904 if (!registered_types.count(model_type)) | 914 if (!registered_types.count(model_type)) |
905 continue; | 915 continue; |
| 916 if (model_type == syncable::AUTOFILL_PROFILE) |
| 917 continue; |
906 const char* pref_name = GetPrefNameForDataType(model_type); | 918 const char* pref_name = GetPrefNameForDataType(model_type); |
907 if (!pref_name) | 919 if (!pref_name) |
908 continue; | 920 continue; |
909 if (profile_->GetPrefs()->GetBoolean(pref_name)) | 921 |
| 922 // We are trying to groupd autofill_profile tag with the same |
| 923 // enabled/disabled state as autofill. Because the UI only shows autofill. |
| 924 if (profile_->GetPrefs()->GetBoolean(pref_name)) { |
910 preferred_types->insert(model_type); | 925 preferred_types->insert(model_type); |
| 926 if (model_type == syncable::AUTOFILL) { |
| 927 if (!registered_types.count(syncable::AUTOFILL_PROFILE)) |
| 928 continue; |
| 929 preferred_types->insert(syncable::AUTOFILL_PROFILE); |
| 930 } |
| 931 } |
911 } | 932 } |
912 } | 933 } |
913 } | 934 } |
914 | 935 |
915 void ProfileSyncService::GetRegisteredDataTypes( | 936 void ProfileSyncService::GetRegisteredDataTypes( |
916 syncable::ModelTypeSet* registered_types) const { | 937 syncable::ModelTypeSet* registered_types) const { |
917 registered_types->clear(); | 938 registered_types->clear(); |
918 // The data_type_controllers_ are determined by command-line flags; that's | 939 // The data_type_controllers_ are determined by command-line flags; that's |
919 // effectively what controls the values returned here. | 940 // effectively what controls the values returned here. |
920 for (DataTypeController::TypeMap::const_iterator it = | 941 for (DataTypeController::TypeMap::const_iterator it = |
(...skipping 228 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1149 // is initialized, all enabled data types are consistent with one | 1170 // is initialized, all enabled data types are consistent with one |
1150 // another, and no unrecoverable error has transpired. | 1171 // another, and no unrecoverable error has transpired. |
1151 if (unrecoverable_error_detected_) | 1172 if (unrecoverable_error_detected_) |
1152 return false; | 1173 return false; |
1153 | 1174 |
1154 if (!data_type_manager_.get()) | 1175 if (!data_type_manager_.get()) |
1155 return false; | 1176 return false; |
1156 | 1177 |
1157 return data_type_manager_->state() == DataTypeManager::CONFIGURED; | 1178 return data_type_manager_->state() == DataTypeManager::CONFIGURED; |
1158 } | 1179 } |
OLD | NEW |