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

Side by Side Diff: chrome/browser/sync/profile_sync_service.cc

Issue 6309002: Further tweaks to the passphrase UI to deal with passphrase entry.... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years, 11 months 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 | Annotate | Revision Log
OLDNEW
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"
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after
59 59
60 const char* ProfileSyncService::kDevServerUrl = 60 const char* ProfileSyncService::kDevServerUrl =
61 "https://clients4.google.com/chrome-sync/dev"; 61 "https://clients4.google.com/chrome-sync/dev";
62 62
63 static const int kSyncClearDataTimeoutInSeconds = 60; // 1 minute. 63 static const int kSyncClearDataTimeoutInSeconds = 60; // 1 minute.
64 64
65 ProfileSyncService::ProfileSyncService(ProfileSyncFactory* factory, 65 ProfileSyncService::ProfileSyncService(ProfileSyncFactory* factory,
66 Profile* profile, 66 Profile* profile,
67 const std::string& cros_user) 67 const std::string& cros_user)
68 : last_auth_error_(AuthError::None()), 68 : last_auth_error_(AuthError::None()),
69 tried_creating_explicit_passphrase_(false),
70 tried_setting_explicit_passphrase_(false),
69 observed_passphrase_required_(false), 71 observed_passphrase_required_(false),
70 passphrase_required_for_decryption_(false), 72 passphrase_required_for_decryption_(false),
71 factory_(factory), 73 factory_(factory),
72 profile_(profile), 74 profile_(profile),
73 cros_user_(cros_user), 75 cros_user_(cros_user),
74 sync_service_url_(kDevServerUrl), 76 sync_service_url_(kDevServerUrl),
75 backend_initialized_(false), 77 backend_initialized_(false),
76 is_auth_in_progress_(false), 78 is_auth_in_progress_(false),
77 ALLOW_THIS_IN_INITIALIZER_LIST(wizard_(this)), 79 ALLOW_THIS_IN_INITIALIZER_LIST(wizard_(this)),
78 unrecoverable_error_detected_(false), 80 unrecoverable_error_detected_(false),
(...skipping 933 matching lines...) Expand 10 before | Expand all | Expand 10 after
1012 1014
1013 void ProfileSyncService::DeactivateDataType( 1015 void ProfileSyncService::DeactivateDataType(
1014 DataTypeController* data_type_controller, 1016 DataTypeController* data_type_controller,
1015 ChangeProcessor* change_processor) { 1017 ChangeProcessor* change_processor) {
1016 change_processor->Stop(); 1018 change_processor->Stop();
1017 if (backend_.get()) 1019 if (backend_.get())
1018 backend_->DeactivateDataType(data_type_controller, change_processor); 1020 backend_->DeactivateDataType(data_type_controller, change_processor);
1019 } 1021 }
1020 1022
1021 void ProfileSyncService::SetPassphrase(const std::string& passphrase, 1023 void ProfileSyncService::SetPassphrase(const std::string& passphrase,
1022 bool is_explicit) { 1024 bool is_explicit,
1025 bool is_creation) {
1023 if (ShouldPushChanges() || observed_passphrase_required_) { 1026 if (ShouldPushChanges() || observed_passphrase_required_) {
1024 backend_->SetPassphrase(passphrase, is_explicit); 1027 backend_->SetPassphrase(passphrase, is_explicit);
1025 } else { 1028 } else {
1026 cached_passphrase_.value = passphrase; 1029 cached_passphrase_.value = passphrase;
1027 cached_passphrase_.is_explicit = is_explicit; 1030 cached_passphrase_.is_explicit = is_explicit;
1031 cached_passphrase_.is_creation = is_creation;
1028 } 1032 }
1033
1034 if (is_explicit && is_creation)
1035 tried_creating_explicit_passphrase_ = true;
1036 else if (is_explicit)
1037 tried_setting_explicit_passphrase_ = true;
1029 } 1038 }
1030 1039
1031 void ProfileSyncService::Observe(NotificationType type, 1040 void ProfileSyncService::Observe(NotificationType type,
1032 const NotificationSource& source, 1041 const NotificationSource& source,
1033 const NotificationDetails& details) { 1042 const NotificationDetails& details) {
1034 switch (type.value) { 1043 switch (type.value) {
1035 case NotificationType::SYNC_CONFIGURE_START: { 1044 case NotificationType::SYNC_CONFIGURE_START: {
1036 FOR_EACH_OBSERVER(Observer, observers_, OnStateChanged()); 1045 FOR_EACH_OBSERVER(Observer, observers_, OnStateChanged());
1037 // TODO(sync): Maybe toast? 1046 // TODO(sync): Maybe toast?
1038 break; 1047 break;
1039 } 1048 }
1040 case NotificationType::SYNC_CONFIGURE_DONE: { 1049 case NotificationType::SYNC_CONFIGURE_DONE: {
1041 DataTypeManager::ConfigureResult result = 1050 DataTypeManager::ConfigureResult result =
1042 *(Details<DataTypeManager::ConfigureResult>(details).ptr()); 1051 *(Details<DataTypeManager::ConfigureResult>(details).ptr());
1043 if (result == DataTypeManager::ABORTED && 1052 if (result == DataTypeManager::ABORTED &&
1044 expect_sync_configuration_aborted_) { 1053 expect_sync_configuration_aborted_) {
1045 expect_sync_configuration_aborted_ = false; 1054 expect_sync_configuration_aborted_ = false;
1046 return; 1055 return;
1047 } 1056 }
1048 if (result != DataTypeManager::OK) { 1057 if (result != DataTypeManager::OK) {
1049 OnUnrecoverableError(FROM_HERE, "Sync Configuration failed."); 1058 OnUnrecoverableError(FROM_HERE, "Sync Configuration failed.");
1050 return; 1059 return;
1051 } 1060 }
1052 1061
1053 if (!cached_passphrase_.value.empty()) { 1062 if (!cached_passphrase_.value.empty()) {
1054 // Don't hold on to the passphrase in raw form longer than needed. 1063 // Don't hold on to the passphrase in raw form longer than needed.
1055 SetPassphrase(cached_passphrase_.value, 1064 SetPassphrase(cached_passphrase_.value,
1056 cached_passphrase_.is_explicit); 1065 cached_passphrase_.is_explicit,
1066 cached_passphrase_.is_creation);
1057 cached_passphrase_ = CachedPassphrase(); 1067 cached_passphrase_ = CachedPassphrase();
1058 } 1068 }
1059 1069
1060 // TODO(sync): Less wizard, more toast. 1070 // TODO(sync): Less wizard, more toast.
1061 if (!observed_passphrase_required_) 1071 if (!observed_passphrase_required_)
1062 wizard_.Step(SyncSetupWizard::DONE); 1072 wizard_.Step(SyncSetupWizard::DONE);
1063 FOR_EACH_OBSERVER(Observer, observers_, OnStateChanged()); 1073 FOR_EACH_OBSERVER(Observer, observers_, OnStateChanged());
1064 1074
1065 break; 1075 break;
1066 } 1076 }
1067 case NotificationType::SYNC_PASSPHRASE_REQUIRED: { 1077 case NotificationType::SYNC_PASSPHRASE_REQUIRED: {
1068 DCHECK(backend_.get()); 1078 DCHECK(backend_.get());
1069 DCHECK(backend_->IsNigoriEnabled()); 1079 DCHECK(backend_->IsNigoriEnabled());
1070 observed_passphrase_required_ = true; 1080 observed_passphrase_required_ = true;
1071 passphrase_required_for_decryption_ = *(Details<bool>(details).ptr()); 1081 passphrase_required_for_decryption_ = *(Details<bool>(details).ptr());
1072 1082
1073 if (!cached_passphrase_.value.empty()) { 1083 if (!cached_passphrase_.value.empty()) {
1074 SetPassphrase(cached_passphrase_.value, 1084 SetPassphrase(cached_passphrase_.value,
1075 cached_passphrase_.is_explicit); 1085 cached_passphrase_.is_explicit,
1086 cached_passphrase_.is_creation);
1076 cached_passphrase_ = CachedPassphrase(); 1087 cached_passphrase_ = CachedPassphrase();
1077 break; 1088 break;
1078 } 1089 }
1079 1090
1080 if (WizardIsVisible()) { 1091 if (WizardIsVisible()) {
1081 wizard_.Step(SyncSetupWizard::ENTER_PASSPHRASE); 1092 wizard_.Step(SyncSetupWizard::ENTER_PASSPHRASE);
1082 } 1093 }
1083 1094
1084 FOR_EACH_OBSERVER(Observer, observers_, OnStateChanged()); 1095 FOR_EACH_OBSERVER(Observer, observers_, OnStateChanged());
1085 break; 1096 break;
1086 } 1097 }
1087 case NotificationType::SYNC_DATA_TYPES_UPDATED: { 1098 case NotificationType::SYNC_DATA_TYPES_UPDATED: {
1088 if (!HasSyncSetupCompleted()) break; 1099 if (!HasSyncSetupCompleted()) break;
1089 1100
1090 syncable::ModelTypeSet types; 1101 syncable::ModelTypeSet types;
1091 GetPreferredDataTypes(&types); 1102 GetPreferredDataTypes(&types);
1092 OnUserChoseDatatypes(false, types); 1103 OnUserChoseDatatypes(false, types);
1093 break; 1104 break;
1094 } 1105 }
1095 case NotificationType::SYNC_PASSPHRASE_ACCEPTED: { 1106 case NotificationType::SYNC_PASSPHRASE_ACCEPTED: {
1096 // Make sure the data types that depend on the passphrase are started at 1107 // Make sure the data types that depend on the passphrase are started at
1097 // this time. 1108 // this time.
1098 syncable::ModelTypeSet types; 1109 syncable::ModelTypeSet types;
1099 GetPreferredDataTypes(&types); 1110 GetPreferredDataTypes(&types);
1100 data_type_manager_->Configure(types); 1111 data_type_manager_->Configure(types);
1101 1112
1102 FOR_EACH_OBSERVER(Observer, observers_, OnStateChanged()); 1113 FOR_EACH_OBSERVER(Observer, observers_, OnStateChanged());
1103 observed_passphrase_required_ = false; 1114 observed_passphrase_required_ = false;
1115 tried_setting_explicit_passphrase_ = false;
1116 tried_creating_explicit_passphrase_ = false;
1104 1117
1105 wizard_.Step(SyncSetupWizard::DONE); 1118 wizard_.Step(SyncSetupWizard::DONE);
1106 break; 1119 break;
1107 } 1120 }
1108 case NotificationType::PREF_CHANGED: { 1121 case NotificationType::PREF_CHANGED: {
1109 std::string* pref_name = Details<std::string>(details).ptr(); 1122 std::string* pref_name = Details<std::string>(details).ptr();
1110 if (*pref_name == prefs::kSyncManaged) { 1123 if (*pref_name == prefs::kSyncManaged) {
1111 FOR_EACH_OBSERVER(Observer, observers_, OnStateChanged()); 1124 FOR_EACH_OBSERVER(Observer, observers_, OnStateChanged());
1112 if (*pref_sync_managed_) { 1125 if (*pref_sync_managed_) {
1113 DisableForUser(); 1126 DisableForUser();
1114 } else if (HasSyncSetupCompleted() && AreCredentialsAvailable()) { 1127 } else if (HasSyncSetupCompleted() && AreCredentialsAvailable()) {
1115 StartUp(); 1128 StartUp();
1116 } 1129 }
1117 } 1130 }
1118 break; 1131 break;
1119 } 1132 }
1120 case NotificationType::GOOGLE_SIGNIN_SUCCESSFUL: { 1133 case NotificationType::GOOGLE_SIGNIN_SUCCESSFUL: {
1121 const GoogleServiceSigninSuccessDetails* successful = 1134 const GoogleServiceSigninSuccessDetails* successful =
1122 (Details<const GoogleServiceSigninSuccessDetails>(details).ptr()); 1135 (Details<const GoogleServiceSigninSuccessDetails>(details).ptr());
1123 // We pass 'false' to SetPassphrase to denote that this is an implicit 1136 // We pass 'false' to SetPassphrase to denote that this is an implicit
1124 // request and shouldn't override an explicit one. Thus, we either 1137 // request and shouldn't override an explicit one. Thus, we either
1125 // update the implicit passphrase (idempotent if the passphrase didn't 1138 // update the implicit passphrase (idempotent if the passphrase didn't
1126 // actually change), or the user has an explicit passphrase set so this 1139 // actually change), or the user has an explicit passphrase set so this
1127 // becomes a no-op. 1140 // becomes a no-op.
1128 tried_implicit_gaia_remove_when_bug_62103_fixed_ = true; 1141 tried_implicit_gaia_remove_when_bug_62103_fixed_ = true;
1129 SetPassphrase(successful->password, false); 1142 SetPassphrase(successful->password, false, true);
1130 break; 1143 break;
1131 } 1144 }
1132 case NotificationType::GOOGLE_SIGNIN_FAILED: { 1145 case NotificationType::GOOGLE_SIGNIN_FAILED: {
1133 GoogleServiceAuthError error = 1146 GoogleServiceAuthError error =
1134 *(Details<const GoogleServiceAuthError>(details).ptr()); 1147 *(Details<const GoogleServiceAuthError>(details).ptr());
1135 UpdateAuthErrorState(error); 1148 UpdateAuthErrorState(error);
1136 break; 1149 break;
1137 } 1150 }
1138 case NotificationType::TOKEN_AVAILABLE: { 1151 case NotificationType::TOKEN_AVAILABLE: {
1139 if (AreCredentialsAvailable()) { 1152 if (AreCredentialsAvailable()) {
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after
1216 // is initialized, all enabled data types are consistent with one 1229 // is initialized, all enabled data types are consistent with one
1217 // another, and no unrecoverable error has transpired. 1230 // another, and no unrecoverable error has transpired.
1218 if (unrecoverable_error_detected_) 1231 if (unrecoverable_error_detected_)
1219 return false; 1232 return false;
1220 1233
1221 if (!data_type_manager_.get()) 1234 if (!data_type_manager_.get())
1222 return false; 1235 return false;
1223 1236
1224 return data_type_manager_->state() == DataTypeManager::CONFIGURED; 1237 return data_type_manager_->state() == DataTypeManager::CONFIGURED;
1225 } 1238 }
OLDNEW
« no previous file with comments | « chrome/browser/sync/profile_sync_service.h ('k') | chrome/browser/sync/profile_sync_service_password_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698