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

Unified Diff: chrome/browser/chromeos/settings/device_settings_provider.cc

Issue 11358113: Add device policy definition for local accounts. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix oversights. Created 8 years, 1 month 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/settings/device_settings_provider.cc
diff --git a/chrome/browser/chromeos/settings/device_settings_provider.cc b/chrome/browser/chromeos/settings/device_settings_provider.cc
index 5f28b168bb8c0ab570ee5d3590347793c4a6c48d..ee7278865e0bcd5f6175598ebfcdda6d5477d9b9 100644
--- a/chrome/browser/chromeos/settings/device_settings_provider.cc
+++ b/chrome/browser/chromeos/settings/device_settings_provider.cc
@@ -40,6 +40,7 @@ const char* kKnownSettings[] = {
kAccountsPrefEphemeralUsersEnabled,
kAccountsPrefShowUserNamesOnSignIn,
kAccountsPrefUsers,
+ kAccountsPrefDeviceLocalAccounts,
kAppPack,
kDeviceOwner,
kIdleLogoutTimeout,
@@ -211,6 +212,22 @@ void DeviceSettingsProvider::SetInPolicy() {
show->set_show_user_names(show_value);
else
NOTREACHED();
+ } else if (prop == kAccountsPrefDeviceLocalAccounts) {
+ em::DeviceLocalAccountsProto* device_local_accounts =
+ device_settings_.mutable_device_local_accounts();
+ base::ListValue* accounts_list;
+ if (value->GetAsList(&accounts_list)) {
+ for (base::ListValue::const_iterator entry(accounts_list->begin());
+ entry != accounts_list->end(); ++entry) {
+ std::string id;
+ if ((*entry)->GetAsString(&id))
+ device_local_accounts->add_account()->set_id(id);
+ else
+ NOTREACHED();
+ }
+ } else {
+ NOTREACHED();
+ }
} else if (prop == kSignedDataRoamingEnabled) {
em::DataRoamingEnabledProto* roam =
device_settings_.mutable_data_roaming_enabled();
@@ -361,6 +378,16 @@ void DeviceSettingsProvider::DecodeLoginPolicies(
list->Append(base::Value::CreateStringValue(*it));
}
new_values_cache->SetValue(kAccountsPrefUsers, list);
+
+ base::ListValue* account_list = new base::ListValue();
+ const RepeatedPtrField<em::DeviceLocalAccountInfoProto>& accounts =
+ policy.device_local_accounts().account();
+ RepeatedPtrField<em::DeviceLocalAccountInfoProto>::const_iterator entry;
+ for (entry = accounts.begin(); entry != accounts.end(); ++entry) {
+ if (entry->has_id())
+ account_list->AppendString(entry->id());
+ }
+ new_values_cache->SetValue(kAccountsPrefDeviceLocalAccounts, account_list);
}
void DeviceSettingsProvider::DecodeKioskPolicies(
« no previous file with comments | « chrome/browser/chromeos/settings/cros_settings_names.cc ('k') | chrome/browser/policy/device_policy_decoder_chromeos.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698