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