Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 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/signin/user_manager_screen_handler.h" | 5 #include "chrome/browser/ui/webui/signin/user_manager_screen_handler.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/location.h" | 8 #include "base/location.h" |
| 9 #include "base/prefs/pref_service.h" | 9 #include "base/prefs/pref_service.h" |
| 10 #include "base/profiler/scoped_tracker.h" | 10 #include "base/profiler/scoped_tracker.h" |
| (...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 74 // JS API callback names. | 74 // JS API callback names. |
| 75 const char kJsApiUserManagerInitialize[] = "userManagerInitialize"; | 75 const char kJsApiUserManagerInitialize[] = "userManagerInitialize"; |
| 76 const char kJsApiUserManagerAddUser[] = "addUser"; | 76 const char kJsApiUserManagerAddUser[] = "addUser"; |
| 77 const char kJsApiUserManagerAuthLaunchUser[] = "authenticatedLaunchUser"; | 77 const char kJsApiUserManagerAuthLaunchUser[] = "authenticatedLaunchUser"; |
| 78 const char kJsApiUserManagerLaunchGuest[] = "launchGuest"; | 78 const char kJsApiUserManagerLaunchGuest[] = "launchGuest"; |
| 79 const char kJsApiUserManagerLaunchUser[] = "launchUser"; | 79 const char kJsApiUserManagerLaunchUser[] = "launchUser"; |
| 80 const char kJsApiUserManagerRemoveUser[] = "removeUser"; | 80 const char kJsApiUserManagerRemoveUser[] = "removeUser"; |
| 81 const char kJsApiUserManagerAttemptUnlock[] = "attemptUnlock"; | 81 const char kJsApiUserManagerAttemptUnlock[] = "attemptUnlock"; |
| 82 const char kJsApiUserManagerLogRemoveUserWarningShown[] = | 82 const char kJsApiUserManagerLogRemoveUserWarningShown[] = |
| 83 "logRemoveUserWarningShown"; | 83 "logRemoveUserWarningShown"; |
| 84 | 84 const char kJsApiUserManagerRemoveUserWarningLoadStats[] = |
| 85 "removeUserWarningLoadStats"; | |
| 85 const size_t kAvatarIconSize = 180; | 86 const size_t kAvatarIconSize = 180; |
| 86 const int kMaxOAuthRetries = 3; | 87 const int kMaxOAuthRetries = 3; |
| 87 | 88 |
| 88 void HandleAndDoNothing(const base::ListValue* args) { | 89 void HandleAndDoNothing(const base::ListValue* args) { |
| 89 } | 90 } |
| 90 | 91 |
| 91 // This callback is run if the only profile has been deleted, and a new | 92 // This callback is run if the only profile has been deleted, and a new |
| 92 // profile has been created to replace it. | 93 // profile has been created to replace it. |
| 93 void OpenNewWindowForProfile( | 94 void OpenNewWindowForProfile( |
| 94 chrome::HostDesktopType desktop_type, | 95 chrome::HostDesktopType desktop_type, |
| (...skipping 446 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 541 const base::ListValue* args) { | 542 const base::ListValue* args) { |
| 542 std::string email; | 543 std::string email; |
| 543 CHECK(args->GetString(0, &email)); | 544 CHECK(args->GetString(0, &email)); |
| 544 SetAuthType( | 545 SetAuthType( |
| 545 email, | 546 email, |
| 546 proximity_auth::ScreenlockBridge::LockHandler::FORCE_OFFLINE_PASSWORD, | 547 proximity_auth::ScreenlockBridge::LockHandler::FORCE_OFFLINE_PASSWORD, |
| 547 base::string16()); | 548 base::string16()); |
| 548 HideUserPodCustomIcon(email); | 549 HideUserPodCustomIcon(email); |
| 549 } | 550 } |
| 550 | 551 |
| 552 void UserManagerScreenHandler::HandleRemoveUserWarningLoadStats( | |
| 553 const base::ListValue* args) { | |
| 554 const base::Value* profile_path_value; | |
| 555 | |
| 556 if (args->Get(0, &profile_path_value)) { | |
| 557 base::FilePath* profile_path = new base::FilePath(); | |
|
Mike Lerman
2015/08/05 19:26:09
Please create this on the stack rather the using n
lwchkg
2015/08/06 04:32:59
Acknowledged. I was worrying too much about copy a
| |
| 558 | |
| 559 if (base::GetValueAsFilePath(*profile_path_value, profile_path)) { | |
| 560 base::StringValue return_profile_path(profile_path->value()); | |
| 561 Profile* profile = g_browser_process->profile_manager()-> | |
| 562 GetProfileByPath(*profile_path); | |
| 563 | |
| 564 if (profile) { | |
| 565 profiles::GetProfileStatistics( | |
| 566 profile, | |
| 567 base::Bind( | |
| 568 &UserManagerScreenHandler::RemoveUserDialogLoadStatsCallback, | |
| 569 weak_ptr_factory_.GetWeakPtr(), base::Owned(profile_path)), | |
| 570 &tracker); | |
| 571 web_ui()->CallJavascriptFunction("updateRemoveWarningDialogHasNoStats", | |
| 572 return_profile_path, base::FundamentalValue(false)); | |
| 573 return; | |
| 574 } | |
| 575 web_ui()->CallJavascriptFunction("updateRemoveWarningDialogHasNoStats", | |
| 576 return_profile_path, base::FundamentalValue(true)); | |
| 577 } | |
| 578 delete profile_path; | |
| 579 } | |
| 580 } | |
| 581 | |
| 582 void UserManagerScreenHandler::RemoveUserDialogLoadStatsCallback( | |
| 583 const base::FilePath* profile_path, | |
| 584 profiles::ProfileStatisticsValues result) { | |
| 585 // Copy result into return_value. | |
| 586 base::StringValue return_profile_path(profile_path->value()); | |
| 587 base::DictionaryValue return_value; | |
| 588 for (profiles::ProfileStatisticsValues::const_iterator | |
| 589 iter = result.begin(); iter != result.end(); iter++) { | |
| 590 return_value.SetIntegerWithoutPathExpansion(iter->first, iter->second); | |
| 591 } | |
| 592 web_ui()->CallJavascriptFunction("updateRemoveWarningDialog", | |
| 593 return_profile_path, return_value); | |
| 594 } | |
| 595 | |
| 551 void UserManagerScreenHandler::OnGetTokenInfoResponse( | 596 void UserManagerScreenHandler::OnGetTokenInfoResponse( |
| 552 scoped_ptr<base::DictionaryValue> token_info) { | 597 scoped_ptr<base::DictionaryValue> token_info) { |
| 553 // Password is unchanged so user just mistyped it. Ask again. | 598 // Password is unchanged so user just mistyped it. Ask again. |
| 554 ReportAuthenticationResult(false, ProfileMetrics::AUTH_FAILED); | 599 ReportAuthenticationResult(false, ProfileMetrics::AUTH_FAILED); |
| 555 } | 600 } |
| 556 | 601 |
| 557 void UserManagerScreenHandler::OnOAuthError() { | 602 void UserManagerScreenHandler::OnOAuthError() { |
| 558 // Password has changed. Go through online signin flow. | 603 // Password has changed. Go through online signin flow. |
| 559 DCHECK(!email_address_.empty()); | 604 DCHECK(!email_address_.empty()); |
| 560 oauth_client_.reset(); | 605 oauth_client_.reset(); |
| (...skipping 24 matching lines...) Expand all Loading... | |
| 585 base::Bind(&UserManagerScreenHandler::HandleLaunchUser, | 630 base::Bind(&UserManagerScreenHandler::HandleLaunchUser, |
| 586 base::Unretained(this))); | 631 base::Unretained(this))); |
| 587 web_ui()->RegisterMessageCallback(kJsApiUserManagerRemoveUser, | 632 web_ui()->RegisterMessageCallback(kJsApiUserManagerRemoveUser, |
| 588 base::Bind(&UserManagerScreenHandler::HandleRemoveUser, | 633 base::Bind(&UserManagerScreenHandler::HandleRemoveUser, |
| 589 base::Unretained(this))); | 634 base::Unretained(this))); |
| 590 web_ui()->RegisterMessageCallback(kJsApiUserManagerAttemptUnlock, | 635 web_ui()->RegisterMessageCallback(kJsApiUserManagerAttemptUnlock, |
| 591 base::Bind(&UserManagerScreenHandler::HandleAttemptUnlock, | 636 base::Bind(&UserManagerScreenHandler::HandleAttemptUnlock, |
| 592 base::Unretained(this))); | 637 base::Unretained(this))); |
| 593 web_ui()->RegisterMessageCallback(kJsApiUserManagerLogRemoveUserWarningShown, | 638 web_ui()->RegisterMessageCallback(kJsApiUserManagerLogRemoveUserWarningShown, |
| 594 base::Bind(&HandleLogRemoveUserWarningShown)); | 639 base::Bind(&HandleLogRemoveUserWarningShown)); |
| 640 web_ui()->RegisterMessageCallback(kJsApiUserManagerRemoveUserWarningLoadStats, | |
| 641 base::Bind(&UserManagerScreenHandler::HandleRemoveUserWarningLoadStats, | |
| 642 base::Unretained(this))); | |
| 595 | 643 |
| 596 const content::WebUI::MessageCallback& kDoNothingCallback = | 644 const content::WebUI::MessageCallback& kDoNothingCallback = |
| 597 base::Bind(&HandleAndDoNothing); | 645 base::Bind(&HandleAndDoNothing); |
| 598 | 646 |
| 599 // Unused callbacks from screen_account_picker.js | 647 // Unused callbacks from screen_account_picker.js |
| 600 web_ui()->RegisterMessageCallback("accountPickerReady", kDoNothingCallback); | 648 web_ui()->RegisterMessageCallback("accountPickerReady", kDoNothingCallback); |
| 601 web_ui()->RegisterMessageCallback("loginUIStateChanged", kDoNothingCallback); | 649 web_ui()->RegisterMessageCallback("loginUIStateChanged", kDoNothingCallback); |
| 602 web_ui()->RegisterMessageCallback("hideCaptivePortal", kDoNothingCallback); | 650 web_ui()->RegisterMessageCallback("hideCaptivePortal", kDoNothingCallback); |
| 603 web_ui()->RegisterMessageCallback("getTouchViewState", kDoNothingCallback); | 651 web_ui()->RegisterMessageCallback("getTouchViewState", kDoNothingCallback); |
| 604 // Unused callbacks from display_manager.js | 652 // Unused callbacks from display_manager.js |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 641 IDS_LOGIN_POD_MENU_REMOVE_ITEM_ACCESSIBLE_NAME)); | 689 IDS_LOGIN_POD_MENU_REMOVE_ITEM_ACCESSIBLE_NAME)); |
| 642 localized_strings->SetString("removeUser", | 690 localized_strings->SetString("removeUser", |
| 643 l10n_util::GetStringUTF16(IDS_LOGIN_POD_USER_REMOVE_WARNING_BUTTON)); | 691 l10n_util::GetStringUTF16(IDS_LOGIN_POD_USER_REMOVE_WARNING_BUTTON)); |
| 644 localized_strings->SetString("passwordFieldAccessibleName", | 692 localized_strings->SetString("passwordFieldAccessibleName", |
| 645 l10n_util::GetStringUTF16(IDS_LOGIN_POD_PASSWORD_FIELD_ACCESSIBLE_NAME)); | 693 l10n_util::GetStringUTF16(IDS_LOGIN_POD_PASSWORD_FIELD_ACCESSIBLE_NAME)); |
| 646 localized_strings->SetString("bootIntoWallpaper", "off"); | 694 localized_strings->SetString("bootIntoWallpaper", "off"); |
| 647 | 695 |
| 648 // For AccountPickerScreen, the remove user warning overlay. | 696 // For AccountPickerScreen, the remove user warning overlay. |
| 649 localized_strings->SetString("removeUserWarningButtonTitle", | 697 localized_strings->SetString("removeUserWarningButtonTitle", |
| 650 l10n_util::GetStringUTF16(IDS_LOGIN_POD_USER_REMOVE_WARNING_BUTTON)); | 698 l10n_util::GetStringUTF16(IDS_LOGIN_POD_USER_REMOVE_WARNING_BUTTON)); |
| 651 localized_strings->SetString("removeUserWarningText", | 699 localized_strings->SetString("removeUserWarningTextNonSync", |
| 652 l10n_util::GetStringUTF16(IDS_LOGIN_POD_USER_REMOVE_WARNING)); | 700 l10n_util::GetStringUTF16(IDS_LOGIN_POD_USER_REMOVE_WARNING_NONSYNC)); |
| 701 localized_strings->SetString("removeUserWarningTextNonSyncNoStats", | |
| 702 l10n_util::GetStringUTF16( | |
| 703 IDS_LOGIN_POD_USER_REMOVE_WARNING_NONSYNC_NOSTATS)); | |
| 704 localized_strings->SetString("removeUserWarningTextHistory", | |
| 705 l10n_util::GetStringUTF16(IDS_LOGIN_POD_USER_REMOVE_WARNING_HISTORY)); | |
| 706 localized_strings->SetString("removeUserWarningTextPasswords", | |
| 707 l10n_util::GetStringUTF16(IDS_LOGIN_POD_USER_REMOVE_WARNING_PASSWORDS)); | |
| 708 localized_strings->SetString("removeUserWarningTextBookmarks", | |
| 709 l10n_util::GetStringUTF16(IDS_LOGIN_POD_USER_REMOVE_WARNING_BOOKMARKS)); | |
| 710 localized_strings->SetString("removeUserWarningTextSettings", | |
| 711 l10n_util::GetStringUTF16(IDS_LOGIN_POD_USER_REMOVE_WARNING_SETTINGS)); | |
| 712 localized_strings->SetString("removeUserWarningTextCalculating", | |
| 713 l10n_util::GetStringUTF16(IDS_LOGIN_POD_USER_REMOVE_WARNING_CALCULATING)); | |
| 714 localized_strings->SetString("removeUserWarningTextSync", | |
| 715 l10n_util::GetStringUTF16(IDS_LOGIN_POD_USER_REMOVE_WARNING_SYNC)); | |
| 716 localized_strings->SetString("removeUserWarningTextSyncNoStats", | |
| 717 l10n_util::GetStringUTF16( | |
| 718 IDS_LOGIN_POD_USER_REMOVE_WARNING_SYNC_NOSTATS)); | |
| 719 localized_strings->SetString("removeUserWarningManageLinkSync", | |
| 720 l10n_util::GetStringUTF16( | |
| 721 IDS_LOGIN_POD_USER_REMOVE_WARNING_MANAGE_LINK_SYNC)); | |
| 653 localized_strings->SetString("removeLegacySupervisedUserWarningText", | 722 localized_strings->SetString("removeLegacySupervisedUserWarningText", |
| 654 l10n_util::GetStringFUTF16( | 723 l10n_util::GetStringFUTF16( |
| 655 IDS_LOGIN_POD_LEGACY_SUPERVISED_USER_REMOVE_WARNING, | 724 IDS_LOGIN_POD_LEGACY_SUPERVISED_USER_REMOVE_WARNING, |
| 656 base::UTF8ToUTF16(chrome::kSupervisedUserManagementDisplayURL))); | 725 base::UTF8ToUTF16(chrome::kSupervisedUserManagementDisplayURL))); |
| 657 | 726 |
| 658 // Strings needed for the User Manager tutorial slides. | 727 // Strings needed for the User Manager tutorial slides. |
| 659 localized_strings->SetString("tutorialNext", | 728 localized_strings->SetString("tutorialNext", |
| 660 l10n_util::GetStringUTF16(IDS_USER_MANAGER_TUTORIAL_NEXT)); | 729 l10n_util::GetStringUTF16(IDS_USER_MANAGER_TUTORIAL_NEXT)); |
| 661 localized_strings->SetString("tutorialDone", | 730 localized_strings->SetString("tutorialDone", |
| 662 l10n_util::GetStringUTF16(IDS_USER_MANAGER_TUTORIAL_DONE)); | 731 l10n_util::GetStringUTF16(IDS_USER_MANAGER_TUTORIAL_DONE)); |
| (...skipping 176 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 839 Profile* profile, Profile::CreateStatus profile_create_status) { | 908 Profile* profile, Profile::CreateStatus profile_create_status) { |
| 840 Browser* browser = chrome::FindAnyBrowser(profile, false, desktop_type_); | 909 Browser* browser = chrome::FindAnyBrowser(profile, false, desktop_type_); |
| 841 if (browser && browser->window()) { | 910 if (browser && browser->window()) { |
| 842 OnBrowserWindowReady(browser); | 911 OnBrowserWindowReady(browser); |
| 843 } else { | 912 } else { |
| 844 registrar_.Add(this, | 913 registrar_.Add(this, |
| 845 chrome::NOTIFICATION_BROWSER_WINDOW_READY, | 914 chrome::NOTIFICATION_BROWSER_WINDOW_READY, |
| 846 content::NotificationService::AllSources()); | 915 content::NotificationService::AllSources()); |
| 847 } | 916 } |
| 848 } | 917 } |
| OLD | NEW |