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

Unified Diff: chrome/browser/chromeos/login/auth/auth_attempt_state.h

Issue 413473003: Revert of Refactoring : Move AuthAttempt and Authenticators to chromeos/login (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 5 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/chromeos/login/auth/auth_attempt_state.h
diff --git a/chrome/browser/chromeos/login/auth/auth_attempt_state.h b/chrome/browser/chromeos/login/auth/auth_attempt_state.h
new file mode 100644
index 0000000000000000000000000000000000000000..a264c4a1f8d22afa6d5aba792dc408c04c84b820
--- /dev/null
+++ b/chrome/browser/chromeos/login/auth/auth_attempt_state.h
@@ -0,0 +1,117 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef CHROME_BROWSER_CHROMEOS_LOGIN_AUTH_AUTH_ATTEMPT_STATE_H_
+#define CHROME_BROWSER_CHROMEOS_LOGIN_AUTH_AUTH_ATTEMPT_STATE_H_
+
+#include <string>
+
+#include "chromeos/login/auth/auth_status_consumer.h"
+#include "chromeos/login/auth/user_context.h"
+#include "components/user_manager/user_type.h"
+#include "google_apis/gaia/gaia_auth_consumer.h"
+#include "google_apis/gaia/gaia_auth_fetcher.h"
+#include "third_party/cros_system_api/dbus/service_constants.h"
+
+namespace chromeos {
+
+// Tracks the state associated with a single attempt to log in to chromium OS.
+// Enforces that methods are only called on the UI thread.
+class AuthAttemptState {
+ public:
+ // Used to initialize for a login attempt.
+ AuthAttemptState(const UserContext& user_context,
+ user_manager::UserType user_type,
+ bool unlock,
+ bool online_complete,
+ bool user_is_new);
+
+ virtual ~AuthAttemptState();
+
+ // Copy |user_context| and copy |outcome| into this object, so we can have
+ // a copy we're sure to own, and can make available on the UI thread.
+ // Must be called from the UI thread.
+ void RecordOnlineLoginStatus(const AuthFailure& outcome);
+
+ // Copy |username_hash| into this object, so we can have
+ // a copy we're sure to own, and can make available on the UI thread.
+ // Must be called from the UI thread.
+ void RecordUsernameHash(const std::string& username_hash);
+
+ // Marks that the username hash request attempt has failed.
+ void RecordUsernameHashFailed();
+
+ // Marks username hash as being requested so that flow will block till both
+ // requests (Mount/GetUsernameHash) are completed.
+ void UsernameHashRequested();
+
+ // The next attempt will not allow HOSTED accounts to log in.
+ void DisableHosted();
+
+ // Copy |cryptohome_code| and |cryptohome_outcome| into this object,
+ // so we can have a copy we're sure to own, and can make available
+ // on the UI thread. Must be called from the UI thread.
+ void RecordCryptohomeStatus(bool cryptohome_outcome,
+ cryptohome::MountError cryptohome_code);
+
+ // Blow away locally stored cryptohome login status.
+ // Must be called from the UI thread.
+ void ResetCryptohomeStatus();
+
+ virtual bool online_complete();
+ virtual const AuthFailure& online_outcome();
+ virtual bool is_first_time_user();
+ virtual GaiaAuthFetcher::HostedAccountsSetting hosted_policy();
+
+ virtual bool cryptohome_complete();
+ virtual bool cryptohome_outcome();
+ virtual cryptohome::MountError cryptohome_code();
+
+ virtual bool username_hash_obtained();
+ virtual bool username_hash_valid();
+
+ // Saved so we can retry client login, and also so we know for whom login
+ // has succeeded, in the event of successful completion.
+ UserContext user_context;
+
+ // These fields are saved so we can retry client login.
+ const std::string login_token;
+ const std::string login_captcha;
+
+ // The type of the user attempting to log in.
+ const user_manager::UserType user_type;
+
+ const bool unlock; // True if authenticating to unlock the computer.
+
+ protected:
+ // Status of our online login attempt.
+ bool online_complete_;
+ AuthFailure online_outcome_;
+
+ // Whether or not we're accepting HOSTED accounts during the current
+ // online auth attempt.
+ GaiaAuthFetcher::HostedAccountsSetting hosted_policy_;
+ bool is_first_time_user_;
+
+ // Status of our cryptohome op attempt. Can only have one in flight at a time.
+ bool cryptohome_complete_;
+ bool cryptohome_outcome_;
+ cryptohome::MountError cryptohome_code_;
+
+ private:
+ // Status of the crypthome GetSanitizedUsername() async call.
+ // This gets initialized as being completed and those callers
+ // that would explicitly request username hash would have to reset this.
+ bool username_hash_obtained_;
+
+ // After the username hash request is completed, this marks whether
+ // the request was successful.
+ bool username_hash_valid_;
+
+ DISALLOW_COPY_AND_ASSIGN(AuthAttemptState);
+};
+
+} // namespace chromeos
+
+#endif // CHROME_BROWSER_CHROMEOS_LOGIN_AUTH_AUTH_ATTEMPT_STATE_H_
« no previous file with comments | « chrome/browser/chromeos/login/app_launch_signin_screen.h ('k') | chrome/browser/chromeos/login/auth/auth_attempt_state.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698