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

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

Issue 286933002: [cros login] Split login related classes into subfolders. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix includes in new tests Created 6 years, 7 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 | Annotate | Revision Log
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #ifndef CHROME_BROWSER_CHROMEOS_LOGIN_AUTH_ATTEMPT_STATE_H_
6 #define CHROME_BROWSER_CHROMEOS_LOGIN_AUTH_ATTEMPT_STATE_H_
7
8 #include <string>
9
10 #include "chrome/browser/chromeos/login/login_status_consumer.h"
11 #include "chrome/browser/chromeos/login/user.h"
12 #include "google_apis/gaia/gaia_auth_consumer.h"
13 #include "google_apis/gaia/gaia_auth_fetcher.h"
14 #include "third_party/cros_system_api/dbus/service_constants.h"
15
16 namespace chromeos {
17
18 // Tracks the state associated with a single attempt to log in to chromium os.
19 // Enforces that methods are only called on the UI thread.
20
21 class AuthAttemptState {
22 public:
23 // Used to initialize for a login attempt.
24 AuthAttemptState(const UserContext& user_context,
25 const std::string& login_token,
26 const std::string& login_captcha,
27 const User::UserType user_type,
28 const bool user_is_new);
29
30 // Used to initialize for a externally authenticated login.
31 AuthAttemptState(const UserContext& user_context,
32 const bool user_is_new);
33
34 // Used to initialize for a screen unlock attempt.
35 AuthAttemptState(const std::string& username, const std::string& password);
36
37 virtual ~AuthAttemptState();
38
39 // Copy |user_context| and copy |outcome| into this object, so we can have
40 // a copy we're sure to own, and can make available on the UI thread.
41 // Must be called from the UI thread.
42 void RecordOnlineLoginStatus(
43 const LoginFailure& outcome);
44
45 // Copy |username_hash| into this object, so we can have
46 // a copy we're sure to own, and can make available on the UI thread.
47 // Must be called from the UI thread.
48 void RecordUsernameHash(const std::string& username_hash);
49
50 // Marks that the username hash request attempt has failed.
51 void RecordUsernameHashFailed();
52
53 // Marks username hash as being requested so that flow will block till both
54 // requests (Mount/GetUsernameHash) are completed.
55 void UsernameHashRequested();
56
57 // The next attempt will not allow HOSTED accounts to log in.
58 void DisableHosted();
59
60 // Copy |cryptohome_code| and |cryptohome_outcome| into this object,
61 // so we can have a copy we're sure to own, and can make available
62 // on the UI thread. Must be called from the UI thread.
63 void RecordCryptohomeStatus(bool cryptohome_outcome,
64 cryptohome::MountError cryptohome_code);
65
66 // Blow away locally stored cryptohome login status.
67 // Must be called from the UI thread.
68 void ResetCryptohomeStatus();
69
70 virtual bool online_complete();
71 virtual const LoginFailure& online_outcome();
72 virtual bool is_first_time_user();
73 virtual GaiaAuthFetcher::HostedAccountsSetting hosted_policy();
74
75 virtual bool cryptohome_complete();
76 virtual bool cryptohome_outcome();
77 virtual cryptohome::MountError cryptohome_code();
78
79 virtual bool username_hash_obtained();
80 virtual bool username_hash_valid();
81
82 // Saved so we can retry client login, and also so we know for whom login
83 // has succeeded, in the event of successful completion.
84 UserContext user_context;
85
86 // These fields are saved so we can retry client login.
87 const std::string login_token;
88 const std::string login_captcha;
89
90 // The type of the user attempting to log in.
91 const User::UserType user_type;
92
93 const bool unlock; // True if authenticating to unlock the computer.
94
95 protected:
96 // Status of our online login attempt.
97 bool online_complete_;
98 LoginFailure online_outcome_;
99
100 // Whether or not we're accepting HOSTED accounts during the current
101 // online auth attempt.
102 GaiaAuthFetcher::HostedAccountsSetting hosted_policy_;
103 bool is_first_time_user_;
104
105 // Status of our cryptohome op attempt. Can only have one in flight at a time.
106 bool cryptohome_complete_;
107 bool cryptohome_outcome_;
108 cryptohome::MountError cryptohome_code_;
109
110 private:
111 // Status of the crypthome GetSanitizedUsername() async call.
112 // This gets initialized as being completed and those callers
113 // that would explicitly request username hash would have to reset this.
114 bool username_hash_obtained_;
115
116 // After the username hash request is completed, this marks whether
117 // the request was successful.
118 bool username_hash_valid_;
119
120 DISALLOW_COPY_AND_ASSIGN(AuthAttemptState);
121 };
122
123 } // namespace chromeos
124
125 #endif // CHROME_BROWSER_CHROMEOS_LOGIN_AUTH_ATTEMPT_STATE_H_
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/login/auth/tpm_password_fetcher.cc ('k') | chrome/browser/chromeos/login/auth_attempt_state.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698