Chromium Code Reviews| 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/supervised_user_pref_mapping_service.h" | 5 #include "chrome/browser/supervised_user/supervised_user_pref_mapping_service.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/prefs/pref_service.h" | 8 #include "base/prefs/pref_service.h" |
| 9 #include "base/values.h" | 9 #include "base/values.h" |
| 10 #include "chrome/browser/managed_mode/managed_user_constants.h" | 10 #include "chrome/browser/supervised_user/supervised_user_constants.h" |
| 11 #include "chrome/browser/managed_mode/managed_user_shared_settings_service.h" | 11 #include "chrome/browser/supervised_user/supervised_user_shared_settings_service .h" |
| 12 #include "chrome/common/pref_names.h" | 12 #include "chrome/common/pref_names.h" |
| 13 | 13 |
| 14 const int kNoAvatar = -1; | 14 const int kNoAvatar = -1; |
| 15 | 15 |
| 16 SupervisedUserPrefMappingService::SupervisedUserPrefMappingService( | 16 SupervisedUserPrefMappingService::SupervisedUserPrefMappingService( |
| 17 PrefService* prefs, | 17 PrefService* prefs, |
| 18 ManagedUserSharedSettingsService* shared_settings) | 18 SupervisedUserSharedSettingsService* shared_settings) |
| 19 : prefs_(prefs), | 19 : prefs_(prefs), |
| 20 shared_settings_(shared_settings), | 20 shared_settings_(shared_settings), |
| 21 managed_user_id_(prefs->GetString(prefs::kSupervisedUserId)), | 21 supervised_user_id_(prefs->GetString(prefs::kSupervisedUserId)), |
| 22 weak_ptr_factory_(this) {} | 22 weak_ptr_factory_(this) {} |
| 23 | 23 |
| 24 SupervisedUserPrefMappingService::~SupervisedUserPrefMappingService() {} | 24 SupervisedUserPrefMappingService::~SupervisedUserPrefMappingService() {} |
| 25 | 25 |
| 26 void SupervisedUserPrefMappingService::Init() { | 26 void SupervisedUserPrefMappingService::Init() { |
| 27 subscription_ = shared_settings_->Subscribe( | 27 subscription_ = shared_settings_->Subscribe( |
| 28 base::Bind(&SupervisedUserPrefMappingService::OnSharedSettingChanged, | 28 base::Bind(&SupervisedUserPrefMappingService::OnSharedSettingChanged, |
| 29 weak_ptr_factory_.GetWeakPtr())); | 29 weak_ptr_factory_.GetWeakPtr())); |
| 30 | 30 |
| 31 pref_change_registrar_.Init(prefs_); | 31 pref_change_registrar_.Init(prefs_); |
| 32 pref_change_registrar_.Add( | 32 pref_change_registrar_.Add( |
| 33 prefs::kProfileAvatarIndex, | 33 prefs::kProfileAvatarIndex, |
| 34 base::Bind(&SupervisedUserPrefMappingService::OnAvatarChanged, | 34 base::Bind(&SupervisedUserPrefMappingService::OnAvatarChanged, |
| 35 weak_ptr_factory_.GetWeakPtr())); | 35 weak_ptr_factory_.GetWeakPtr())); |
| 36 | 36 |
| 37 // Check if we need to update the shared setting with the avatar index. | 37 // Check if we need to update the shared setting with the avatar index. |
| 38 // Otherwise we update the user pref in case we missed a notification. | 38 // Otherwise we update the user pref in case we missed a notification. |
| 39 if (GetChromeAvatarIndex() == kNoAvatar) | 39 if (GetChromeAvatarIndex() == kNoAvatar) |
| 40 OnAvatarChanged(); | 40 OnAvatarChanged(); |
| 41 else | 41 else |
| 42 OnSharedSettingChanged(managed_user_id_, managed_users::kChromeAvatarIndex); | 42 OnSharedSettingChanged(supervised_user_id_, |
| 43 supervised_users::kChromeAvatarIndex); | |
|
Pam (message me for reviews)
2014/06/16 23:51:51
Now that this is multiple lines, the style guide m
| |
| 43 } | 44 } |
| 44 | 45 |
| 45 void SupervisedUserPrefMappingService::OnAvatarChanged() { | 46 void SupervisedUserPrefMappingService::OnAvatarChanged() { |
| 46 int new_avatar_index = prefs_->GetInteger(prefs::kProfileAvatarIndex); | 47 int new_avatar_index = prefs_->GetInteger(prefs::kProfileAvatarIndex); |
| 47 if (new_avatar_index < 0) | 48 if (new_avatar_index < 0) |
| 48 return; | 49 return; |
| 49 | 50 |
| 50 // First check if the avatar index is a new value. | 51 // First check if the avatar index is a new value. |
| 51 if (GetChromeAvatarIndex() == new_avatar_index) | 52 if (GetChromeAvatarIndex() == new_avatar_index) |
| 52 return; | 53 return; |
| 53 | 54 |
| 54 // If yes, update the shared settings value. | 55 // If yes, update the shared settings value. |
| 55 shared_settings_->SetValue(managed_user_id_, | 56 shared_settings_->SetValue(supervised_user_id_, |
| 56 managed_users::kChromeAvatarIndex, | 57 supervised_users::kChromeAvatarIndex, |
| 57 base::FundamentalValue(new_avatar_index)); | 58 base::FundamentalValue(new_avatar_index)); |
| 58 } | 59 } |
| 59 | 60 |
| 60 void SupervisedUserPrefMappingService::OnSharedSettingChanged( | 61 void SupervisedUserPrefMappingService::OnSharedSettingChanged( |
| 61 const std::string& mu_id, | 62 const std::string& mu_id, |
| 62 const std::string& key) { | 63 const std::string& key) { |
| 63 DCHECK_EQ(mu_id, managed_user_id_); | 64 DCHECK_EQ(mu_id, supervised_user_id_); |
| 64 if (key != managed_users::kChromeAvatarIndex) | 65 if (key != supervised_users::kChromeAvatarIndex) |
| 65 return; | 66 return; |
| 66 | 67 |
| 67 const base::Value* value = shared_settings_->GetValue(mu_id, key); | 68 const base::Value* value = shared_settings_->GetValue(mu_id, key); |
| 68 int avatar_index; | 69 int avatar_index; |
| 69 bool success = value->GetAsInteger(&avatar_index); | 70 bool success = value->GetAsInteger(&avatar_index); |
| 70 DCHECK(success); | 71 DCHECK(success); |
| 71 prefs_->SetInteger(prefs::kProfileAvatarIndex, avatar_index); | 72 prefs_->SetInteger(prefs::kProfileAvatarIndex, avatar_index); |
| 72 } | 73 } |
| 73 | 74 |
| 74 void SupervisedUserPrefMappingService::Shutdown() { | 75 void SupervisedUserPrefMappingService::Shutdown() { |
| 75 subscription_.reset(); | 76 subscription_.reset(); |
| 76 } | 77 } |
| 77 | 78 |
| 78 int SupervisedUserPrefMappingService::GetChromeAvatarIndex() { | 79 int SupervisedUserPrefMappingService::GetChromeAvatarIndex() { |
| 79 const base::Value* value = shared_settings_->GetValue( | 80 const base::Value* value = shared_settings_->GetValue( |
| 80 managed_user_id_, managed_users::kChromeAvatarIndex); | 81 supervised_user_id_, supervised_users::kChromeAvatarIndex); |
| 81 if (!value) | 82 if (!value) |
| 82 return kNoAvatar; | 83 return kNoAvatar; |
| 83 | 84 |
| 84 int current_avatar_index; | 85 int current_avatar_index; |
| 85 bool success = value->GetAsInteger(¤t_avatar_index); | 86 bool success = value->GetAsInteger(¤t_avatar_index); |
| 86 DCHECK(success); | 87 DCHECK(success); |
| 87 return current_avatar_index; | 88 return current_avatar_index; |
| 88 } | 89 } |
| OLD | NEW |