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

Side by Side Diff: chrome/browser/chromeos/login/user_flow.h

Issue 654173005: Don't allow restarting to apply custom flags when supervised user creation flow is active (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: logging restart due flags as warning, don't restart for supervised users Created 6 years, 2 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 #ifndef CHROME_BROWSER_CHROMEOS_LOGIN_USER_FLOW_H_ 5 #ifndef CHROME_BROWSER_CHROMEOS_LOGIN_USER_FLOW_H_
6 #define CHROME_BROWSER_CHROMEOS_LOGIN_USER_FLOW_H_ 6 #define CHROME_BROWSER_CHROMEOS_LOGIN_USER_FLOW_H_
7 7
8 #include "base/compiler_specific.h" 8 #include "base/compiler_specific.h"
9 #include "chrome/browser/profiles/profile.h" 9 #include "chrome/browser/profiles/profile.h"
10 #include "chromeos/login/auth/auth_status_consumer.h" 10 #include "chromeos/login/auth/auth_status_consumer.h"
11 #include "components/user_manager/user.h" 11 #include "components/user_manager/user.h"
12 12
13 namespace chromeos { 13 namespace chromeos {
14 14
15 class UserContext; 15 class UserContext;
16 16
17 class LoginDisplayHost; 17 class LoginDisplayHost;
18 // Defines possible variants of user flow upon logging in. 18 // Defines possible variants of user flow upon logging in.
19 // See UserManager::SetUserFlow for usage contract. 19 // See UserManager::SetUserFlow for usage contract.
20 class UserFlow { 20 class UserFlow {
21 public: 21 public:
22 UserFlow(); 22 UserFlow();
23 virtual ~UserFlow() = 0; 23 virtual ~UserFlow() = 0;
24 // Indicates if screen locking should be enabled or disabled for a flow. 24 // Indicates if screen locking should be enabled or disabled for a flow.
25 virtual bool CanLockScreen() = 0; 25 virtual bool CanLockScreen() = 0;
26 virtual bool ShouldShowSettings() = 0; 26 virtual bool ShouldShowSettings() = 0;
27 virtual bool ShouldLaunchBrowser() = 0; 27 virtual bool ShouldLaunchBrowser() = 0;
28 virtual bool ShouldSkipPostLoginScreens() = 0; 28 virtual bool ShouldSkipPostLoginScreens() = 0;
29 virtual bool SupportsEarlyRestartToApplyFlags() = 0;
29 virtual bool HandleLoginFailure(const AuthFailure& failure) = 0; 30 virtual bool HandleLoginFailure(const AuthFailure& failure) = 0;
30 virtual void HandleLoginSuccess(const UserContext& context) = 0; 31 virtual void HandleLoginSuccess(const UserContext& context) = 0;
31 virtual bool HandlePasswordChangeDetected() = 0; 32 virtual bool HandlePasswordChangeDetected() = 0;
32 virtual void HandleOAuthTokenStatusChange( 33 virtual void HandleOAuthTokenStatusChange(
33 user_manager::User::OAuthTokenStatus status) = 0; 34 user_manager::User::OAuthTokenStatus status) = 0;
34 virtual void LaunchExtraSteps(Profile* profile) = 0; 35 virtual void LaunchExtraSteps(Profile* profile) = 0;
35 36
36 void set_host(LoginDisplayHost* host) { 37 void set_host(LoginDisplayHost* host) {
37 host_ = host; 38 host_ = host;
38 } 39 }
39 40
40 LoginDisplayHost* host() { 41 LoginDisplayHost* host() {
41 return host_; 42 return host_;
42 } 43 }
43 44
44 private: 45 private:
45 LoginDisplayHost* host_; 46 LoginDisplayHost* host_;
46 }; 47 };
47 48
48 // UserFlow implementation for regular login flow. 49 // UserFlow implementation for regular login flow.
49 class DefaultUserFlow : public UserFlow { 50 class DefaultUserFlow : public UserFlow {
50 public: 51 public:
51 virtual ~DefaultUserFlow(); 52 virtual ~DefaultUserFlow();
52 53
53 virtual bool CanLockScreen() override; 54 virtual bool CanLockScreen() override;
54 virtual bool ShouldShowSettings() override; 55 virtual bool ShouldShowSettings() override;
55 virtual bool ShouldLaunchBrowser() override; 56 virtual bool ShouldLaunchBrowser() override;
56 virtual bool ShouldSkipPostLoginScreens() override; 57 virtual bool ShouldSkipPostLoginScreens() override;
58 virtual bool SupportsEarlyRestartToApplyFlags() override;
57 virtual bool HandleLoginFailure(const AuthFailure& failure) override; 59 virtual bool HandleLoginFailure(const AuthFailure& failure) override;
58 virtual void HandleLoginSuccess(const UserContext& context) override; 60 virtual void HandleLoginSuccess(const UserContext& context) override;
59 virtual bool HandlePasswordChangeDetected() override; 61 virtual bool HandlePasswordChangeDetected() override;
60 virtual void HandleOAuthTokenStatusChange( 62 virtual void HandleOAuthTokenStatusChange(
61 user_manager::User::OAuthTokenStatus status) override; 63 user_manager::User::OAuthTokenStatus status) override;
62 virtual void LaunchExtraSteps(Profile* profile) override; 64 virtual void LaunchExtraSteps(Profile* profile) override;
63 }; 65 };
64 66
65 // UserFlow stub for non-regular flows. 67 // UserFlow stub for non-regular flows.
66 class ExtendedUserFlow : public UserFlow { 68 class ExtendedUserFlow : public UserFlow {
(...skipping 10 matching lines...) Expand all
77 return user_id_; 79 return user_id_;
78 } 80 }
79 81
80 private: 82 private:
81 std::string user_id_; 83 std::string user_id_;
82 }; 84 };
83 85
84 } // namespace chromeos 86 } // namespace chromeos
85 87
86 #endif // CHROME_BROWSER_CHROMEOS_LOGIN_USER_FLOW_H_ 88 #endif // CHROME_BROWSER_CHROMEOS_LOGIN_USER_FLOW_H_
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/login/supervised/supervised_user_login_flow.cc ('k') | chrome/browser/chromeos/login/user_flow.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698