// 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 COMPONENTS_USER_MANAGER_USER_H_ #define COMPONENTS_USER_MANAGER_USER_H_ #include #include #include #include "base/callback_forward.h" #include "base/gtest_prod_util.h" #include "base/macros.h" #include "base/strings/string16.h" #include "components/account_id/account_id.h" #include "components/user_manager/user_image/user_image.h" #include "components/user_manager/user_info.h" #include "components/user_manager/user_manager_export.h" #include "components/user_manager/user_type.h" #include "third_party/skia/include/core/SkBitmap.h" #include "ui/gfx/image/image_skia.h" namespace chromeos { class ChromeUserManagerImpl; class FakeChromeUserManager; class MockUserManager; class SupervisedUserManagerImpl; class UserAddingScreenTest; class UserImageManagerImpl; class UserSessionManager; } namespace policy { class ProfilePolicyConnectorTest; } namespace user_manager { class UserManagerBase; class FakeUserManager; // A class representing information about a previously logged in user. // Each user has an |AccountId| containing canonical email (username), // returned by |GetAccountId().GetUserEmail()| and may have a different // displayed email (in the raw form as entered by user), returned by // |displayed_email()|. // Displayed emails are for use in UI only, anywhere else users must be // referred to by |GetAccountId()|. Internal details of AccountId should not // be relied on unless you have special knowledge of the account type. class USER_MANAGER_EXPORT User : public UserInfo { public: // User OAuth token status according to the last check. // Please note that enum values 1 and 2 were used for OAuth1 status and are // deprecated now. typedef enum { OAUTH_TOKEN_STATUS_UNKNOWN = 0, OAUTH2_TOKEN_STATUS_INVALID = 3, OAUTH2_TOKEN_STATUS_VALID = 4, } OAuthTokenStatus; // These special values are used instead of actual default image indices. typedef enum { USER_IMAGE_INVALID = -3, // Returned as |image_index| when user profile image is used as user image. USER_IMAGE_PROFILE = -2, // Returned as |image_index| when user-selected file or photo is used as // user image. USER_IMAGE_EXTERNAL = -1, } UserImageType; // Returns true if user type has gaia account. static bool TypeHasGaiaAccount(UserType user_type); explicit User(const AccountId& account_id); ~User() override; // UserInfo std::string GetDisplayEmail() const override; base::string16 GetDisplayName() const override; base::string16 GetGivenName() const override; const gfx::ImageSkia& GetImage() const override; const AccountId& GetAccountId() const override; // Returns the user type. virtual UserType GetType() const = 0; // Will LOG(FATAL) unless overridden. virtual void UpdateType(UserType user_type); // Returns true if user has gaia account. True for users of types // USER_TYPE_REGULAR and USER_TYPE_CHILD. virtual bool HasGaiaAccount() const; // Returns true if it's Active Directory user. virtual bool IsActiveDirectoryUser() const; // Returns true if user is supervised. virtual bool IsSupervised() const; // Returns true if user is child. virtual bool IsChild() const; // True if user image can be synced. virtual bool CanSyncImage() const; // The displayed (non-canonical) user email. virtual std::string display_email() const; // True if the user is affiliated to the device. virtual bool IsAffiliated() const; // True if the user is a device local account user. virtual bool IsDeviceLocalAccount() const; // The displayed user name. base::string16 display_name() const { return display_name_; } // If the user has to use SAML to log in. bool using_saml() const { return using_saml_; } // Returns the account name part of the email. Use the display form of the // email if available and use_display_name == true. Otherwise use canonical. std::string GetAccountName(bool use_display_email) const; // Whether the user has a default image. bool HasDefaultImage() const; int image_index() const { return image_index_; } bool has_image_bytes() const { return user_image_->has_image_bytes(); } // Returns bytes representation of static user image for WebUI. scoped_refptr image_bytes() const { return user_image_->image_bytes(); } // Returns image format of the bytes representation of static user image // for WebUI. UserImage::ImageFormat image_format() const { return user_image_->image_format(); } // Whether |user_image_| contains data in format that is considered safe to // decode in sensitive environment (on Login screen). bool image_is_safe_format() const { return user_image_->is_safe_format(); } // Returns the URL of user image, if there is any. Currently only the profile // image has a URL, for other images empty URL is returned. GURL image_url() const { return user_image_->url(); } // True if user image is a stub (while real image is being loaded from file). bool image_is_stub() const { return image_is_stub_; } // True if image is being loaded from file. bool image_is_loading() const { return image_is_loading_; } // OAuth token status for this user. OAuthTokenStatus oauth_token_status() const { return oauth_token_status_; } // Whether online authentication against GAIA should be enforced during the // user's next sign-in. bool force_online_signin() const { return force_online_signin_; } // Whether the user's session has completed initialization yet. bool profile_ever_initialized() const { return profile_ever_initialized_; } // Public so it can be called via tests. void set_profile_ever_initialized(bool profile_ever_initialized) { profile_ever_initialized_ = profile_ever_initialized; } // True if the user's session can be locked (i.e. the user has a password with // which to unlock the session). bool can_lock() const; // Returns empty string when home dir hasn't been mounted yet. std::string username_hash() const; // True if current user is logged in. bool is_logged_in() const; // True if current user is active within the current session. bool is_active() const; // True if the user Profile is created. bool is_profile_created() const { return profile_is_created_; } static User* CreatePublicAccountUserForTesting(const AccountId& account_id) { return CreatePublicAccountUser(account_id); } static User* CreateRegularUserForTesting(const AccountId& account_id) { User* user = CreateRegularUser(account_id, USER_TYPE_REGULAR); user->SetImage(std::unique_ptr(new UserImage), 0); return user; } void AddProfileCreatedObserver(base::OnceClosure on_profile_created); protected: friend class UserManagerBase; friend class chromeos::ChromeUserManagerImpl; friend class chromeos::SupervisedUserManagerImpl; friend class chromeos::UserImageManagerImpl; friend class chromeos::UserSessionManager; // For testing: friend class FakeUserManager; friend class chromeos::FakeChromeUserManager; friend class chromeos::MockUserManager; friend class chromeos::UserAddingScreenTest; friend class policy::ProfilePolicyConnectorTest; FRIEND_TEST_ALL_PREFIXES(UserTest, DeviceLocalAccountAffiliation); FRIEND_TEST_ALL_PREFIXES(UserTest, UserSessionInitialized); // Do not allow anyone else to create new User instances. static User* CreateRegularUser(const AccountId& account_id, const UserType user_type); static User* CreateGuestUser(const AccountId& guest_account_id); static User* CreateKioskAppUser(const AccountId& kiosk_app_account_id); static User* CreateArcKioskAppUser(const AccountId& arc_kiosk_account_id); static User* CreateSupervisedUser(const AccountId& account_id); static User* CreatePublicAccountUser(const AccountId& account_id); const std::string* GetAccountLocale() const { return account_locale_.get(); } // Setters are private so only UserManager can call them. void SetAccountLocale(const std::string& resolved_account_locale); void SetImage(std::unique_ptr user_image, int image_index); void SetImageURL(const GURL& image_url); // Sets a stub image until the next |SetImage| call. |image_index| may be // one of |USER_IMAGE_EXTERNAL| or |USER_IMAGE_PROFILE|. // If |is_loading| is |true|, that means user image is being loaded from file. void SetStubImage(std::unique_ptr stub_user_image, int image_index, bool is_loading); void set_display_name(const base::string16& display_name) { display_name_ = display_name; } void set_given_name(const base::string16& given_name) { given_name_ = given_name; } void set_display_email(const std::string& display_email) { display_email_ = display_email; } void set_using_saml(const bool using_saml) { using_saml_ = using_saml; } const UserImage& user_image() const { return *user_image_; } void set_oauth_token_status(OAuthTokenStatus status) { oauth_token_status_ = status; } void set_force_online_signin(bool force_online_signin) { force_online_signin_ = force_online_signin; } void set_username_hash(const std::string& username_hash) { username_hash_ = username_hash; } void set_is_logged_in(bool is_logged_in) { is_logged_in_ = is_logged_in; } void set_can_lock(bool can_lock) { can_lock_ = can_lock; } void set_is_active(bool is_active) { is_active_ = is_active; } void SetProfileIsCreated(); // True if user has google account (not a guest or managed user). bool has_gaia_account() const; virtual void SetAffiliation(bool is_affiliated); private: AccountId account_id_; base::string16 display_name_; base::string16 given_name_; // The displayed user email, defaults to |email_|. std::string display_email_; bool using_saml_ = false; std::unique_ptr user_image_; OAuthTokenStatus oauth_token_status_ = OAUTH_TOKEN_STATUS_UNKNOWN; bool force_online_signin_ = false; bool profile_ever_initialized_ = false; // This is set to chromeos locale if account data has been downloaded. // (Or failed to download, but at least one download attempt finished). // An empty string indicates error in data load, or in // translation of Account locale to chromeos locale. std::unique_ptr account_locale_; // Used to identify homedir mount point. std::string username_hash_; // Either index of a default image for the user, |USER_IMAGE_EXTERNAL| or // |USER_IMAGE_PROFILE|. int image_index_ = USER_IMAGE_INVALID; // True if current user image is a stub set by a |SetStubImage| call. bool image_is_stub_ = false; // True if current user image is being loaded from file. bool image_is_loading_ = false; // True if user is able to lock screen. bool can_lock_ = false; // True if user is currently logged in in current session. bool is_logged_in_ = false; // True if user is currently logged in and active in current session. bool is_active_ = false; // True if user Profile is created bool profile_is_created_ = false; // True if the user is affiliated to the device. bool is_affiliated_ = false; std::vector on_profile_created_observers_; DISALLOW_COPY_AND_ASSIGN(User); }; // List of known users. using UserList = std::vector; } // namespace user_manager #endif // COMPONENTS_USER_MANAGER_USER_H_