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

Side by Side Diff: chrome/browser/chromeos/login/existing_user_controller.cc

Issue 2692163003: cros: Add enterprise user session metrics (Closed)
Patch Set: update sparse histogram comment Created 3 years, 10 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
OLDNEW
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/chromeos/login/existing_user_controller.h" 5 #include "chrome/browser/chromeos/login/existing_user_controller.h"
6 6
7 #include <memory> 7 #include <memory>
8 #include <vector> 8 #include <vector>
9 9
10 #include "base/bind.h" 10 #include "base/bind.h"
11 #include "base/bind_helpers.h" 11 #include "base/bind_helpers.h"
12 #include "base/callback.h" 12 #include "base/callback.h"
13 #include "base/command_line.h" 13 #include "base/command_line.h"
14 #include "base/logging.h" 14 #include "base/logging.h"
15 #include "base/message_loop/message_loop.h" 15 #include "base/message_loop/message_loop.h"
16 #include "base/metrics/histogram_macros.h" 16 #include "base/metrics/histogram_macros.h"
17 #include "base/strings/string_util.h" 17 #include "base/strings/string_util.h"
18 #include "base/strings/utf_string_conversions.h" 18 #include "base/strings/utf_string_conversions.h"
19 #include "base/values.h" 19 #include "base/values.h"
20 #include "base/version.h" 20 #include "base/version.h"
21 #include "chrome/browser/browser_process.h" 21 #include "chrome/browser/browser_process.h"
22 #include "chrome/browser/browser_process_platform_part.h" 22 #include "chrome/browser/browser_process_platform_part.h"
23 #include "chrome/browser/chrome_notification_types.h" 23 #include "chrome/browser/chrome_notification_types.h"
24 #include "chrome/browser/chromeos/boot_times_recorder.h" 24 #include "chrome/browser/chromeos/boot_times_recorder.h"
25 #include "chrome/browser/chromeos/customization/customization_document.h" 25 #include "chrome/browser/chromeos/customization/customization_document.h"
26 #include "chrome/browser/chromeos/login/arc_kiosk_controller.h" 26 #include "chrome/browser/chromeos/login/arc_kiosk_controller.h"
27 #include "chrome/browser/chromeos/login/auth/chrome_login_performer.h" 27 #include "chrome/browser/chromeos/login/auth/chrome_login_performer.h"
28 #include "chrome/browser/chromeos/login/easy_unlock/bootstrap_user_context_initi alizer.h" 28 #include "chrome/browser/chromeos/login/easy_unlock/bootstrap_user_context_initi alizer.h"
29 #include "chrome/browser/chromeos/login/easy_unlock/bootstrap_user_flow.h" 29 #include "chrome/browser/chromeos/login/easy_unlock/bootstrap_user_flow.h"
30 #include "chrome/browser/chromeos/login/enterprise_user_session_metrics.h"
30 #include "chrome/browser/chromeos/login/helper.h" 31 #include "chrome/browser/chromeos/login/helper.h"
31 #include "chrome/browser/chromeos/login/session/user_session_manager.h" 32 #include "chrome/browser/chromeos/login/session/user_session_manager.h"
32 #include "chrome/browser/chromeos/login/signin/oauth2_token_initializer.h" 33 #include "chrome/browser/chromeos/login/signin/oauth2_token_initializer.h"
33 #include "chrome/browser/chromeos/login/signin_specifics.h" 34 #include "chrome/browser/chromeos/login/signin_specifics.h"
34 #include "chrome/browser/chromeos/login/startup_utils.h" 35 #include "chrome/browser/chromeos/login/startup_utils.h"
35 #include "chrome/browser/chromeos/login/ui/login_display_host.h" 36 #include "chrome/browser/chromeos/login/ui/login_display_host.h"
36 #include "chrome/browser/chromeos/login/ui/user_adding_screen.h" 37 #include "chrome/browser/chromeos/login/ui/user_adding_screen.h"
37 #include "chrome/browser/chromeos/login/user_flow.h" 38 #include "chrome/browser/chromeos/login/user_flow.h"
38 #include "chrome/browser/chromeos/login/users/chrome_user_manager.h" 39 #include "chrome/browser/chromeos/login/users/chrome_user_manager.h"
39 #include "chrome/browser/chromeos/login/wizard_controller.h" 40 #include "chrome/browser/chromeos/login/wizard_controller.h"
(...skipping 691 matching lines...) Expand 10 before | Expand all | Expand 10 after
731 user_manager::UserManager::Get()->SaveUserDisplayEmail( 732 user_manager::UserManager::Get()->SaveUserDisplayEmail(
732 user_context.GetAccountId(), display_email_); 733 user_context.GetAccountId(), display_email_);
733 } 734 }
734 if (!display_name_.empty() || !given_name_.empty()) { 735 if (!display_name_.empty() || !given_name_.empty()) {
735 user_manager::UserManager::Get()->UpdateUserAccountData( 736 user_manager::UserManager::Get()->UpdateUserAccountData(
736 user_context.GetAccountId(), 737 user_context.GetAccountId(),
737 user_manager::UserManager::UserAccountData(display_name_, given_name_, 738 user_manager::UserManager::UserAccountData(display_name_, given_name_,
738 std::string() /* locale */)); 739 std::string() /* locale */));
739 } 740 }
740 ClearRecordedNames(); 741 ClearRecordedNames();
742
743 if (g_browser_process->platform_part()
744 ->browser_policy_connector_chromeos()
745 ->IsEnterpriseManaged()) {
746 enterprise_user_session_metrics::RecordSignInEvent(
747 user_context, last_login_attempt_was_auto_login_);
748 }
741 } 749 }
742 750
743 void ExistingUserController::OnProfilePrepared(Profile* profile, 751 void ExistingUserController::OnProfilePrepared(Profile* profile,
744 bool browser_launched) { 752 bool browser_launched) {
745 // Reenable clicking on other windows and status area. 753 // Reenable clicking on other windows and status area.
746 login_display_->SetUIEnabled(true); 754 login_display_->SetUIEnabled(true);
747 755
748 if (browser_launched) 756 if (browser_launched)
749 host_ = nullptr; 757 host_ = nullptr;
750 758
(...skipping 263 matching lines...) Expand 10 before | Expand all | Expand 10 after
1014 void ExistingUserController::ResetAutoLoginTimer() { 1022 void ExistingUserController::ResetAutoLoginTimer() {
1015 // Only restart the auto-login timer if it's already running. 1023 // Only restart the auto-login timer if it's already running.
1016 if (auto_login_timer_ && auto_login_timer_->IsRunning()) { 1024 if (auto_login_timer_ && auto_login_timer_->IsRunning()) {
1017 StopAutoLoginTimer(); 1025 StopAutoLoginTimer();
1018 StartAutoLoginTimer(); 1026 StartAutoLoginTimer();
1019 } 1027 }
1020 } 1028 }
1021 1029
1022 void ExistingUserController::OnPublicSessionAutoLoginTimerFire() { 1030 void ExistingUserController::OnPublicSessionAutoLoginTimerFire() {
1023 CHECK(auto_launch_ready_ && public_session_auto_login_account_id_.is_valid()); 1031 CHECK(auto_launch_ready_ && public_session_auto_login_account_id_.is_valid());
1032 SigninSpecifics signin_specifics;
1033 signin_specifics.is_auto_login = true;
1024 Login(UserContext(user_manager::USER_TYPE_PUBLIC_ACCOUNT, 1034 Login(UserContext(user_manager::USER_TYPE_PUBLIC_ACCOUNT,
1025 public_session_auto_login_account_id_), 1035 public_session_auto_login_account_id_),
1026 SigninSpecifics()); 1036 signin_specifics);
1027 } 1037 }
1028 1038
1029 void ExistingUserController::OnArcKioskAutoLoginTimerFire() { 1039 void ExistingUserController::OnArcKioskAutoLoginTimerFire() {
1030 CHECK(auto_launch_ready_ && (arc_kiosk_auto_login_account_id_.is_valid())); 1040 CHECK(auto_launch_ready_ && (arc_kiosk_auto_login_account_id_.is_valid()));
1041 SigninSpecifics signin_specifics;
1042 signin_specifics.is_auto_login = true;
1031 Login(UserContext(user_manager::USER_TYPE_ARC_KIOSK_APP, 1043 Login(UserContext(user_manager::USER_TYPE_ARC_KIOSK_APP,
1032 arc_kiosk_auto_login_account_id_), 1044 arc_kiosk_auto_login_account_id_),
1033 SigninSpecifics()); 1045 signin_specifics);
1034 } 1046 }
1035 1047
1036 void ExistingUserController::StopAutoLoginTimer() { 1048 void ExistingUserController::StopAutoLoginTimer() {
1037 if (auto_login_timer_) 1049 if (auto_login_timer_)
1038 auto_login_timer_->Stop(); 1050 auto_login_timer_->Stop();
1039 } 1051 }
1040 1052
1041 void ExistingUserController::StartAutoLoginTimer() { 1053 void ExistingUserController::StartAutoLoginTimer() {
1042 if (!auto_launch_ready_ || is_login_in_progress_ || 1054 if (!auto_launch_ready_ || is_login_in_progress_ ||
1043 (!public_session_auto_login_account_id_.is_valid() && 1055 (!public_session_auto_login_account_id_.is_valid() &&
(...skipping 217 matching lines...) Expand 10 before | Expand all | Expand 10 after
1261 user_context, base::Bind(&ExistingUserController::OnOAuth2TokensFetched, 1273 user_context, base::Bind(&ExistingUserController::OnOAuth2TokensFetched,
1262 weak_factory_.GetWeakPtr())); 1274 weak_factory_.GetWeakPtr()));
1263 return; 1275 return;
1264 } 1276 }
1265 1277
1266 PerformLogin(user_context, LoginPerformer::AUTH_MODE_EXTENSION); 1278 PerformLogin(user_context, LoginPerformer::AUTH_MODE_EXTENSION);
1267 } 1279 }
1268 1280
1269 void ExistingUserController::DoLogin(const UserContext& user_context, 1281 void ExistingUserController::DoLogin(const UserContext& user_context,
1270 const SigninSpecifics& specifics) { 1282 const SigninSpecifics& specifics) {
1283 last_login_attempt_was_auto_login_ = specifics.is_auto_login;
1284
1271 if (user_context.GetUserType() == user_manager::USER_TYPE_GUEST) { 1285 if (user_context.GetUserType() == user_manager::USER_TYPE_GUEST) {
1272 if (!specifics.guest_mode_url.empty()) { 1286 if (!specifics.guest_mode_url.empty()) {
1273 guest_mode_url_ = GURL(specifics.guest_mode_url); 1287 guest_mode_url_ = GURL(specifics.guest_mode_url);
1274 if (specifics.guest_mode_url_append_locale) 1288 if (specifics.guest_mode_url_append_locale)
1275 guest_mode_url_ = google_util::AppendGoogleLocaleParam( 1289 guest_mode_url_ = google_util::AppendGoogleLocaleParam(
1276 guest_mode_url_, g_browser_process->GetApplicationLocale()); 1290 guest_mode_url_, g_browser_process->GetApplicationLocale());
1277 } 1291 }
1278 LoginAsGuest(); 1292 LoginAsGuest();
1279 return; 1293 return;
1280 } 1294 }
(...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after
1360 login_display_->ShowUnrecoverableCrypthomeErrorDialog(); 1374 login_display_->ShowUnrecoverableCrypthomeErrorDialog();
1361 } 1375 }
1362 1376
1363 void ExistingUserController::ClearRecordedNames() { 1377 void ExistingUserController::ClearRecordedNames() {
1364 display_email_.clear(); 1378 display_email_.clear();
1365 display_name_.clear(); 1379 display_name_.clear();
1366 given_name_.clear(); 1380 given_name_.clear();
1367 } 1381 }
1368 1382
1369 } // namespace chromeos 1383 } // namespace chromeos
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/login/existing_user_controller.h ('k') | chrome/browser/chromeos/login/signin_specifics.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698