Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(281)

Unified Diff: chrome/browser/chromeos/login/user_manager_impl.cc

Issue 23494053: Remove NOTIFICATION_SYSTEM_SETTING_CHANGED, switch CrosSettings to base::CallbackRegistry. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: trailing space Created 7 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/chromeos/login/user_manager_impl.cc
diff --git a/chrome/browser/chromeos/login/user_manager_impl.cc b/chrome/browser/chromeos/login/user_manager_impl.cc
index ddbbb2afb731ba426001f36eaac0eae83ab26862..e2f65b501082e914dc8f0d374e104623f90c2e5c 100644
--- a/chrome/browser/chromeos/login/user_manager_impl.cc
+++ b/chrome/browser/chromeos/login/user_manager_impl.cc
@@ -236,10 +236,14 @@ UserManagerImpl::UserManagerImpl()
registrar_.Add(this, chrome::NOTIFICATION_LOGIN_USER_PROFILE_PREPARED,
content::NotificationService::AllSources());
RetrieveTrustedDevicePolicies();
- cros_settings_->AddSettingsObserver(kAccountsPrefDeviceLocalAccounts,
- this);
- cros_settings_->AddSettingsObserver(kAccountsPrefSupervisedUsersEnabled,
- this);
+ local_accounts_subscription_ = cros_settings_->AddSettingsObserver(
+ kAccountsPrefDeviceLocalAccounts,
+ base::Bind(&UserManagerImpl::RetrieveTrustedDevicePolicies,
+ base::Unretained(this)));
+ supervised_users_subscription_ = cros_settings_->AddSettingsObserver(
+ kAccountsPrefSupervisedUsersEnabled,
+ base::Bind(&UserManagerImpl::RetrieveTrustedDevicePolicies,
+ base::Unretained(this)));
UpdateLoginState();
}
@@ -260,11 +264,8 @@ UserManagerImpl::~UserManagerImpl() {
void UserManagerImpl::Shutdown() {
DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
- cros_settings_->RemoveSettingsObserver(kAccountsPrefDeviceLocalAccounts,
- this);
- cros_settings_->RemoveSettingsObserver(
- kAccountsPrefSupervisedUsersEnabled,
- this);
+ local_accounts_subscription_.reset();
+ supervised_users_subscription_.reset();
// Stop the session length limiter.
session_length_limiter_.reset();
@@ -792,14 +793,6 @@ void UserManagerImpl::Observe(int type,
}
}
break;
- case chrome::NOTIFICATION_SYSTEM_SETTING_CHANGED: {
- std::string changed_setting =
- *content::Details<const std::string>(details).ptr();
- DCHECK(changed_setting == kAccountsPrefDeviceLocalAccounts ||
- changed_setting == kAccountsPrefSupervisedUsersEnabled);
- RetrieveTrustedDevicePolicies();
- break;
- }
default:
NOTREACHED();
}
« no previous file with comments | « chrome/browser/chromeos/login/user_manager_impl.h ('k') | chrome/browser/chromeos/login/version_info_updater.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698