/*
 * Copyright (C) 2011 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package android.content.pm;

import android.os.Parcel;
import android.os.Parcelable;
import android.os.SystemProperties;
import android.os.UserHandle;
import android.os.UserManager;

Per-user information.
@hide
/** * Per-user information. * @hide */
public class UserInfo implements Parcelable {
16 bits for user type
/** 16 bits for user type */
public static final int FLAG_MASK_USER_TYPE = 0x0000FFFF; /** * *************************** NOTE *************************** * These flag values CAN NOT CHANGE because they are written * directly to storage. */
Primary user. Only one user can have this flag set. It identifies the first human user on a device.
/** * Primary user. Only one user can have this flag set. It identifies the first human user * on a device. */
public static final int FLAG_PRIMARY = 0x00000001;
User with administrative privileges. Such a user can create and delete users.
/** * User with administrative privileges. Such a user can create and * delete users. */
public static final int FLAG_ADMIN = 0x00000002;
Indicates a guest user that may be transient.
/** * Indicates a guest user that may be transient. */
public static final int FLAG_GUEST = 0x00000004;
Indicates the user has restrictions in privileges, in addition to those for normal users. Exact meaning TBD. For instance, maybe they can't install apps or administer WiFi access pts.
/** * Indicates the user has restrictions in privileges, in addition to those for normal users. * Exact meaning TBD. For instance, maybe they can't install apps or administer WiFi access pts. */
public static final int FLAG_RESTRICTED = 0x00000008;
Indicates that this user has gone through its first-time initialization.
/** * Indicates that this user has gone through its first-time initialization. */
public static final int FLAG_INITIALIZED = 0x00000010;
Indicates that this user is a profile of another user, for example holding a users corporate data.
/** * Indicates that this user is a profile of another user, for example holding a users * corporate data. */
public static final int FLAG_MANAGED_PROFILE = 0x00000020;
Indicates that this user is disabled.

Note: If an ephemeral user is disabled, it shouldn't be later re-enabled. Ephemeral users are disabled as their removal is in progress to indicate that they shouldn't be re-entered.

/** * Indicates that this user is disabled. * * <p>Note: If an ephemeral user is disabled, it shouldn't be later re-enabled. Ephemeral users * are disabled as their removal is in progress to indicate that they shouldn't be re-entered. */
public static final int FLAG_DISABLED = 0x00000040; public static final int FLAG_QUIET_MODE = 0x00000080;
Indicates that this user is ephemeral. I.e. the user will be removed after leaving the foreground.
/** * Indicates that this user is ephemeral. I.e. the user will be removed after leaving * the foreground. */
public static final int FLAG_EPHEMERAL = 0x00000100;
User is for demo purposes only and can be removed at any time.
/** * User is for demo purposes only and can be removed at any time. */
public static final int FLAG_DEMO = 0x00000200; public static final int NO_PROFILE_GROUP_ID = UserHandle.USER_NULL; public int id; public int serialNumber; public String name; public String iconPath; public int flags; public long creationTime; public long lastLoggedInTime; public String lastLoggedInFingerprint;
If this user is a parent user, it would be its own user id. If this user is a child user, it would be its parent user id. Otherwise, it would be NO_PROFILE_GROUP_ID.
/** * If this user is a parent user, it would be its own user id. * If this user is a child user, it would be its parent user id. * Otherwise, it would be {@link #NO_PROFILE_GROUP_ID}. */
public int profileGroupId; public int restrictedProfileParentId;
Which profile badge color/label to use.
/** Which profile badge color/label to use. */
public int profileBadge;
User is only partially created.
/** User is only partially created. */
public boolean partial; public boolean guestToRemove; public UserInfo(int id, String name, int flags) { this(id, name, null, flags); } public UserInfo(int id, String name, String iconPath, int flags) { this.id = id; this.name = name; this.flags = flags; this.iconPath = iconPath; this.profileGroupId = NO_PROFILE_GROUP_ID; this.restrictedProfileParentId = NO_PROFILE_GROUP_ID; } public boolean isPrimary() { return (flags & FLAG_PRIMARY) == FLAG_PRIMARY; } public boolean isAdmin() { return (flags & FLAG_ADMIN) == FLAG_ADMIN; } public boolean isGuest() { return (flags & FLAG_GUEST) == FLAG_GUEST; } public boolean isRestricted() { return (flags & FLAG_RESTRICTED) == FLAG_RESTRICTED; } public boolean isManagedProfile() { return (flags & FLAG_MANAGED_PROFILE) == FLAG_MANAGED_PROFILE; } public boolean isEnabled() { return (flags & FLAG_DISABLED) != FLAG_DISABLED; } public boolean isQuietModeEnabled() { return (flags & FLAG_QUIET_MODE) == FLAG_QUIET_MODE; } public boolean isEphemeral() { return (flags & FLAG_EPHEMERAL) == FLAG_EPHEMERAL; } public boolean isInitialized() { return (flags & FLAG_INITIALIZED) == FLAG_INITIALIZED; } public boolean isDemo() { return (flags & FLAG_DEMO) == FLAG_DEMO; }
Returns true if the user is a split system user.

If split system user mode is not enabled, the method always returns false.

/** * Returns true if the user is a split system user. * <p>If {@link UserManager#isSplitSystemUser split system user mode} is not enabled, * the method always returns false. */
public boolean isSystemOnly() { return isSystemOnly(id); }
Returns true if the given user is a split system user.

If split system user mode is not enabled, the method always returns false.

/** * Returns true if the given user is a split system user. * <p>If {@link UserManager#isSplitSystemUser split system user mode} is not enabled, * the method always returns false. */
public static boolean isSystemOnly(int userId) { return userId == UserHandle.USER_SYSTEM && UserManager.isSplitSystemUser(); }
Returns:true if this user can be switched to.
/** * @return true if this user can be switched to. **/
public boolean supportsSwitchTo() { if (isEphemeral() && !isEnabled()) { // Don't support switching to an ephemeral user with removal in progress. return false; } return !isManagedProfile(); }
Returns:true if this user can be switched to by end user through UI.
/** * @return true if this user can be switched to by end user through UI. */
public boolean supportsSwitchToByUser() { // Hide the system user when it does not represent a human user. boolean hideSystemUser = UserManager.isSplitSystemUser(); return (!hideSystemUser || id != UserHandle.USER_SYSTEM) && supportsSwitchTo(); } /* @hide */ public boolean canHaveProfile() { if (isManagedProfile() || isGuest() || isRestricted()) { return false; } if (UserManager.isSplitSystemUser()) { return id != UserHandle.USER_SYSTEM; } else { return id == UserHandle.USER_SYSTEM; } } public UserInfo() { } public UserInfo(UserInfo orig) { name = orig.name; iconPath = orig.iconPath; id = orig.id; flags = orig.flags; serialNumber = orig.serialNumber; creationTime = orig.creationTime; lastLoggedInTime = orig.lastLoggedInTime; lastLoggedInFingerprint = orig.lastLoggedInFingerprint; partial = orig.partial; profileGroupId = orig.profileGroupId; restrictedProfileParentId = orig.restrictedProfileParentId; guestToRemove = orig.guestToRemove; profileBadge = orig.profileBadge; } public UserHandle getUserHandle() { return new UserHandle(id); } @Override public String toString() { return "UserInfo{" + id + ":" + name + ":" + Integer.toHexString(flags) + "}"; } public int describeContents() { return 0; } public void writeToParcel(Parcel dest, int parcelableFlags) { dest.writeInt(id); dest.writeString(name); dest.writeString(iconPath); dest.writeInt(flags); dest.writeInt(serialNumber); dest.writeLong(creationTime); dest.writeLong(lastLoggedInTime); dest.writeString(lastLoggedInFingerprint); dest.writeInt(partial ? 1 : 0); dest.writeInt(profileGroupId); dest.writeInt(guestToRemove ? 1 : 0); dest.writeInt(restrictedProfileParentId); dest.writeInt(profileBadge); } public static final Parcelable.Creator<UserInfo> CREATOR = new Parcelable.Creator<UserInfo>() { public UserInfo createFromParcel(Parcel source) { return new UserInfo(source); } public UserInfo[] newArray(int size) { return new UserInfo[size]; } }; private UserInfo(Parcel source) { id = source.readInt(); name = source.readString(); iconPath = source.readString(); flags = source.readInt(); serialNumber = source.readInt(); creationTime = source.readLong(); lastLoggedInTime = source.readLong(); lastLoggedInFingerprint = source.readString(); partial = source.readInt() != 0; profileGroupId = source.readInt(); guestToRemove = source.readInt() != 0; restrictedProfileParentId = source.readInt(); profileBadge = source.readInt(); } }