| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/user_manager/known_user.h" | 5 #include "components/user_manager/known_user.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 | 8 |
| 9 #include <memory> | 9 #include <memory> |
| 10 #include <utility> | 10 #include <utility> |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 46 | 46 |
| 47 // Key of GAPS cookie. | 47 // Key of GAPS cookie. |
| 48 const char kGAPSCookie[] = "gaps_cookie"; | 48 const char kGAPSCookie[] = "gaps_cookie"; |
| 49 | 49 |
| 50 // Key of the reason for re-auth. | 50 // Key of the reason for re-auth. |
| 51 const char kReauthReasonKey[] = "reauth_reason"; | 51 const char kReauthReasonKey[] = "reauth_reason"; |
| 52 | 52 |
| 53 // Key for the GaiaId migration status. | 53 // Key for the GaiaId migration status. |
| 54 const char kGaiaIdMigration[] = "gaia_id_migration"; | 54 const char kGaiaIdMigration[] = "gaia_id_migration"; |
| 55 | 55 |
| 56 // Key of the boolean flag telling if user session has finished init yet. |
| 57 const char kProfileEverInitialized[] = "profile_ever_initialized"; |
| 58 |
| 56 PrefService* GetLocalState() { | 59 PrefService* GetLocalState() { |
| 57 if (!UserManager::IsInitialized()) | 60 if (!UserManager::IsInitialized()) |
| 58 return nullptr; | 61 return nullptr; |
| 59 | 62 |
| 60 return UserManager::Get()->GetLocalState(); | 63 return UserManager::Get()->GetLocalState(); |
| 61 } | 64 } |
| 62 | 65 |
| 63 // Checks if values in |dict| correspond with |account_id| identity. | 66 // Checks if values in |dict| correspond with |account_id| identity. |
| 64 bool UserMatches(const AccountId& account_id, | 67 bool UserMatches(const AccountId& account_id, |
| 65 const base::DictionaryValue& dict) { | 68 const base::DictionaryValue& dict) { |
| (...skipping 378 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 444 SetBooleanPref(account_id, kUsingSAMLKey, using_saml); | 447 SetBooleanPref(account_id, kUsingSAMLKey, using_saml); |
| 445 } | 448 } |
| 446 | 449 |
| 447 bool IsUsingSAML(const AccountId& account_id) { | 450 bool IsUsingSAML(const AccountId& account_id) { |
| 448 bool using_saml; | 451 bool using_saml; |
| 449 if (GetBooleanPref(account_id, kUsingSAMLKey, &using_saml)) | 452 if (GetBooleanPref(account_id, kUsingSAMLKey, &using_saml)) |
| 450 return using_saml; | 453 return using_saml; |
| 451 return false; | 454 return false; |
| 452 } | 455 } |
| 453 | 456 |
| 457 bool WasProfileEverInitialized(const AccountId& account_id) { |
| 458 bool profile_ever_initialized; |
| 459 if (GetBooleanPref(account_id, kProfileEverInitialized, |
| 460 &profile_ever_initialized)) |
| 461 return profile_ever_initialized; |
| 462 |
| 463 // Sessions created before we started setting the session_initialized flag |
| 464 // should default to "initialized = true". |
| 465 LOG(WARNING) << "Treating unmigrated user as profile_ever_initialized=true"; |
| 466 return true; |
| 467 } |
| 468 |
| 469 void SetProfileEverInitialized(const AccountId& account_id, bool initialized) { |
| 470 SetBooleanPref(account_id, kProfileEverInitialized, initialized); |
| 471 } |
| 472 |
| 454 void UpdateReauthReason(const AccountId& account_id, const int reauth_reason) { | 473 void UpdateReauthReason(const AccountId& account_id, const int reauth_reason) { |
| 455 SetIntegerPref(account_id, kReauthReasonKey, reauth_reason); | 474 SetIntegerPref(account_id, kReauthReasonKey, reauth_reason); |
| 456 } | 475 } |
| 457 | 476 |
| 458 bool FindReauthReason(const AccountId& account_id, int* out_value) { | 477 bool FindReauthReason(const AccountId& account_id, int* out_value) { |
| 459 return GetIntegerPref(account_id, kReauthReasonKey, out_value); | 478 return GetIntegerPref(account_id, kReauthReasonKey, out_value); |
| 460 } | 479 } |
| 461 | 480 |
| 462 void RemovePrefs(const AccountId& account_id) { | 481 void RemovePrefs(const AccountId& account_id) { |
| 463 PrefService* local_state = GetLocalState(); | 482 PrefService* local_state = GetLocalState(); |
| 464 | 483 |
| 465 // Local State may not be initialized in tests. | 484 // Local State may not be initialized in tests. |
| 466 if (!local_state) | 485 if (!local_state) |
| 467 return; | 486 return; |
| 468 | 487 |
| 469 ListPrefUpdate update(local_state, kKnownUsers); | 488 ListPrefUpdate update(local_state, kKnownUsers); |
| 470 for (size_t i = 0; i < update->GetSize(); ++i) { | 489 for (size_t i = 0; i < update->GetSize(); ++i) { |
| 471 base::DictionaryValue* element = nullptr; | 490 base::DictionaryValue* element = nullptr; |
| 472 if (update->GetDictionary(i, &element)) { | 491 if (update->GetDictionary(i, &element)) { |
| 473 if (UserMatches(account_id, *element)) { | 492 if (UserMatches(account_id, *element)) { |
| 474 update->Remove(i, nullptr); | 493 update->Remove(i, nullptr); |
| 475 break; | 494 break; |
| 476 } | 495 } |
| 477 } | 496 } |
| 478 } | 497 } |
| 479 } | 498 } |
| 480 | 499 |
| 500 // Exported so tests can call this from other components. |
| 501 void RemovePrefsForTesting(const AccountId& account_id) { |
| 502 RemovePrefs(account_id); |
| 503 } |
| 504 |
| 481 void RegisterPrefs(PrefRegistrySimple* registry) { | 505 void RegisterPrefs(PrefRegistrySimple* registry) { |
| 482 registry->RegisterListPref(kKnownUsers); | 506 registry->RegisterListPref(kKnownUsers); |
| 483 } | 507 } |
| 484 | 508 |
| 485 } // namespace known_user | 509 } // namespace known_user |
| 486 } // namespace user_manager | 510 } // namespace user_manager |
| OLD | NEW |