1 // Copyright 2014 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.
5 #ifndef COMPONENTS_USER_MANAGER_USER_H_
6 #define COMPONENTS_USER_MANAGER_USER_H_
11 #include "base/basictypes.h"
12 #include "base/strings/string16.h"
13 #include "components/user_manager/user_id.h"
14 #include "components/user_manager/user_image/user_image.h"
15 #include "components/user_manager/user_info.h"
16 #include "components/user_manager/user_manager_export.h"
17 #include "components/user_manager/user_type.h"
18 #include "third_party/skia/include/core/SkBitmap.h"
19 #include "ui/gfx/image/image_skia.h"
22 class ChromeUserManagerImpl
;
23 class FakeChromeUserManager
;
24 class MockUserManager
;
25 class SupervisedUserManagerImpl
;
26 class UserAddingScreenTest
;
27 class UserImageManagerImpl
;
28 class UserSessionManager
;
31 namespace user_manager
{
33 class UserManagerBase
;
34 class FakeUserManager
;
36 // A class representing information about a previously logged in user.
37 // Each user has a canonical email (username), returned by |email()| and
38 // may have a different displayed email (in the raw form as entered by user),
39 // returned by |displayed_email()|.
40 // Displayed emails are for use in UI only, anywhere else users must be referred
42 class USER_MANAGER_EXPORT User
: public UserInfo
{
44 // User OAuth token status according to the last check.
45 // Please note that enum values 1 and 2 were used for OAuth1 status and are
48 OAUTH_TOKEN_STATUS_UNKNOWN
= 0,
49 OAUTH2_TOKEN_STATUS_INVALID
= 3,
50 OAUTH2_TOKEN_STATUS_VALID
= 4,
53 // These special values are used instead of actual default image indices.
55 USER_IMAGE_INVALID
= -3,
57 // Returned as |image_index| when user profile image is used as user image.
58 USER_IMAGE_PROFILE
= -2,
60 // Returned as |image_index| when user-selected file or photo is used as
62 USER_IMAGE_EXTERNAL
= -1,
65 // This enum is used to define the buckets for an enumerated UMA histogram.
67 // (a) existing enumerated constants should never be deleted or reordered,
68 // (b) new constants should only be appended at the end of the enumeration.
70 /* DAILY = 0 */ // Removed.
71 CUSTOMIZED
= 1, // Selected by user.
72 DEFAULT
= 2, // Default.
73 /* UNKNOWN = 3 */ // Removed.
74 ONLINE
= 4, // WallpaperInfo.location denotes an URL.
75 POLICY
= 5, // Controlled by policy, can't be changed by the user.
76 WALLPAPER_TYPE_COUNT
= 6
79 // Returns true if user type has gaia account.
80 static bool TypeHasGaiaAccount(UserType user_type
);
82 // Returns the user type.
83 virtual UserType
GetType() const = 0;
85 // The email the user used to log in.
86 const std::string
& email() const { return email_
; }
88 // The displayed user name.
89 base::string16
display_name() const { return display_name_
; }
92 std::string
GetEmail() const override
;
93 base::string16
GetDisplayName() const override
;
94 base::string16
GetGivenName() const override
;
95 const gfx::ImageSkia
& GetImage() const override
;
96 UserID
GetUserID() const override
;
98 // Allows managing child status of the user. Used for RegularUser.
99 virtual void SetIsChild(bool is_child
);
101 // Returns true if user has gaia account. True for users of types
102 // USER_TYPE_REGULAR and USER_TYPE_CHILD.
103 virtual bool HasGaiaAccount() const;
105 // Returns true if user is supervised.
106 virtual bool IsSupervised() const;
108 // Returns the account name part of the email. Use the display form of the
109 // email if available and use_display_name == true. Otherwise use canonical.
110 std::string
GetAccountName(bool use_display_email
) const;
112 // Whether the user has a default image.
113 bool HasDefaultImage() const;
115 // True if user image can be synced.
116 virtual bool CanSyncImage() const;
118 int image_index() const { return image_index_
; }
119 bool has_raw_image() const { return user_image_
.has_raw_image(); }
120 // Returns raw representation of static user image.
121 const UserImage::RawImage
& raw_image() const {
122 return user_image_
.raw_image();
125 // Whether |raw_image| contains data in format that is considered safe to
126 // decode in sensitive environment (on Login screen).
127 bool image_is_safe_format() const { return user_image_
.is_safe_format(); }
129 // Returns the URL of user image, if there is any. Currently only the profile
130 // image has a URL, for other images empty URL is returned.
131 GURL
image_url() const { return user_image_
.url(); }
133 // True if user image is a stub (while real image is being loaded from file).
134 bool image_is_stub() const { return image_is_stub_
; }
136 // True if image is being loaded from file.
137 bool image_is_loading() const { return image_is_loading_
; }
139 // The displayed (non-canonical) user email.
140 virtual std::string
display_email() const;
142 // OAuth token status for this user.
143 OAuthTokenStatus
oauth_token_status() const { return oauth_token_status_
; }
145 // Whether online authentication against GAIA should be enforced during the
146 // user's next sign-in.
147 bool force_online_signin() const { return force_online_signin_
; }
149 // True if the user's session can be locked (i.e. the user has a password with
150 // which to unlock the session).
151 bool can_lock() const;
153 // Returns empty string when home dir hasn't been mounted yet.
154 std::string
username_hash() const;
156 // True if current user is logged in.
157 bool is_logged_in() const;
159 // True if current user is active within the current session.
160 bool is_active() const;
162 // True if the user Profile is created.
163 bool is_profile_created() const { return profile_is_created_
; }
166 friend class UserManagerBase
;
167 friend class chromeos::ChromeUserManagerImpl
;
168 friend class chromeos::SupervisedUserManagerImpl
;
169 friend class chromeos::UserImageManagerImpl
;
170 friend class chromeos::UserSessionManager
;
173 friend class FakeUserManager
;
174 friend class chromeos::FakeChromeUserManager
;
175 friend class chromeos::MockUserManager
;
176 friend class chromeos::UserAddingScreenTest
;
178 // Do not allow anyone else to create new User instances.
179 static User
* CreateRegularUser(const UserID
& email
);
180 static User
* CreateGuestUser();
181 static User
* CreateKioskAppUser(const UserID
& kiosk_app_username
);
182 static User
* CreateSupervisedUser(const UserID
& username
);
183 static User
* CreatePublicAccountUser(const UserID
& email
);
185 explicit User(const std::string
& email
);
188 const std::string
* GetAccountLocale() const { return account_locale_
.get(); }
190 // Setters are private so only UserManager can call them.
191 void SetAccountLocale(const std::string
& resolved_account_locale
);
193 void SetImage(const UserImage
& user_image
, int image_index
);
195 void SetImageURL(const GURL
& image_url
);
197 // Sets a stub image until the next |SetImage| call. |image_index| may be
198 // one of |USER_IMAGE_EXTERNAL| or |USER_IMAGE_PROFILE|.
199 // If |is_loading| is |true|, that means user image is being loaded from file.
200 void SetStubImage(const UserImage
& stub_user_image
,
204 void set_display_name(const base::string16
& display_name
) {
205 display_name_
= display_name
;
208 void set_given_name(const base::string16
& given_name
) {
209 given_name_
= given_name
;
212 void set_display_email(const std::string
& display_email
) {
213 display_email_
= display_email
;
216 const UserImage
& user_image() const { return user_image_
; }
218 void set_oauth_token_status(OAuthTokenStatus status
) {
219 oauth_token_status_
= status
;
222 void set_force_online_signin(bool force_online_signin
) {
223 force_online_signin_
= force_online_signin
;
226 void set_username_hash(const std::string
& username_hash
) {
227 username_hash_
= username_hash
;
230 void set_is_logged_in(bool is_logged_in
) { is_logged_in_
= is_logged_in
; }
232 void set_can_lock(bool can_lock
) { can_lock_
= can_lock
; }
234 void set_is_active(bool is_active
) { is_active_
= is_active
; }
236 void set_profile_is_created() { profile_is_created_
= true; }
238 // True if user has google account (not a guest or managed user).
239 bool has_gaia_account() const;
243 base::string16 display_name_
;
244 base::string16 given_name_
;
245 // The displayed user email, defaults to |email_|.
246 std::string display_email_
;
247 UserImage user_image_
;
248 OAuthTokenStatus oauth_token_status_
;
249 bool force_online_signin_
;
251 // This is set to chromeos locale if account data has been downloaded.
252 // (Or failed to download, but at least one download attempt finished).
253 // An empty string indicates error in data load, or in
254 // translation of Account locale to chromeos locale.
255 scoped_ptr
<std::string
> account_locale_
;
257 // Used to identify homedir mount point.
258 std::string username_hash_
;
260 // Either index of a default image for the user, |USER_IMAGE_EXTERNAL| or
261 // |USER_IMAGE_PROFILE|.
264 // True if current user image is a stub set by a |SetStubImage| call.
267 // True if current user image is being loaded from file.
268 bool image_is_loading_
;
270 // True if user is able to lock screen.
273 // True if user is currently logged in in current session.
276 // True if user is currently logged in and active in current session.
279 // True if user Profile is created
280 bool profile_is_created_
;
282 DISALLOW_COPY_AND_ASSIGN(User
);
285 // List of known users.
286 typedef std::vector
<User
*> UserList
;
288 } // namespace user_manager
290 #endif // COMPONENTS_USER_MANAGER_USER_H_