| 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 "chrome/browser/managed_mode/chromeos/managed_user_password_service.h" | 5 #include "chrome/browser/supervised_user/chromeos/supervised_user_password_servi
ce.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/values.h" | 8 #include "base/values.h" |
| 9 #include "chrome/browser/chromeos/login/managed/supervised_user_authentication.h
" | 9 #include "chrome/browser/chromeos/login/managed/supervised_user_authentication.h
" |
| 10 #include "chrome/browser/chromeos/login/users/supervised_user_manager.h" | 10 #include "chrome/browser/chromeos/login/users/supervised_user_manager.h" |
| 11 #include "chrome/browser/chromeos/login/users/user_manager.h" | 11 #include "chrome/browser/chromeos/login/users/user_manager.h" |
| 12 #include "chrome/browser/managed_mode/managed_user_constants.h" | 12 #include "chrome/browser/supervised_user/supervised_user_constants.h" |
| 13 #include "chrome/browser/managed_mode/managed_user_sync_service.h" | 13 #include "chrome/browser/supervised_user/supervised_user_sync_service.h" |
| 14 | 14 |
| 15 namespace chromeos { | 15 namespace chromeos { |
| 16 | 16 |
| 17 ManagedUserPasswordService::ManagedUserPasswordService() | 17 SupervisedUserPasswordService::SupervisedUserPasswordService() |
| 18 : weak_ptr_factory_(this) {} | 18 : weak_ptr_factory_(this) {} |
| 19 | 19 |
| 20 ManagedUserPasswordService::~ManagedUserPasswordService() {} | 20 SupervisedUserPasswordService::~SupervisedUserPasswordService() {} |
| 21 | 21 |
| 22 void ManagedUserPasswordService::Init( | 22 void SupervisedUserPasswordService::Init( |
| 23 const std::string& user_id, | 23 const std::string& user_id, |
| 24 ManagedUserSharedSettingsService* shared_settings_service) { | 24 SupervisedUserSharedSettingsService* shared_settings_service) { |
| 25 user_id_ = user_id; | 25 user_id_ = user_id; |
| 26 settings_service_ = shared_settings_service; | 26 settings_service_ = shared_settings_service; |
| 27 settings_service_subscription_ = settings_service_->Subscribe( | 27 settings_service_subscription_ = settings_service_->Subscribe( |
| 28 base::Bind(&ManagedUserPasswordService::OnSharedSettingsChange, | 28 base::Bind(&SupervisedUserPasswordService::OnSharedSettingsChange, |
| 29 weak_ptr_factory_.GetWeakPtr())); | 29 weak_ptr_factory_.GetWeakPtr())); |
| 30 | 30 |
| 31 // Force value check in case we have missed some notification. | 31 // Force value check in case we have missed some notification. |
| 32 | 32 |
| 33 chromeos::SupervisedUserManager* supervised_user_manager = | 33 chromeos::SupervisedUserManager* supervised_user_manager = |
| 34 chromeos::UserManager::Get()->GetSupervisedUserManager(); | 34 chromeos::UserManager::Get()->GetSupervisedUserManager(); |
| 35 | 35 |
| 36 OnSharedSettingsChange(supervised_user_manager->GetUserSyncId(user_id), | 36 OnSharedSettingsChange(supervised_user_manager->GetUserSyncId(user_id), |
| 37 managed_users::kChromeOSPasswordData); | 37 supervised_users::kChromeOSPasswordData); |
| 38 } | 38 } |
| 39 | 39 |
| 40 void ManagedUserPasswordService::OnSharedSettingsChange( | 40 void SupervisedUserPasswordService::OnSharedSettingsChange( |
| 41 const std::string& mu_id, | 41 const std::string& su_id, |
| 42 const std::string& key) { | 42 const std::string& key) { |
| 43 if (key != managed_users::kChromeOSPasswordData) | 43 if (key != supervised_users::kChromeOSPasswordData) |
| 44 return; | 44 return; |
| 45 chromeos::SupervisedUserManager* supervised_user_manager = | 45 chromeos::SupervisedUserManager* supervised_user_manager = |
| 46 chromeos::UserManager::Get()->GetSupervisedUserManager(); | 46 chromeos::UserManager::Get()->GetSupervisedUserManager(); |
| 47 const chromeos::User* user = supervised_user_manager->FindBySyncId(mu_id); | 47 const chromeos::User* user = supervised_user_manager->FindBySyncId(su_id); |
| 48 if (user == NULL) { | 48 if (user == NULL) { |
| 49 LOG(WARNING) << "Got notification for user not on device."; | 49 LOG(WARNING) << "Got notification for user not on device."; |
| 50 return; | 50 return; |
| 51 } | 51 } |
| 52 DCHECK(user_id_ == user->email()); | 52 DCHECK(user_id_ == user->email()); |
| 53 if (user_id_ != user->email()) | 53 if (user_id_ != user->email()) |
| 54 return; | 54 return; |
| 55 const base::Value* value = settings_service_->GetValue(mu_id, key); | 55 const base::Value* value = settings_service_->GetValue(su_id, key); |
| 56 if (value == NULL) { | 56 if (value == NULL) { |
| 57 LOG(WARNING) << "Got empty value from sync."; | 57 LOG(WARNING) << "Got empty value from sync."; |
| 58 return; | 58 return; |
| 59 } | 59 } |
| 60 const base::DictionaryValue* dict; | 60 const base::DictionaryValue* dict; |
| 61 if (!value->GetAsDictionary(&dict)) { | 61 if (!value->GetAsDictionary(&dict)) { |
| 62 LOG(WARNING) << "Got non-dictionary value from sync."; | 62 LOG(WARNING) << "Got non-dictionary value from sync."; |
| 63 return; | 63 return; |
| 64 } | 64 } |
| 65 chromeos::SupervisedUserAuthentication* auth = | 65 chromeos::SupervisedUserAuthentication* auth = |
| 66 supervised_user_manager->GetAuthentication(); | 66 supervised_user_manager->GetAuthentication(); |
| 67 if (!auth->NeedPasswordChange(user_id_, dict)) | 67 if (!auth->NeedPasswordChange(user_id_, dict)) |
| 68 return; | 68 return; |
| 69 auth->ScheduleSupervisedPasswordChange(user_id_, dict); | 69 auth->ScheduleSupervisedPasswordChange(user_id_, dict); |
| 70 } | 70 } |
| 71 | 71 |
| 72 void ManagedUserPasswordService::Shutdown() { | 72 void SupervisedUserPasswordService::Shutdown() { |
| 73 settings_service_subscription_.reset(); | 73 settings_service_subscription_.reset(); |
| 74 } | 74 } |
| 75 | 75 |
| 76 } // namespace chromeos | 76 } // namespace chromeos |
| OLD | NEW |