| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "components/signin/core/browser/signin_manager.h" | 5 #include "components/signin/core/browser/signin_manager.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/metrics/histogram.h" | 10 #include "base/metrics/histogram.h" |
| 11 #include "base/prefs/pref_service.h" | 11 #include "base/prefs/pref_service.h" |
| 12 #include "base/strings/string_split.h" | 12 #include "base/strings/string_split.h" |
| 13 #include "base/strings/string_util.h" | 13 #include "base/strings/string_util.h" |
| 14 #include "base/strings/utf_string_conversions.h" | 14 #include "base/strings/utf_string_conversions.h" |
| 15 #include "base/time/time.h" | 15 #include "base/time/time.h" |
| 16 #include "components/signin/core/browser/account_tracker_service.h" |
| 16 #include "components/signin/core/browser/gaia_cookie_manager_service.h" | 17 #include "components/signin/core/browser/gaia_cookie_manager_service.h" |
| 17 #include "components/signin/core/browser/profile_oauth2_token_service.h" | 18 #include "components/signin/core/browser/profile_oauth2_token_service.h" |
| 18 #include "components/signin/core/browser/signin_account_id_helper.h" | |
| 19 #include "components/signin/core/browser/signin_client.h" | 19 #include "components/signin/core/browser/signin_client.h" |
| 20 #include "components/signin/core/browser/signin_internals_util.h" | 20 #include "components/signin/core/browser/signin_internals_util.h" |
| 21 #include "components/signin/core/browser/signin_manager_cookie_helper.h" | 21 #include "components/signin/core/browser/signin_manager_cookie_helper.h" |
| 22 #include "components/signin/core/browser/signin_metrics.h" | 22 #include "components/signin/core/browser/signin_metrics.h" |
| 23 #include "components/signin/core/common/signin_pref_names.h" | 23 #include "components/signin/core/common/signin_pref_names.h" |
| 24 #include "google_apis/gaia/gaia_auth_util.h" | 24 #include "google_apis/gaia/gaia_auth_util.h" |
| 25 #include "google_apis/gaia/gaia_constants.h" | 25 #include "google_apis/gaia/gaia_constants.h" |
| 26 #include "google_apis/gaia/gaia_urls.h" | 26 #include "google_apis/gaia/gaia_urls.h" |
| 27 #include "google_apis/gaia/google_service_auth_error.h" | 27 #include "google_apis/gaia/google_service_auth_error.h" |
| 28 #include "third_party/icu/source/i18n/unicode/regex.h" | 28 #include "third_party/icu/source/i18n/unicode/regex.h" |
| 29 | 29 |
| 30 using namespace signin_internals_util; | 30 using namespace signin_internals_util; |
| 31 | 31 |
| 32 SigninManager::SigninManager(SigninClient* client, | 32 SigninManager::SigninManager(SigninClient* client, |
| 33 ProfileOAuth2TokenService* token_service, | 33 ProfileOAuth2TokenService* token_service, |
| 34 AccountTrackerService* account_tracker_service, | 34 AccountTrackerService* account_tracker_service, |
| 35 GaiaCookieManagerService* cookie_manager_service) | 35 GaiaCookieManagerService* cookie_manager_service) |
| 36 : SigninManagerBase(client), | 36 : SigninManagerBase(client, account_tracker_service), |
| 37 prohibit_signout_(false), | 37 prohibit_signout_(false), |
| 38 type_(SIGNIN_TYPE_NONE), | 38 type_(SIGNIN_TYPE_NONE), |
| 39 client_(client), | 39 client_(client), |
| 40 token_service_(token_service), | 40 token_service_(token_service), |
| 41 account_tracker_service_(account_tracker_service), | |
| 42 cookie_manager_service_(cookie_manager_service), | 41 cookie_manager_service_(cookie_manager_service), |
| 43 signin_manager_signed_in_(false), | 42 signin_manager_signed_in_(false), |
| 44 user_info_fetched_by_account_tracker_(false), | 43 user_info_fetched_by_account_tracker_(false), |
| 45 weak_pointer_factory_(this) {} | 44 weak_pointer_factory_(this) {} |
| 46 | 45 |
| 47 SigninManager::~SigninManager() {} | 46 SigninManager::~SigninManager() {} |
| 48 | 47 |
| 49 void SigninManager::InitTokenService() { | 48 void SigninManager::InitTokenService() { |
| 50 if (token_service_ && IsAuthenticated()) | 49 if (token_service_ && IsAuthenticated()) |
| 51 token_service_->LoadCredentials(GetAuthenticatedAccountId()); | 50 token_service_->LoadCredentials(GetAuthenticatedAccountId()); |
| 52 } | 51 } |
| 53 | 52 |
| 54 std::string SigninManager::SigninTypeToString(SigninManager::SigninType type) { | 53 std::string SigninManager::SigninTypeToString(SigninManager::SigninType type) { |
| 55 switch (type) { | 54 switch (type) { |
| 56 case SIGNIN_TYPE_NONE: | 55 case SIGNIN_TYPE_NONE: |
| 57 return "No Signin"; | 56 return "No Signin"; |
| 58 case SIGNIN_TYPE_WITH_REFRESH_TOKEN: | 57 case SIGNIN_TYPE_WITH_REFRESH_TOKEN: |
| 59 return "With refresh token"; | 58 return "With refresh token"; |
| 60 } | 59 } |
| 61 | 60 |
| 62 NOTREACHED(); | 61 NOTREACHED(); |
| 63 return std::string(); | 62 return std::string(); |
| 64 } | 63 } |
| 65 | 64 |
| 66 bool SigninManager::PrepareForSignin(SigninType type, | 65 bool SigninManager::PrepareForSignin(SigninType type, |
| 66 const std::string& gaia_id, |
| 67 const std::string& username, | 67 const std::string& username, |
| 68 const std::string& password) { | 68 const std::string& password) { |
| 69 DCHECK(possibly_invalid_username_.empty() || | 69 std::string account_id = |
| 70 possibly_invalid_username_ == username); | 70 account_tracker_service()->PickAccountIdForAccount(gaia_id, username); |
| 71 DCHECK(!username.empty()); | 71 DCHECK(possibly_invalid_account_id_.empty() || |
| 72 possibly_invalid_account_id_ == account_id); |
| 73 DCHECK(!account_id.empty()); |
| 72 | 74 |
| 73 if (!IsAllowedUsername(username)) { | 75 if (!IsAllowedUsername(username)) { |
| 74 // Account is not allowed by admin policy. | 76 // Account is not allowed by admin policy. |
| 75 HandleAuthError( | 77 HandleAuthError( |
| 76 GoogleServiceAuthError(GoogleServiceAuthError::ACCOUNT_DISABLED)); | 78 GoogleServiceAuthError(GoogleServiceAuthError::ACCOUNT_DISABLED)); |
| 77 return false; | 79 return false; |
| 78 } | 80 } |
| 79 | 81 |
| 80 // This attempt is either 1) the user trying to establish initial sync, or | 82 // This attempt is either 1) the user trying to establish initial sync, or |
| 81 // 2) trying to refresh credentials for an existing username. If it is 2, we | 83 // 2) trying to refresh credentials for an existing username. If it is 2, we |
| 82 // need to try again, but take care to leave state around tracking that the | 84 // need to try again, but take care to leave state around tracking that the |
| 83 // user has successfully signed in once before with this username, so that on | 85 // user has successfully signed in once before with this username, so that on |
| 84 // restart we don't think sync setup has never completed. | 86 // restart we don't think sync setup has never completed. |
| 85 ClearTransientSigninData(); | 87 ClearTransientSigninData(); |
| 86 type_ = type; | 88 type_ = type; |
| 87 possibly_invalid_username_.assign(username); | 89 possibly_invalid_account_id_.assign(account_id); |
| 90 possibly_invalid_gaia_id_.assign(gaia_id); |
| 91 possibly_invalid_email_.assign(username); |
| 88 password_.assign(password); | 92 password_.assign(password); |
| 89 signin_manager_signed_in_ = false; | 93 signin_manager_signed_in_ = false; |
| 90 user_info_fetched_by_account_tracker_ = false; | 94 user_info_fetched_by_account_tracker_ = false; |
| 91 NotifyDiagnosticsObservers(SIGNIN_STARTED, SigninTypeToString(type)); | 95 NotifyDiagnosticsObservers(SIGNIN_STARTED, SigninTypeToString(type)); |
| 92 return true; | 96 return true; |
| 93 } | 97 } |
| 94 | 98 |
| 95 void SigninManager::StartSignInWithRefreshToken( | 99 void SigninManager::StartSignInWithRefreshToken( |
| 96 const std::string& refresh_token, | 100 const std::string& refresh_token, |
| 101 const std::string& gaia_id, |
| 97 const std::string& username, | 102 const std::string& username, |
| 98 const std::string& password, | 103 const std::string& password, |
| 99 const OAuthTokenFetchedCallback& callback) { | 104 const OAuthTokenFetchedCallback& callback) { |
| 100 DCHECK(!IsAuthenticated() || | 105 DCHECK(!IsAuthenticated()); |
| 101 gaia::AreEmailsSame(username, GetAuthenticatedUsername())); | |
| 102 | 106 |
| 103 if (!PrepareForSignin(SIGNIN_TYPE_WITH_REFRESH_TOKEN, username, password)) | 107 if (!PrepareForSignin(SIGNIN_TYPE_WITH_REFRESH_TOKEN, gaia_id, username, |
| 108 password)) { |
| 104 return; | 109 return; |
| 110 } |
| 105 | 111 |
| 106 // Store our callback and token. | 112 // Store our token. |
| 107 temp_refresh_token_ = refresh_token; | 113 temp_refresh_token_ = refresh_token; |
| 108 possibly_invalid_username_ = username; | |
| 109 | 114 |
| 110 if (!callback.is_null() && !temp_refresh_token_.empty()) { | 115 if (!callback.is_null() && !temp_refresh_token_.empty()) { |
| 111 callback.Run(temp_refresh_token_); | 116 callback.Run(temp_refresh_token_); |
| 112 } else { | 117 } else { |
| 113 // No oauth token or callback, so just complete our pending signin. | 118 // No oauth token or callback, so just complete our pending signin. |
| 114 CompletePendingSignin(); | 119 CompletePendingSignin(); |
| 115 } | 120 } |
| 116 } | 121 } |
| 117 | 122 |
| 118 void SigninManager::CopyCredentialsFrom(const SigninManager& source) { | 123 void SigninManager::CopyCredentialsFrom(const SigninManager& source) { |
| 119 DCHECK_NE(this, &source); | 124 DCHECK_NE(this, &source); |
| 120 possibly_invalid_username_ = source.possibly_invalid_username_; | 125 possibly_invalid_account_id_ = source.possibly_invalid_account_id_; |
| 126 possibly_invalid_gaia_id_ = source.possibly_invalid_gaia_id_; |
| 127 possibly_invalid_email_ = source.possibly_invalid_email_; |
| 121 temp_refresh_token_ = source.temp_refresh_token_; | 128 temp_refresh_token_ = source.temp_refresh_token_; |
| 122 password_ = source.password_; | 129 password_ = source.password_; |
| 123 } | 130 } |
| 124 | 131 |
| 125 void SigninManager::ClearTransientSigninData() { | 132 void SigninManager::ClearTransientSigninData() { |
| 126 DCHECK(IsInitialized()); | 133 DCHECK(IsInitialized()); |
| 127 | 134 |
| 128 possibly_invalid_username_.clear(); | 135 possibly_invalid_account_id_.clear(); |
| 136 possibly_invalid_gaia_id_.clear(); |
| 137 possibly_invalid_email_.clear(); |
| 129 password_.clear(); | 138 password_.clear(); |
| 130 type_ = SIGNIN_TYPE_NONE; | 139 type_ = SIGNIN_TYPE_NONE; |
| 131 temp_refresh_token_.clear(); | 140 temp_refresh_token_.clear(); |
| 132 } | 141 } |
| 133 | 142 |
| 134 void SigninManager::HandleAuthError(const GoogleServiceAuthError& error) { | 143 void SigninManager::HandleAuthError(const GoogleServiceAuthError& error) { |
| 135 ClearTransientSigninData(); | 144 ClearTransientSigninData(); |
| 136 | 145 |
| 137 FOR_EACH_OBSERVER(SigninManagerBase::Observer, | 146 FOR_EACH_OBSERVER(SigninManagerBase::Observer, |
| 138 observer_list_, | 147 observer_list_, |
| (...skipping 26 matching lines...) Expand all Loading... |
| 165 return; | 174 return; |
| 166 } | 175 } |
| 167 | 176 |
| 168 ClearTransientSigninData(); | 177 ClearTransientSigninData(); |
| 169 | 178 |
| 170 const std::string account_id = GetAuthenticatedAccountId(); | 179 const std::string account_id = GetAuthenticatedAccountId(); |
| 171 const std::string username = GetAuthenticatedUsername(); | 180 const std::string username = GetAuthenticatedUsername(); |
| 172 const base::Time signin_time = | 181 const base::Time signin_time = |
| 173 base::Time::FromInternalValue( | 182 base::Time::FromInternalValue( |
| 174 client_->GetPrefs()->GetInt64(prefs::kSignedInTime)); | 183 client_->GetPrefs()->GetInt64(prefs::kSignedInTime)); |
| 175 ClearAuthenticatedUsername(); | 184 clear_authenticated_user(); |
| 176 client_->GetPrefs()->ClearPref(prefs::kGoogleServicesHostedDomain); | 185 client_->GetPrefs()->ClearPref(prefs::kGoogleServicesHostedDomain); |
| 177 client_->GetPrefs()->ClearPref(prefs::kGoogleServicesUsername); | 186 client_->GetPrefs()->ClearPref(prefs::kGoogleServicesAccountId); |
| 187 client_->GetPrefs()->ClearPref(prefs::kGoogleServicesUserAccountId); |
| 178 client_->GetPrefs()->ClearPref(prefs::kSignedInTime); | 188 client_->GetPrefs()->ClearPref(prefs::kSignedInTime); |
| 179 client_->OnSignedOut(); | 189 client_->OnSignedOut(); |
| 180 | 190 |
| 181 // Determine the duration the user was logged in and log that to UMA. | 191 // Determine the duration the user was logged in and log that to UMA. |
| 182 if (!signin_time.is_null()) { | 192 if (!signin_time.is_null()) { |
| 183 base::TimeDelta signed_in_duration = base::Time::Now() - signin_time; | 193 base::TimeDelta signed_in_duration = base::Time::Now() - signin_time; |
| 184 UMA_HISTOGRAM_COUNTS("Signin.SignedInDurationBeforeSignout", | 194 UMA_HISTOGRAM_COUNTS("Signin.SignedInDurationBeforeSignout", |
| 185 signed_in_duration.InMinutes()); | 195 signed_in_duration.InMinutes()); |
| 186 } | 196 } |
| 187 | 197 |
| (...skipping 18 matching lines...) Expand all Loading... |
| 206 local_state_pref_registrar_.Add( | 216 local_state_pref_registrar_.Add( |
| 207 prefs::kGoogleServicesUsernamePattern, | 217 prefs::kGoogleServicesUsernamePattern, |
| 208 base::Bind(&SigninManager::OnGoogleServicesUsernamePatternChanged, | 218 base::Bind(&SigninManager::OnGoogleServicesUsernamePatternChanged, |
| 209 weak_pointer_factory_.GetWeakPtr())); | 219 weak_pointer_factory_.GetWeakPtr())); |
| 210 } | 220 } |
| 211 signin_allowed_.Init(prefs::kSigninAllowed, | 221 signin_allowed_.Init(prefs::kSigninAllowed, |
| 212 client_->GetPrefs(), | 222 client_->GetPrefs(), |
| 213 base::Bind(&SigninManager::OnSigninAllowedPrefChanged, | 223 base::Bind(&SigninManager::OnSigninAllowedPrefChanged, |
| 214 base::Unretained(this))); | 224 base::Unretained(this))); |
| 215 | 225 |
| 216 std::string user = | 226 std::string account_id = |
| 217 client_->GetPrefs()->GetString(prefs::kGoogleServicesUsername); | 227 client_->GetPrefs()->GetString(prefs::kGoogleServicesAccountId); |
| 218 if ((!user.empty() && !IsAllowedUsername(user)) || !IsSigninAllowed()) { | 228 std::string user = account_id.empty() ? std::string() : |
| 229 account_tracker_service()->GetAccountInfo(account_id).email; |
| 230 if ((!account_id.empty() && !IsAllowedUsername(user)) || !IsSigninAllowed()) { |
| 219 // User is signed in, but the username is invalid - the administrator must | 231 // User is signed in, but the username is invalid - the administrator must |
| 220 // have changed the policy since the last signin, so sign out the user. | 232 // have changed the policy since the last signin, so sign out the user. |
| 221 SignOut(signin_metrics::SIGNIN_PREF_CHANGED_DURING_SIGNIN); | 233 SignOut(signin_metrics::SIGNIN_PREF_CHANGED_DURING_SIGNIN); |
| 222 } | 234 } |
| 223 | 235 |
| 224 InitTokenService(); | 236 InitTokenService(); |
| 225 account_id_helper_.reset( | 237 account_tracker_service()->AddObserver(this); |
| 226 new SigninAccountIdHelper(client_, token_service_, this)); | |
| 227 | |
| 228 account_tracker_service_->AddObserver(this); | |
| 229 } | 238 } |
| 230 | 239 |
| 231 void SigninManager::Shutdown() { | 240 void SigninManager::Shutdown() { |
| 232 account_tracker_service_->RemoveObserver(this); | 241 account_tracker_service()->RemoveObserver(this); |
| 233 local_state_pref_registrar_.RemoveAll(); | 242 local_state_pref_registrar_.RemoveAll(); |
| 234 account_id_helper_.reset(); | |
| 235 SigninManagerBase::Shutdown(); | 243 SigninManagerBase::Shutdown(); |
| 236 } | 244 } |
| 237 | 245 |
| 238 void SigninManager::OnGoogleServicesUsernamePatternChanged() { | 246 void SigninManager::OnGoogleServicesUsernamePatternChanged() { |
| 239 if (IsAuthenticated() && | 247 if (IsAuthenticated() && !IsAllowedUsername(GetAuthenticatedUsername())) { |
| 240 !IsAllowedUsername(GetAuthenticatedUsername())) { | |
| 241 // Signed in user is invalid according to the current policy so sign | 248 // Signed in user is invalid according to the current policy so sign |
| 242 // the user out. | 249 // the user out. |
| 243 SignOut(signin_metrics::GOOGLE_SERVICE_NAME_PATTERN_CHANGED); | 250 SignOut(signin_metrics::GOOGLE_SERVICE_NAME_PATTERN_CHANGED); |
| 244 } | 251 } |
| 245 } | 252 } |
| 246 | 253 |
| 247 bool SigninManager::IsSigninAllowed() const { | 254 bool SigninManager::IsSigninAllowed() const { |
| 248 return signin_allowed_.GetValue(); | 255 return signin_allowed_.GetValue(); |
| 249 } | 256 } |
| 250 | 257 |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 290 const PrefService* local_state = local_state_pref_registrar_.prefs(); | 297 const PrefService* local_state = local_state_pref_registrar_.prefs(); |
| 291 if (!local_state) | 298 if (!local_state) |
| 292 return true; // In a unit test with no local state - all names are allowed. | 299 return true; // In a unit test with no local state - all names are allowed. |
| 293 | 300 |
| 294 std::string pattern = | 301 std::string pattern = |
| 295 local_state->GetString(prefs::kGoogleServicesUsernamePattern); | 302 local_state->GetString(prefs::kGoogleServicesUsernamePattern); |
| 296 return IsUsernameAllowedByPolicy(username, pattern); | 303 return IsUsernameAllowedByPolicy(username, pattern); |
| 297 } | 304 } |
| 298 | 305 |
| 299 bool SigninManager::AuthInProgress() const { | 306 bool SigninManager::AuthInProgress() const { |
| 300 return !possibly_invalid_username_.empty(); | 307 return !possibly_invalid_account_id_.empty(); |
| 308 } |
| 309 |
| 310 const std::string& SigninManager::GetAccountIdForAuthInProgress() const { |
| 311 return possibly_invalid_account_id_; |
| 301 } | 312 } |
| 302 | 313 |
| 303 const std::string& SigninManager::GetUsernameForAuthInProgress() const { | 314 const std::string& SigninManager::GetUsernameForAuthInProgress() const { |
| 304 return possibly_invalid_username_; | 315 return possibly_invalid_email_; |
| 305 } | 316 } |
| 306 | 317 |
| 307 void SigninManager::DisableOneClickSignIn(PrefService* prefs) { | 318 void SigninManager::DisableOneClickSignIn(PrefService* prefs) { |
| 308 prefs->SetBoolean(prefs::kReverseAutologinEnabled, false); | 319 prefs->SetBoolean(prefs::kReverseAutologinEnabled, false); |
| 309 } | 320 } |
| 310 | 321 |
| 311 void SigninManager::MergeSigninCredentialIntoCookieJar() { | 322 void SigninManager::MergeSigninCredentialIntoCookieJar() { |
| 312 if (!client_->ShouldMergeSigninCredentialsIntoCookieJar()) | 323 if (!client_->ShouldMergeSigninCredentialsIntoCookieJar()) |
| 313 return; | 324 return; |
| 314 | 325 |
| 315 if (!IsAuthenticated()) | 326 if (!IsAuthenticated()) |
| 316 return; | 327 return; |
| 317 | 328 |
| 318 cookie_manager_service_->AddAccountToCookie(GetAuthenticatedAccountId()); | 329 cookie_manager_service_->AddAccountToCookie(GetAuthenticatedAccountId()); |
| 319 } | 330 } |
| 320 | 331 |
| 321 void SigninManager::CompletePendingSignin() { | 332 void SigninManager::CompletePendingSignin() { |
| 322 NotifyDiagnosticsObservers(SIGNIN_COMPLETED, "Successful"); | 333 NotifyDiagnosticsObservers(SIGNIN_COMPLETED, "Successful"); |
| 323 | 334 DCHECK(!possibly_invalid_account_id_.empty()); |
| 324 DCHECK(!possibly_invalid_username_.empty()); | 335 OnSignedIn(); |
| 325 OnSignedIn(possibly_invalid_username_); | |
| 326 | 336 |
| 327 DCHECK(!temp_refresh_token_.empty()); | 337 DCHECK(!temp_refresh_token_.empty()); |
| 328 DCHECK(IsAuthenticated()); | 338 DCHECK(IsAuthenticated()); |
| 329 token_service_->UpdateCredentials(GetAuthenticatedAccountId(), | 339 |
| 330 temp_refresh_token_); | 340 std::string account_id = GetAuthenticatedAccountId(); |
| 341 token_service_->UpdateCredentials(account_id, temp_refresh_token_); |
| 331 temp_refresh_token_.clear(); | 342 temp_refresh_token_.clear(); |
| 332 | 343 |
| 333 MergeSigninCredentialIntoCookieJar(); | 344 MergeSigninCredentialIntoCookieJar(); |
| 334 } | 345 } |
| 335 | 346 |
| 336 void SigninManager::OnExternalSigninCompleted(const std::string& username) { | 347 void SigninManager::OnExternalSigninCompleted(const std::string& username) { |
| 337 OnSignedIn(username); | 348 AccountTrackerService::AccountInfo info = |
| 349 account_tracker_service()->FindAccountInfoByEmail(username); |
| 350 DCHECK(!info.gaia.empty()); |
| 351 DCHECK(!info.email.empty()); |
| 352 possibly_invalid_account_id_ = info.account_id; |
| 353 possibly_invalid_gaia_id_ = info.gaia; |
| 354 possibly_invalid_email_ = info.email; |
| 355 OnSignedIn(); |
| 338 } | 356 } |
| 339 | 357 |
| 340 void SigninManager::OnSignedIn(const std::string& username) { | 358 void SigninManager::OnSignedIn() { |
| 341 client_->GetPrefs()->SetInt64(prefs::kSignedInTime, | 359 client_->GetPrefs()->SetInt64(prefs::kSignedInTime, |
| 342 base::Time::Now().ToInternalValue()); | 360 base::Time::Now().ToInternalValue()); |
| 343 SetAuthenticatedUsername(username); | 361 SetAuthenticatedAccountInfo(possibly_invalid_gaia_id_, |
| 344 possibly_invalid_username_.clear(); | 362 possibly_invalid_email_); |
| 363 possibly_invalid_account_id_.clear(); |
| 364 possibly_invalid_gaia_id_.clear(); |
| 365 possibly_invalid_email_.clear(); |
| 345 signin_manager_signed_in_ = true; | 366 signin_manager_signed_in_ = true; |
| 346 | 367 |
| 347 FOR_EACH_OBSERVER( | 368 FOR_EACH_OBSERVER( |
| 348 SigninManagerBase::Observer, | 369 SigninManagerBase::Observer, |
| 349 observer_list_, | 370 observer_list_, |
| 350 GoogleSigninSucceeded(GetAuthenticatedAccountId(), | 371 GoogleSigninSucceeded(GetAuthenticatedAccountId(), |
| 351 GetAuthenticatedUsername(), | 372 GetAuthenticatedUsername(), |
| 352 password_)); | 373 password_)); |
| 353 | 374 |
| 354 client_->OnSignedIn(GetAuthenticatedAccountId(), | 375 client_->OnSignedIn(GetAuthenticatedAccountId(), |
| (...skipping 27 matching lines...) Expand all Loading... |
| 382 void SigninManager::OnAccountUpdateFailed(const std::string& account_id) { | 403 void SigninManager::OnAccountUpdateFailed(const std::string& account_id) { |
| 383 user_info_fetched_by_account_tracker_ = true; | 404 user_info_fetched_by_account_tracker_ = true; |
| 384 PostSignedIn(); | 405 PostSignedIn(); |
| 385 } | 406 } |
| 386 | 407 |
| 387 void SigninManager::ProhibitSignout(bool prohibit_signout) { | 408 void SigninManager::ProhibitSignout(bool prohibit_signout) { |
| 388 prohibit_signout_ = prohibit_signout; | 409 prohibit_signout_ = prohibit_signout; |
| 389 } | 410 } |
| 390 | 411 |
| 391 bool SigninManager::IsSignoutProhibited() const { return prohibit_signout_; } | 412 bool SigninManager::IsSignoutProhibited() const { return prohibit_signout_; } |
| OLD | NEW |