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

Unified Diff: chrome/browser/ui/webui/options/chromeos/accounts_options_handler.cc

Issue 8773046: [cros] Display emails of users are stored in a separate dictionary in Local State. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Review fixes. Created 9 years 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/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 41550f5a61e0f03a0dd48c9f7b992e36b012ddf6..91eb6ee8349dc1926d3f69d7a8ffb6218054ff63 100644
--- a/chrome/browser/ui/webui/options/chromeos/accounts_options_handler.cc
+++ b/chrome/browser/ui/webui/options/chromeos/accounts_options_handler.cc
@@ -23,6 +23,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() {
}
@@ -32,13 +47,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)));
}
@@ -64,9 +79,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() ?
@@ -79,47 +97,70 @@ void AccountsOptionsHandler::GetLocalizedValues(
ASCIIToUTF16("true") : ASCIIToUTF16("false"));
}
-void AccountsOptionsHandler::WhitelistUser(const base::ListValue* args) {
+base::DictionaryValue* AccountsOptionsHandler::CreateUserInfo(
+ const std::string& username,
+ const std::string& display_email,
+ const std::string& display_name) {
+ base::DictionaryValue* user_dict = new DictionaryValue;
+ user_dict->SetString("username", username);
+ user_dict->SetString("name", display_email);
+ user_dict->SetString("email", display_name);
+ user_dict->SetBoolean("owner", IsLoggedInOwner(username));
+ return user_dict;
+}
+
+void AccountsOptionsHandler::HandleWhitelistUser(const base::ListValue* args) {
std::string email;
- if (!args->GetString(0, &email)) {
+ std::string name;
+ if (!args->GetString(0, &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());
+ std::string canonical_email = Authenticator::Canonicalize(email);
+ // Record a display email for the whitelisted user if it doesn't exist yet.
+ UserManager::Get()->SaveUserDisplayEmail(canonical_email, email, false);
+
+ if (WhitelistUser(canonical_email)) {
+ base::ListValue single_user;
+ single_user.Append(CreateUserInfo(canonical_email, email, name));
+ web_ui_->CallJavascriptFunction("AccountsOptions.addUsers", single_user);
+ }
}
-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);
+ // TODO(ivankr): this will not remove user's diplayed email if there is
+ // no such user.
UserManager::Get()->RemoveUser(email, NULL);
}
-void AccountsOptionsHandler::WhitelistExistingUsers(
+void AccountsOptionsHandler::HandleWhitelistExistingUsers(
const base::ListValue* args) {
base::ListValue whitelist_users;
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);
+ if (WhitelistUser(email)) {
+ whitelist_users.Append(CreateUserInfo(
+ email, (*it)->display_email(), (*it)->GetDisplayName()));
}
}
web_ui_->CallJavascriptFunction("AccountsOptions.addUsers", whitelist_users);
}
+bool AccountsOptionsHandler::IsLoggedInOwner(const std::string& username) {
James Hawkins 2011/12/02 19:52:30 This should be able to be moved to unnamed namespa
Ivan Korotkov 2011/12/05 14:12:48 Done.
+ UserManager* user_manager = UserManager::Get();
+ return user_manager->current_user_is_owner() &&
+ user_manager->logged_in_user().email() == username;
+}
+
} // namespace chromeos

Powered by Google App Engine
This is Rietveld 408576698