| Index: chrome/browser/ui/webui/options/chromeos/accounts_options_handler.cc
|
| diff --git a/chrome/browser/ui/webui/options/chromeos/accounts_options_handler.cc b/chrome/browser/ui/webui/options/chromeos/accounts_options_handler.cc
|
| index 0eb6c35a0f41388902235b81c8f79990b3ed5551..431a5dfd282aba16b8501673fe73175a780060de 100644
|
| --- a/chrome/browser/ui/webui/options/chromeos/accounts_options_handler.cc
|
| +++ b/chrome/browser/ui/webui/options/chromeos/accounts_options_handler.cc
|
| @@ -22,6 +22,21 @@
|
|
|
| namespace chromeos {
|
|
|
| +namespace {
|
| +
|
| +// Adds specified user to the whitelist. Returns false if that user is already
|
| +// in the whitelist.
|
| +bool WhitelistUser(const std::string& username) {
|
| + CrosSettings* cros_settings = CrosSettings::Get();
|
| + if (cros_settings->FindEmailInList(kAccountsPrefUsers, username))
|
| + return false;
|
| + base::StringValue username_value(username);
|
| + cros_settings->AppendToList(kAccountsPrefUsers, &username_value);
|
| + return true;
|
| +}
|
| +
|
| +} // namespace
|
| +
|
| AccountsOptionsHandler::AccountsOptionsHandler() {
|
| }
|
|
|
| @@ -31,13 +46,13 @@ AccountsOptionsHandler::~AccountsOptionsHandler() {
|
| void AccountsOptionsHandler::RegisterMessages() {
|
| DCHECK(web_ui_);
|
| web_ui_->RegisterMessageCallback("whitelistUser",
|
| - base::Bind(&AccountsOptionsHandler::WhitelistUser,
|
| + base::Bind(&AccountsOptionsHandler::HandleWhitelistUser,
|
| base::Unretained(this)));
|
| web_ui_->RegisterMessageCallback("unwhitelistUser",
|
| - base::Bind(&AccountsOptionsHandler::UnwhitelistUser,
|
| + base::Bind(&AccountsOptionsHandler::HandleUnwhitelistUser,
|
| base::Unretained(this)));
|
| web_ui_->RegisterMessageCallback("whitelistExistingUsers",
|
| - base::Bind(&AccountsOptionsHandler::WhitelistExistingUsers,
|
| + base::Bind(&AccountsOptionsHandler::HandleWhitelistExistingUsers,
|
| base::Unretained(this)));
|
| }
|
|
|
| @@ -63,9 +78,12 @@ void AccountsOptionsHandler::GetLocalizedValues(
|
| localized_strings->SetString("owner_only", l10n_util::GetStringUTF16(
|
| IDS_OPTIONS_ACCOUNTS_OWNER_ONLY));
|
|
|
| - std::string owner;
|
| - CrosSettings::Get()->GetString(kDeviceOwner, &owner);
|
| - localized_strings->SetString("owner_user_id", UTF8ToUTF16(owner));
|
| + std::string owner_email;
|
| + CrosSettings::Get()->GetString(kDeviceOwner, &owner_email);
|
| + // Translate owner's email to the display email.
|
| + std::string display_email =
|
| + UserManager::Get()->GetUserDisplayEmail(owner_email);
|
| + localized_strings->SetString("owner_user_id", UTF8ToUTF16(display_email));
|
|
|
| localized_strings->SetString("current_user_is_owner",
|
| UserManager::Get()->current_user_is_owner() ?
|
| @@ -78,47 +96,37 @@ void AccountsOptionsHandler::GetLocalizedValues(
|
| ASCIIToUTF16("true") : ASCIIToUTF16("false"));
|
| }
|
|
|
| -void AccountsOptionsHandler::WhitelistUser(const base::ListValue* args) {
|
| - std::string email;
|
| - if (!args->GetString(0, &email)) {
|
| +void AccountsOptionsHandler::HandleWhitelistUser(const base::ListValue* args) {
|
| + std::string typed_email;
|
| + std::string name;
|
| + if (!args->GetString(0, &typed_email) ||
|
| + !args->GetString(1, &name)) {
|
| return;
|
| }
|
|
|
| - scoped_ptr<base::StringValue> canonical_email(
|
| - base::Value::CreateStringValue(Authenticator::Canonicalize(email)));
|
| - CrosSettings::Get()->AppendToList(kAccountsPrefUsers, canonical_email.get());
|
| + WhitelistUser(Authenticator::Canonicalize(typed_email));
|
| }
|
|
|
| -void AccountsOptionsHandler::UnwhitelistUser(const base::ListValue* args) {
|
| +void AccountsOptionsHandler::HandleUnwhitelistUser(
|
| + const base::ListValue* args) {
|
| std::string email;
|
| if (!args->GetString(0, &email)) {
|
| return;
|
| }
|
|
|
| - scoped_ptr<base::StringValue> canonical_email(
|
| - base::Value::CreateStringValue(Authenticator::Canonicalize(email)));
|
| - CrosSettings::Get()->RemoveFromList(kAccountsPrefUsers,
|
| - canonical_email.get());
|
| + base::StringValue canonical_email(Authenticator::Canonicalize(email));
|
| + CrosSettings::Get()->RemoveFromList(kAccountsPrefUsers, &canonical_email);
|
| UserManager::Get()->RemoveUser(email, NULL);
|
| }
|
|
|
| -void AccountsOptionsHandler::WhitelistExistingUsers(
|
| +void AccountsOptionsHandler::HandleWhitelistExistingUsers(
|
| const base::ListValue* args) {
|
| - base::ListValue whitelist_users;
|
| + DCHECK(args && args->empty());
|
| +
|
| const UserList& users = UserManager::Get()->GetUsers();
|
| for (UserList::const_iterator it = users.begin(); it < users.end(); ++it) {
|
| - const std::string& email = (*it)->email();
|
| - if (!CrosSettings::Get()->FindEmailInList(kAccountsPrefUsers, email)) {
|
| - base::DictionaryValue* user_dict = new DictionaryValue;
|
| - user_dict->SetString("name", (*it)->GetDisplayName());
|
| - user_dict->SetString("email", email);
|
| - user_dict->SetBoolean("owner", false);
|
| -
|
| - whitelist_users.Append(user_dict);
|
| - }
|
| + WhitelistUser((*it)->email());
|
| }
|
| -
|
| - web_ui_->CallJavascriptFunction("AccountsOptions.addUsers", whitelist_users);
|
| }
|
|
|
| } // namespace chromeos
|
|
|