| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
| 9 #include "base/callback.h" | 9 #include "base/callback.h" |
| 10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
| (...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 60 const char kGaiaExtStartPage[] = | 60 const char kGaiaExtStartPage[] = |
| 61 "chrome-extension://mfffpogegjflfpflabcdkioaeobkgjik/main.html"; | 61 "chrome-extension://mfffpogegjflfpflabcdkioaeobkgjik/main.html"; |
| 62 // Same as above but offline version. | 62 // Same as above but offline version. |
| 63 const char kGaiaExtStartPageOffline[] = | 63 const char kGaiaExtStartPageOffline[] = |
| 64 "chrome-extension://mfffpogegjflfpflabcdkioaeobkgjik/offline.html"; | 64 "chrome-extension://mfffpogegjflfpflabcdkioaeobkgjik/offline.html"; |
| 65 | 65 |
| 66 // User dictionary keys. | 66 // User dictionary keys. |
| 67 const char kKeyUsername[] = "username"; | 67 const char kKeyUsername[] = "username"; |
| 68 const char kKeyDisplayName[] = "displayName"; | 68 const char kKeyDisplayName[] = "displayName"; |
| 69 const char kKeyEmailAddress[] = "emailAddress"; | 69 const char kKeyEmailAddress[] = "emailAddress"; |
| 70 const char kKeyEnterpriseDomain[] = "enterpriseDomain"; |
| 70 const char kKeyNameTooltip[] = "nameTooltip"; | 71 const char kKeyNameTooltip[] = "nameTooltip"; |
| 72 const char kKeyPublicAccount[] = "publicAccount"; |
| 71 const char kKeySignedIn[] = "signedIn"; | 73 const char kKeySignedIn[] = "signedIn"; |
| 72 const char kKeyCanRemove[] = "canRemove"; | 74 const char kKeyCanRemove[] = "canRemove"; |
| 73 const char kKeyOauthTokenStatus[] = "oauthTokenStatus"; | 75 const char kKeyOauthTokenStatus[] = "oauthTokenStatus"; |
| 74 | 76 |
| 75 // Max number of users to show. | 77 // Max number of users to show. |
| 76 const size_t kMaxUsers = 5; | 78 const size_t kMaxUsers = 5; |
| 77 | 79 |
| 78 // The Task posted to PostTaskAndReply in StartClearingDnsCache on the IO | 80 // The Task posted to PostTaskAndReply in StartClearingDnsCache on the IO |
| 79 // thread. | 81 // thread. |
| 80 void ClearDnsCache(IOThread* io_thread) { | 82 void ClearDnsCache(IOThread* io_thread) { |
| (...skipping 16 matching lines...) Expand all Loading... |
| 97 const CrosSettings* cros_settings) { | 99 const CrosSettings* cros_settings) { |
| 98 bool allow_new_user = true; | 100 bool allow_new_user = true; |
| 99 cros_settings->GetBoolean(kAccountsPrefAllowNewUser, &allow_new_user); | 101 cros_settings->GetBoolean(kAccountsPrefAllowNewUser, &allow_new_user); |
| 100 bool allow_guest = true; | 102 bool allow_guest = true; |
| 101 cros_settings->GetBoolean(kAccountsPrefAllowGuest, &allow_guest); | 103 cros_settings->GetBoolean(kAccountsPrefAllowGuest, &allow_guest); |
| 102 // Account creation depends on Guest sign-in (http://crosbug.com/24570). | 104 // Account creation depends on Guest sign-in (http://crosbug.com/24570). |
| 103 params->SetBoolean("createAccount", allow_new_user && allow_guest); | 105 params->SetBoolean("createAccount", allow_new_user && allow_guest); |
| 104 params->SetBoolean("guestSignin", allow_guest); | 106 params->SetBoolean("guestSignin", allow_guest); |
| 105 } | 107 } |
| 106 | 108 |
| 107 } // namespace | 109 } // namespace |
| 108 | 110 |
| 109 // SigninScreenHandler implementation ------------------------------------------ | 111 // SigninScreenHandler implementation ------------------------------------------ |
| 110 | 112 |
| 111 SigninScreenHandler::SigninScreenHandler( | 113 SigninScreenHandler::SigninScreenHandler( |
| 112 const scoped_refptr<NetworkStateInformer>& network_state_informer) | 114 const scoped_refptr<NetworkStateInformer>& network_state_informer) |
| 113 : delegate_(NULL), | 115 : delegate_(NULL), |
| 114 native_window_delegate_(NULL), | 116 native_window_delegate_(NULL), |
| 115 show_on_init_(false), | 117 show_on_init_(false), |
| 116 oobe_ui_(false), | 118 oobe_ui_(false), |
| 117 focus_stolen_(false), | 119 focus_stolen_(false), |
| (...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 188 localized_strings->SetString("errorTpmFailureReboot", | 190 localized_strings->SetString("errorTpmFailureReboot", |
| 189 l10n_util::GetStringFUTF16( | 191 l10n_util::GetStringFUTF16( |
| 190 IDS_LOGIN_ERROR_TPM_FAILURE_REBOOT, | 192 IDS_LOGIN_ERROR_TPM_FAILURE_REBOOT, |
| 191 l10n_util::GetStringUTF16(IDS_SHORT_PRODUCT_NAME))); | 193 l10n_util::GetStringUTF16(IDS_SHORT_PRODUCT_NAME))); |
| 192 localized_strings->SetString("disabledAddUserTooltip", | 194 localized_strings->SetString("disabledAddUserTooltip", |
| 193 l10n_util::GetStringUTF16( | 195 l10n_util::GetStringUTF16( |
| 194 g_browser_process->browser_policy_connector()->IsEnterpriseManaged() ? | 196 g_browser_process->browser_policy_connector()->IsEnterpriseManaged() ? |
| 195 IDS_DISABLED_ADD_USER_TOOLTIP_ENTERPRISE : | 197 IDS_DISABLED_ADD_USER_TOOLTIP_ENTERPRISE : |
| 196 IDS_DISABLED_ADD_USER_TOOLTIP)); | 198 IDS_DISABLED_ADD_USER_TOOLTIP)); |
| 197 | 199 |
| 200 localized_strings->SetString("publicAccountInfoFormat", |
| 201 l10n_util::GetStringUTF16(IDS_LOGIN_PUBLIC_ACCOUNT_INFO_FORMAT)); |
| 202 localized_strings->SetString("publicAccountReminder", |
| 203 l10n_util::GetStringUTF16(IDS_LOGIN_PUBLIC_ACCOUNT_SIGNOUT_REMINDER)); |
| 204 localized_strings->SetString("publicAccountEnter", |
| 205 l10n_util::GetStringUTF16(IDS_LOGIN_PUBLIC_ACCOUNT_ENTER)); |
| 206 |
| 198 if (chromeos::KioskModeSettings::Get()->IsKioskModeEnabled()) { | 207 if (chromeos::KioskModeSettings::Get()->IsKioskModeEnabled()) { |
| 199 localized_strings->SetString("demoLoginMessage", | 208 localized_strings->SetString("demoLoginMessage", |
| 200 l10n_util::GetStringUTF16(IDS_KIOSK_MODE_LOGIN_MESSAGE)); | 209 l10n_util::GetStringUTF16(IDS_KIOSK_MODE_LOGIN_MESSAGE)); |
| 201 } | 210 } |
| 202 } | 211 } |
| 203 | 212 |
| 204 void SigninScreenHandler::Show(bool oobe_ui) { | 213 void SigninScreenHandler::Show(bool oobe_ui) { |
| 205 CHECK(delegate_); | 214 CHECK(delegate_); |
| 206 oobe_ui_ = oobe_ui; | 215 oobe_ui_ = oobe_ui; |
| 207 if (!page_is_ready()) { | 216 if (!page_is_ready()) { |
| (...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 281 base::Unretained(this))); | 290 base::Unretained(this))); |
| 282 web_ui()->RegisterMessageCallback("getUsers", | 291 web_ui()->RegisterMessageCallback("getUsers", |
| 283 base::Bind(&SigninScreenHandler::HandleGetUsers, | 292 base::Bind(&SigninScreenHandler::HandleGetUsers, |
| 284 base::Unretained(this))); | 293 base::Unretained(this))); |
| 285 web_ui()->RegisterMessageCallback("launchDemoUser", | 294 web_ui()->RegisterMessageCallback("launchDemoUser", |
| 286 base::Bind(&SigninScreenHandler::HandleLaunchDemoUser, | 295 base::Bind(&SigninScreenHandler::HandleLaunchDemoUser, |
| 287 base::Unretained(this))); | 296 base::Unretained(this))); |
| 288 web_ui()->RegisterMessageCallback("launchIncognito", | 297 web_ui()->RegisterMessageCallback("launchIncognito", |
| 289 base::Bind(&SigninScreenHandler::HandleLaunchIncognito, | 298 base::Bind(&SigninScreenHandler::HandleLaunchIncognito, |
| 290 base::Unretained(this))); | 299 base::Unretained(this))); |
| 300 web_ui()->RegisterMessageCallback("launchPublicAccount", |
| 301 base::Bind(&SigninScreenHandler::HandleLaunchPublicAccount, |
| 302 base::Unretained(this))); |
| 291 web_ui()->RegisterMessageCallback("offlineLogin", | 303 web_ui()->RegisterMessageCallback("offlineLogin", |
| 292 base::Bind(&SigninScreenHandler::HandleOfflineLogin, | 304 base::Bind(&SigninScreenHandler::HandleOfflineLogin, |
| 293 base::Unretained(this))); | 305 base::Unretained(this))); |
| 294 web_ui()->RegisterMessageCallback("showAddUser", | 306 web_ui()->RegisterMessageCallback("showAddUser", |
| 295 base::Bind(&SigninScreenHandler::HandleShowAddUser, | 307 base::Bind(&SigninScreenHandler::HandleShowAddUser, |
| 296 base::Unretained(this))); | 308 base::Unretained(this))); |
| 297 web_ui()->RegisterMessageCallback("shutdownSystem", | 309 web_ui()->RegisterMessageCallback("shutdownSystem", |
| 298 base::Bind(&SigninScreenHandler::HandleShutdownSystem, | 310 base::Bind(&SigninScreenHandler::HandleShutdownSystem, |
| 299 base::Unretained(this))); | 311 base::Unretained(this))); |
| 300 web_ui()->RegisterMessageCallback("loadWallpaper", | 312 web_ui()->RegisterMessageCallback("loadWallpaper", |
| (...skipping 315 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 616 void SigninScreenHandler::HandleLaunchDemoUser(const base::ListValue* args) { | 628 void SigninScreenHandler::HandleLaunchDemoUser(const base::ListValue* args) { |
| 617 if (delegate_) | 629 if (delegate_) |
| 618 delegate_->LoginAsRetailModeUser(); | 630 delegate_->LoginAsRetailModeUser(); |
| 619 } | 631 } |
| 620 | 632 |
| 621 void SigninScreenHandler::HandleLaunchIncognito(const base::ListValue* args) { | 633 void SigninScreenHandler::HandleLaunchIncognito(const base::ListValue* args) { |
| 622 if (delegate_) | 634 if (delegate_) |
| 623 delegate_->LoginAsGuest(); | 635 delegate_->LoginAsGuest(); |
| 624 } | 636 } |
| 625 | 637 |
| 638 void SigninScreenHandler::HandleLaunchPublicAccount( |
| 639 const base::ListValue* args) { |
| 640 // TODO(bartfab): Wire this with real public account signin. |
| 641 } |
| 642 |
| 626 void SigninScreenHandler::HandleOfflineLogin(const base::ListValue* args) { | 643 void SigninScreenHandler::HandleOfflineLogin(const base::ListValue* args) { |
| 627 if (!delegate_ || delegate_->IsShowUsers()) { | 644 if (!delegate_ || delegate_->IsShowUsers()) { |
| 628 NOTREACHED(); | 645 NOTREACHED(); |
| 629 return; | 646 return; |
| 630 } | 647 } |
| 631 if (!args->GetString(0, &email_)) | 648 if (!args->GetString(0, &email_)) |
| 632 email_.clear(); | 649 email_.clear(); |
| 633 | 650 |
| 634 // Load auth extension. Parameters are: force reload, do not load extension in | 651 // Load auth extension. Parameters are: force reload, do not load extension in |
| 635 // background, use offline version. | 652 // background, use offline version. |
| (...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 728 | 745 |
| 729 ListValue users_list; | 746 ListValue users_list; |
| 730 const UserList& users = delegate_->GetUsers(); | 747 const UserList& users = delegate_->GetUsers(); |
| 731 | 748 |
| 732 bool single_user = users.size() == 1; | 749 bool single_user = users.size() == 1; |
| 733 for (UserList::const_iterator it = users.begin(); it != users.end(); ++it) { | 750 for (UserList::const_iterator it = users.begin(); it != users.end(); ++it) { |
| 734 const std::string& email = (*it)->email(); | 751 const std::string& email = (*it)->email(); |
| 735 std::string owner; | 752 std::string owner; |
| 736 chromeos::CrosSettings::Get()->GetString(chromeos::kDeviceOwner, &owner); | 753 chromeos::CrosSettings::Get()->GetString(chromeos::kDeviceOwner, &owner); |
| 737 bool is_owner = (email == owner); | 754 bool is_owner = (email == owner); |
| 755 bool public_account = ((*it)->GetType() == User::USER_TYPE_PUBLIC_ACCOUNT); |
| 738 bool signed_in = *it == UserManager::Get()->GetLoggedInUser(); | 756 bool signed_in = *it == UserManager::Get()->GetLoggedInUser(); |
| 739 | 757 |
| 740 if (non_owner_count < max_non_owner_users || is_owner) { | 758 if (non_owner_count < max_non_owner_users || is_owner) { |
| 741 DictionaryValue* user_dict = new DictionaryValue(); | 759 DictionaryValue* user_dict = new DictionaryValue(); |
| 742 user_dict->SetString(kKeyUsername, email); | 760 user_dict->SetString(kKeyUsername, email); |
| 743 user_dict->SetString(kKeyEmailAddress, (*it)->display_email()); | 761 user_dict->SetString(kKeyEmailAddress, (*it)->display_email()); |
| 744 user_dict->SetString(kKeyDisplayName, (*it)->GetDisplayName()); | 762 user_dict->SetString(kKeyDisplayName, (*it)->GetDisplayName()); |
| 745 user_dict->SetString(kKeyNameTooltip, (*it)->display_email()); | 763 user_dict->SetString(kKeyNameTooltip, (*it)->display_email()); |
| 764 user_dict->SetBoolean(kKeyPublicAccount, public_account); |
| 746 user_dict->SetInteger(kKeyOauthTokenStatus, (*it)->oauth_token_status()); | 765 user_dict->SetInteger(kKeyOauthTokenStatus, (*it)->oauth_token_status()); |
| 747 user_dict->SetBoolean(kKeySignedIn, signed_in); | 766 user_dict->SetBoolean(kKeySignedIn, signed_in); |
| 748 | 767 |
| 768 if (public_account) { |
| 769 policy::BrowserPolicyConnector* policy_connector = |
| 770 g_browser_process->browser_policy_connector(); |
| 771 |
| 772 if (policy_connector->IsEnterpriseManaged()) { |
| 773 user_dict->SetString(kKeyEnterpriseDomain, |
| 774 policy_connector->GetEnterpriseDomain()); |
| 775 } |
| 776 } |
| 777 |
| 749 // Single user check here is necessary because owner info might not be | 778 // Single user check here is necessary because owner info might not be |
| 750 // available when running into login screen on first boot. | 779 // available when running into login screen on first boot. |
| 751 // See http://crosbug.com/12723 | 780 // See http://crosbug.com/12723 |
| 752 user_dict->SetBoolean(kKeyCanRemove, | 781 user_dict->SetBoolean(kKeyCanRemove, |
| 753 !single_user && | 782 !single_user && |
| 754 !email.empty() && | 783 !email.empty() && |
| 755 !is_owner && | 784 !is_owner && |
| 785 !public_account && |
| 756 !signed_in); | 786 !signed_in); |
| 757 | 787 |
| 758 users_list.Append(user_dict); | 788 users_list.Append(user_dict); |
| 759 if (!is_owner) | 789 if (!is_owner) |
| 760 ++non_owner_count; | 790 ++non_owner_count; |
| 761 } | 791 } |
| 762 } | 792 } |
| 763 | 793 |
| 764 base::FundamentalValue animated_value(animated); | 794 base::FundamentalValue animated_value(animated); |
| 765 base::FundamentalValue guest_value(delegate_->IsShowGuest()); | 795 base::FundamentalValue guest_value(delegate_->IsShowGuest()); |
| (...skipping 234 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1000 ConnectionType last_network_type) { | 1030 ConnectionType last_network_type) { |
| 1001 base::FundamentalValue state_value(state); | 1031 base::FundamentalValue state_value(state); |
| 1002 base::StringValue network_value(network_name); | 1032 base::StringValue network_value(network_name); |
| 1003 base::StringValue reason_value(reason); | 1033 base::StringValue reason_value(reason); |
| 1004 base::FundamentalValue last_network_value(last_network_type); | 1034 base::FundamentalValue last_network_value(last_network_type); |
| 1005 web_ui()->CallJavascriptFunction(callback, | 1035 web_ui()->CallJavascriptFunction(callback, |
| 1006 state_value, network_value, reason_value, last_network_value); | 1036 state_value, network_value, reason_value, last_network_value); |
| 1007 } | 1037 } |
| 1008 | 1038 |
| 1009 } // namespace chromeos | 1039 } // namespace chromeos |
| OLD | NEW |