| 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_macros.h" | 10 #include "base/metrics/histogram_macros.h" |
| (...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 118 } | 118 } |
| 119 } | 119 } |
| 120 | 120 |
| 121 void SigninManager::CopyCredentialsFrom(const SigninManager& source) { | 121 void SigninManager::CopyCredentialsFrom(const SigninManager& source) { |
| 122 DCHECK_NE(this, &source); | 122 DCHECK_NE(this, &source); |
| 123 possibly_invalid_account_id_ = source.possibly_invalid_account_id_; | 123 possibly_invalid_account_id_ = source.possibly_invalid_account_id_; |
| 124 possibly_invalid_gaia_id_ = source.possibly_invalid_gaia_id_; | 124 possibly_invalid_gaia_id_ = source.possibly_invalid_gaia_id_; |
| 125 possibly_invalid_email_ = source.possibly_invalid_email_; | 125 possibly_invalid_email_ = source.possibly_invalid_email_; |
| 126 temp_refresh_token_ = source.temp_refresh_token_; | 126 temp_refresh_token_ = source.temp_refresh_token_; |
| 127 password_ = source.password_; | 127 password_ = source.password_; |
| 128 source.client_->AfterCredentialsCopied(); |
| 128 } | 129 } |
| 129 | 130 |
| 130 void SigninManager::ClearTransientSigninData() { | 131 void SigninManager::ClearTransientSigninData() { |
| 131 DCHECK(IsInitialized()); | 132 DCHECK(IsInitialized()); |
| 132 | 133 |
| 133 possibly_invalid_account_id_.clear(); | 134 possibly_invalid_account_id_.clear(); |
| 134 possibly_invalid_gaia_id_.clear(); | 135 possibly_invalid_gaia_id_.clear(); |
| 135 possibly_invalid_email_.clear(); | 136 possibly_invalid_email_.clear(); |
| 136 password_.clear(); | 137 password_.clear(); |
| 137 type_ = SIGNIN_TYPE_NONE; | 138 type_ = SIGNIN_TYPE_NONE; |
| 138 temp_refresh_token_.clear(); | 139 temp_refresh_token_.clear(); |
| 139 } | 140 } |
| 140 | 141 |
| 141 void SigninManager::HandleAuthError(const GoogleServiceAuthError& error) { | 142 void SigninManager::HandleAuthError(const GoogleServiceAuthError& error) { |
| 142 ClearTransientSigninData(); | 143 ClearTransientSigninData(); |
| 143 | 144 |
| 144 for (auto& observer : observer_list_) | 145 for (auto& observer : observer_list_) |
| 145 observer.GoogleSigninFailed(error); | 146 observer.GoogleSigninFailed(error); |
| 146 } | 147 } |
| 147 | 148 |
| 148 void SigninManager::SignOut( | 149 void SigninManager::SignOut( |
| 149 signin_metrics::ProfileSignout signout_source_metric, | 150 signin_metrics::ProfileSignout signout_source_metric, |
| 150 signin_metrics::SignoutDelete signout_delete_metric) { | 151 signin_metrics::SignoutDelete signout_delete_metric) { |
| 152 client_->PreSignOut(base::Bind(&SigninManager::DoSignOut, |
| 153 base::Unretained(this), signout_source_metric, |
| 154 signout_delete_metric)); |
| 155 } |
| 156 |
| 157 void SigninManager::DoSignOut( |
| 158 signin_metrics::ProfileSignout signout_source_metric, |
| 159 signin_metrics::SignoutDelete signout_delete_metric) { |
| 151 DCHECK(IsInitialized()); | 160 DCHECK(IsInitialized()); |
| 152 | 161 |
| 153 signin_metrics::LogSignout(signout_source_metric, signout_delete_metric); | 162 signin_metrics::LogSignout(signout_source_metric, signout_delete_metric); |
| 154 if (!IsAuthenticated()) { | 163 if (!IsAuthenticated()) { |
| 155 if (AuthInProgress()) { | 164 if (AuthInProgress()) { |
| 156 // If the user is in the process of signing in, then treat a call to | 165 // If the user is in the process of signing in, then treat a call to |
| 157 // SignOut as a cancellation request. | 166 // SignOut as a cancellation request. |
| 158 GoogleServiceAuthError error(GoogleServiceAuthError::REQUEST_CANCELED); | 167 GoogleServiceAuthError error(GoogleServiceAuthError::REQUEST_CANCELED); |
| 159 HandleAuthError(error); | 168 HandleAuthError(error); |
| 160 } else { | 169 } else { |
| (...skipping 254 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 415 account_tracker_service()->SetMigrationDone(); | 424 account_tracker_service()->SetMigrationDone(); |
| 416 token_service_->RemoveObserver(this); | 425 token_service_->RemoveObserver(this); |
| 417 } | 426 } |
| 418 } | 427 } |
| 419 | 428 |
| 420 void SigninManager::ProhibitSignout(bool prohibit_signout) { | 429 void SigninManager::ProhibitSignout(bool prohibit_signout) { |
| 421 prohibit_signout_ = prohibit_signout; | 430 prohibit_signout_ = prohibit_signout; |
| 422 } | 431 } |
| 423 | 432 |
| 424 bool SigninManager::IsSignoutProhibited() const { return prohibit_signout_; } | 433 bool SigninManager::IsSignoutProhibited() const { return prohibit_signout_; } |
| OLD | NEW |