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

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

Issue 7867044: PART1: Initiated the SignedSettings refactoring. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Addressed the comments from Denis. Created 9 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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/ui/webui/options/chromeos/accounts_options_handler.h" 5 #include "chrome/browser/ui/webui/options/chromeos/accounts_options_handler.h"
6 6
7 #include "base/json/json_reader.h" 7 #include "base/json/json_reader.h"
8 #include "base/memory/scoped_ptr.h" 8 #include "base/memory/scoped_ptr.h"
9 #include "base/utf_string_conversions.h" 9 #include "base/utf_string_conversions.h"
10 #include "base/values.h" 10 #include "base/values.h"
11 #include "chrome/browser/browser_process.h" 11 #include "chrome/browser/browser_process.h"
12 #include "chrome/browser/chromeos/cros_settings.h"
12 #include "chrome/browser/chromeos/cros_settings_names.h" 13 #include "chrome/browser/chromeos/cros_settings_names.h"
13 #include "chrome/browser/chromeos/login/authenticator.h" 14 #include "chrome/browser/chromeos/login/authenticator.h"
14 #include "chrome/browser/chromeos/login/user_manager.h" 15 #include "chrome/browser/chromeos/login/user_manager.h"
15 #include "chrome/browser/chromeos/user_cros_settings_provider.h" 16 #include "chrome/browser/chromeos/user_cros_settings_provider.h"
16 #include "chrome/browser/prefs/pref_service.h" 17 #include "chrome/browser/prefs/pref_service.h"
17 #include "chrome/browser/policy/browser_policy_connector.h" 18 #include "chrome/browser/policy/browser_policy_connector.h"
18 #include "grit/generated_resources.h" 19 #include "grit/generated_resources.h"
19 #include "ui/base/l10n/l10n_util.h" 20 #include "ui/base/l10n/l10n_util.h"
20 21
21 namespace chromeos { 22 namespace chromeos {
22 23
23 AccountsOptionsHandler::AccountsOptionsHandler() 24 AccountsOptionsHandler::AccountsOptionsHandler() {
24 : CrosOptionsPageUIHandler(new UserCrosSettingsProvider) {
25 } 25 }
26 26
27 AccountsOptionsHandler::~AccountsOptionsHandler() { 27 AccountsOptionsHandler::~AccountsOptionsHandler() {
28 } 28 }
29 29
30 void AccountsOptionsHandler::RegisterMessages() { 30 void AccountsOptionsHandler::RegisterMessages() {
31 DCHECK(web_ui_); 31 DCHECK(web_ui_);
32 web_ui_->RegisterMessageCallback("whitelistUser", 32 web_ui_->RegisterMessageCallback("whitelistUser",
33 NewCallback(this, &AccountsOptionsHandler::WhitelistUser)); 33 NewCallback(this, &AccountsOptionsHandler::WhitelistUser));
34 web_ui_->RegisterMessageCallback("unwhitelistUser", 34 web_ui_->RegisterMessageCallback("unwhitelistUser",
(...skipping 16 matching lines...) Expand all
51 localized_strings->SetString("show_user_on_signin",l10n_util::GetStringUTF16( 51 localized_strings->SetString("show_user_on_signin",l10n_util::GetStringUTF16(
52 IDS_OPTIONS_ACCOUNTS_SHOW_USER_NAMES_ON_SINGIN_DESCRIPTION)); 52 IDS_OPTIONS_ACCOUNTS_SHOW_USER_NAMES_ON_SINGIN_DESCRIPTION));
53 localized_strings->SetString("username_edit_hint",l10n_util::GetStringUTF16( 53 localized_strings->SetString("username_edit_hint",l10n_util::GetStringUTF16(
54 IDS_OPTIONS_ACCOUNTS_USERNAME_EDIT_HINT)); 54 IDS_OPTIONS_ACCOUNTS_USERNAME_EDIT_HINT));
55 localized_strings->SetString("username_format",l10n_util::GetStringUTF16( 55 localized_strings->SetString("username_format",l10n_util::GetStringUTF16(
56 IDS_OPTIONS_ACCOUNTS_USERNAME_FORMAT)); 56 IDS_OPTIONS_ACCOUNTS_USERNAME_FORMAT));
57 localized_strings->SetString("add_users",l10n_util::GetStringUTF16( 57 localized_strings->SetString("add_users",l10n_util::GetStringUTF16(
58 IDS_OPTIONS_ACCOUNTS_ADD_USERS)); 58 IDS_OPTIONS_ACCOUNTS_ADD_USERS));
59 localized_strings->SetString("owner_only", l10n_util::GetStringUTF16( 59 localized_strings->SetString("owner_only", l10n_util::GetStringUTF16(
60 IDS_OPTIONS_ACCOUNTS_OWNER_ONLY)); 60 IDS_OPTIONS_ACCOUNTS_OWNER_ONLY));
61 localized_strings->SetString("owner_user_id", UTF8ToUTF16( 61
62 UserCrosSettingsProvider::cached_owner())); 62 std::string owner;
63 CrosSettings::Get()->GetString(kDeviceOwner, &owner);
64 localized_strings->SetString("owner_user_id", UTF8ToUTF16(owner));
63 65
64 localized_strings->SetString("current_user_is_owner", 66 localized_strings->SetString("current_user_is_owner",
65 UserManager::Get()->current_user_is_owner() ? 67 UserManager::Get()->current_user_is_owner() ?
66 ASCIIToUTF16("true") : ASCIIToUTF16("false")); 68 ASCIIToUTF16("true") : ASCIIToUTF16("false"));
67 localized_strings->SetString("logged_in_as_guest", 69 localized_strings->SetString("logged_in_as_guest",
68 UserManager::Get()->IsLoggedInAsGuest() ? 70 UserManager::Get()->IsLoggedInAsGuest() ?
69 ASCIIToUTF16("true") : ASCIIToUTF16("false")); 71 ASCIIToUTF16("true") : ASCIIToUTF16("false"));
70 localized_strings->SetString("whitelist_is_managed", 72 localized_strings->SetString("whitelist_is_managed",
71 g_browser_process->browser_policy_connector()->IsEnterpriseManaged() ? 73 g_browser_process->browser_policy_connector()->IsEnterpriseManaged() ?
72 ASCIIToUTF16("true") : ASCIIToUTF16("false")); 74 ASCIIToUTF16("true") : ASCIIToUTF16("false"));
73 } 75 }
74 76
75 UserCrosSettingsProvider* AccountsOptionsHandler::users_settings() const {
76 return static_cast<UserCrosSettingsProvider*>(settings_provider_.get());
77 }
78
79 void AccountsOptionsHandler::WhitelistUser(const ListValue* args) { 77 void AccountsOptionsHandler::WhitelistUser(const ListValue* args) {
80 std::string email; 78 std::string email;
81 if (!args->GetString(0, &email)) { 79 if (!args->GetString(0, &email)) {
82 return; 80 return;
83 } 81 }
84 82
85 users_settings()->WhitelistUser(Authenticator::Canonicalize(email)); 83 UserCrosSettingsProvider::WhitelistUser(Authenticator::Canonicalize(email));
86 } 84 }
87 85
88 void AccountsOptionsHandler::UnwhitelistUser(const ListValue* args) { 86 void AccountsOptionsHandler::UnwhitelistUser(const ListValue* args) {
89 std::string email; 87 std::string email;
90 if (!args->GetString(0, &email)) { 88 if (!args->GetString(0, &email)) {
91 return; 89 return;
92 } 90 }
93 91
94 users_settings()->UnwhitelistUser(Authenticator::Canonicalize(email)); 92 UserCrosSettingsProvider::UnwhitelistUser(Authenticator::Canonicalize(email));
95 UserManager::Get()->RemoveUser(email, NULL); 93 UserManager::Get()->RemoveUser(email, NULL);
96 } 94 }
97 95
98 void AccountsOptionsHandler::WhitelistExistingUsers(const ListValue* args) { 96 void AccountsOptionsHandler::WhitelistExistingUsers(const ListValue* args) {
99 ListValue whitelist_users; 97 ListValue whitelist_users;
100 98
101 UserVector users = UserManager::Get()->GetUsers(); 99 UserVector users = UserManager::Get()->GetUsers();
102 for (UserVector::const_iterator it = users.begin(); 100 for (UserVector::const_iterator it = users.begin();
103 it < users.end(); ++it) { 101 it < users.end(); ++it) {
104 const std::string& email = it->email(); 102 const std::string& email = it->email();
105 if (!UserCrosSettingsProvider::IsEmailInCachedWhitelist(email)) { 103 const ListValue *user_list;
104 CrosSettings::Get()->GetList(kAccountsPrefUsers, &user_list);
105 if (user_list->Find(StringValue(email)) != user_list->end()) {
106 DictionaryValue* user_dict = new DictionaryValue; 106 DictionaryValue* user_dict = new DictionaryValue;
107 user_dict->SetString("name", it->GetDisplayName()); 107 user_dict->SetString("name", it->GetDisplayName());
108 user_dict->SetString("email", email); 108 user_dict->SetString("email", email);
109 user_dict->SetBoolean("owner", false); 109 user_dict->SetBoolean("owner", false);
110 110
111 whitelist_users.Append(user_dict); 111 whitelist_users.Append(user_dict);
112 } 112 }
113 } 113 }
114 114
115 web_ui_->CallJavascriptFunction("AccountsOptions.addUsers", whitelist_users); 115 web_ui_->CallJavascriptFunction("AccountsOptions.addUsers", whitelist_users);
116 } 116 }
117 117
118 } // namespace chromeos 118 } // namespace chromeos
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698