| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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/chromeos/login/signin_screen_handler.h" | 5 #include "chrome/browser/ui/webui/chromeos/login/signin_screen_handler.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
| (...skipping 1272 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1283 void SigninScreenHandler::SendUserList(bool animated) { | 1283 void SigninScreenHandler::SendUserList(bool animated) { |
| 1284 if (!delegate_) | 1284 if (!delegate_) |
| 1285 return; | 1285 return; |
| 1286 TRACE_EVENT_ASYNC_STEP_INTO0("ui", | 1286 TRACE_EVENT_ASYNC_STEP_INTO0("ui", |
| 1287 "ShowLoginWebUI", | 1287 "ShowLoginWebUI", |
| 1288 LoginDisplayHostImpl::kShowLoginWebUIid, | 1288 LoginDisplayHostImpl::kShowLoginWebUIid, |
| 1289 "SendUserList"); | 1289 "SendUserList"); |
| 1290 BootTimesLoader::Get()->RecordCurrentStats("login-send-user-list"); | 1290 BootTimesLoader::Get()->RecordCurrentStats("login-send-user-list"); |
| 1291 | 1291 |
| 1292 base::ListValue users_list; | 1292 base::ListValue users_list; |
| 1293 size_t first_non_public_account_index = 0; | |
| 1294 const UserList& users = delegate_->GetUsers(); | 1293 const UserList& users = delegate_->GetUsers(); |
| 1295 | 1294 |
| 1296 // TODO(nkostylev): Move to a separate method in UserManager. | 1295 // TODO(nkostylev): Move to a separate method in UserManager. |
| 1297 // http://crbug.com/230852 | 1296 // http://crbug.com/230852 |
| 1298 bool is_signin_to_add = LoginDisplayHostImpl::default_host() && | 1297 bool is_signin_to_add = LoginDisplayHostImpl::default_host() && |
| 1299 UserManager::Get()->IsUserLoggedIn(); | 1298 UserManager::Get()->IsUserLoggedIn(); |
| 1300 | 1299 |
| 1301 bool single_user = users.size() == 1; | 1300 bool single_user = users.size() == 1; |
| 1302 std::string owner; | 1301 std::string owner; |
| 1303 chromeos::CrosSettings::Get()->GetString(chromeos::kDeviceOwner, &owner); | 1302 chromeos::CrosSettings::Get()->GetString(chromeos::kDeviceOwner, &owner); |
| 1304 bool has_owner = owner.size() > 0; | 1303 bool has_owner = owner.size() > 0; |
| 1305 // if public accounts available, that means there's no device owner | |
| 1306 size_t max_non_owner_users = has_owner ? kMaxUsers - 1 : kMaxUsers; | 1304 size_t max_non_owner_users = has_owner ? kMaxUsers - 1 : kMaxUsers; |
| 1307 size_t non_owner_count = 0; | 1305 size_t non_owner_count = 0; |
| 1308 | 1306 |
| 1309 for (UserList::const_iterator it = users.begin(); it != users.end(); ++it) { | 1307 for (UserList::const_iterator it = users.begin(); it != users.end(); ++it) { |
| 1310 const std::string& email = (*it)->email(); | 1308 const std::string& email = (*it)->email(); |
| 1311 bool is_owner = (email == owner); | 1309 bool is_owner = (email == owner); |
| 1312 bool is_public_account = | 1310 bool is_public_account = |
| 1313 ((*it)->GetType() == User::USER_TYPE_PUBLIC_ACCOUNT); | 1311 ((*it)->GetType() == User::USER_TYPE_PUBLIC_ACCOUNT); |
| 1314 | 1312 |
| 1315 if (is_public_account || non_owner_count < max_non_owner_users || | 1313 if (is_public_account || non_owner_count < max_non_owner_users || |
| 1316 is_owner) { | 1314 is_owner) { |
| 1317 base::DictionaryValue* user_dict = new base::DictionaryValue(); | 1315 base::DictionaryValue* user_dict = new base::DictionaryValue(); |
| 1318 FillUserDictionary(*it, is_owner, is_signin_to_add, user_dict); | 1316 FillUserDictionary(*it, is_owner, is_signin_to_add, user_dict); |
| 1319 bool signed_in = (*it)->is_logged_in(); | 1317 bool signed_in = (*it)->is_logged_in(); |
| 1320 // Single user check here is necessary because owner info might not be | 1318 // Single user check here is necessary because owner info might not be |
| 1321 // available when running into login screen on first boot. | 1319 // available when running into login screen on first boot. |
| 1322 // See http://crosbug.com/12723 | 1320 // See http://crosbug.com/12723 |
| 1323 bool can_remove_user = !single_user && !email.empty() && !is_owner && | 1321 bool can_remove_user = !single_user && !email.empty() && !is_owner && |
| 1324 !is_public_account && !signed_in && !is_signin_to_add; | 1322 !is_public_account && !signed_in && !is_signin_to_add; |
| 1325 user_dict->SetBoolean(kKeyCanRemove, can_remove_user); | 1323 user_dict->SetBoolean(kKeyCanRemove, can_remove_user); |
| 1326 | 1324 |
| 1327 if (!is_owner) | 1325 if (!is_owner) |
| 1328 ++non_owner_count; | 1326 ++non_owner_count; |
| 1329 // public accounts come first in the list | 1327 |
| 1330 if (is_public_account) { | 1328 users_list.Append(user_dict); |
| 1331 users_list.Insert(first_non_public_account_index++, user_dict); | |
| 1332 } else { | |
| 1333 users_list.Append(user_dict); | |
| 1334 } | |
| 1335 } | 1329 } |
| 1336 } | 1330 } |
| 1337 while (users_list.GetSize() > kMaxUsers) | 1331 while (users_list.GetSize() > kMaxUsers) |
| 1338 users_list.Remove(kMaxUsers, NULL); | 1332 users_list.Remove(kMaxUsers, NULL); |
| 1339 | 1333 |
| 1340 CallJS("login.AccountPickerScreen.loadUsers", users_list, animated, | 1334 CallJS("login.AccountPickerScreen.loadUsers", users_list, animated, |
| 1341 delegate_->IsShowGuest()); | 1335 delegate_->IsShowGuest()); |
| 1342 } | 1336 } |
| 1343 | 1337 |
| 1344 void SigninScreenHandler::HandleAccountPickerReady() { | 1338 void SigninScreenHandler::HandleAccountPickerReady() { |
| (...skipping 383 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1728 DCHECK(gaia_screen_handler_); | 1722 DCHECK(gaia_screen_handler_); |
| 1729 return gaia_screen_handler_->frame_state(); | 1723 return gaia_screen_handler_->frame_state(); |
| 1730 } | 1724 } |
| 1731 | 1725 |
| 1732 net::Error SigninScreenHandler::FrameError() const { | 1726 net::Error SigninScreenHandler::FrameError() const { |
| 1733 DCHECK(gaia_screen_handler_); | 1727 DCHECK(gaia_screen_handler_); |
| 1734 return gaia_screen_handler_->frame_error(); | 1728 return gaia_screen_handler_->frame_error(); |
| 1735 } | 1729 } |
| 1736 | 1730 |
| 1737 } // namespace chromeos | 1731 } // namespace chromeos |
| OLD | NEW |