UserInfo.java revision 1a447535cef7e3739d5f763dfe13e568568b9789
14b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani/*
24b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani * Copyright (C) 2011 The Android Open Source Project
34b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani *
44b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani * Licensed under the Apache License, Version 2.0 (the "License");
54b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani * you may not use this file except in compliance with the License.
64b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani * You may obtain a copy of the License at
74b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani *
84b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani *      http://www.apache.org/licenses/LICENSE-2.0
94b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani *
104b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani * Unless required by applicable law or agreed to in writing, software
114b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani * distributed under the License is distributed on an "AS IS" BASIS,
124b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
134b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani * See the License for the specific language governing permissions and
144b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani * limitations under the License.
154b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani */
164b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
174b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasanipackage android.content.pm;
184b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
194b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasaniimport android.os.Parcel;
204b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasaniimport android.os.Parcelable;
211a447535cef7e3739d5f763dfe13e568568b9789Kenny Guyimport android.os.SystemProperties;
22b049e212ab7fe8967893c202efcb30fecfdb82fbJeff Sharkeyimport android.os.UserHandle;
234b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
244b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani/**
254b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani * Per-user information.
264b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani * @hide
274b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani */
284b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasanipublic class UserInfo implements Parcelable {
29258848d2ae04f447ff1c18023fa76b139fcc0862Amith Yamasani
30258848d2ae04f447ff1c18023fa76b139fcc0862Amith Yamasani    /** 6 bits for user type */
31258848d2ae04f447ff1c18023fa76b139fcc0862Amith Yamasani    public static final int FLAG_MASK_USER_TYPE = 0x0000003F;
32258848d2ae04f447ff1c18023fa76b139fcc0862Amith Yamasani
334b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    /**
345dc5a00e7ebadc085ded7e29feacd17e53698486Dianne Hackborn     * *************************** NOTE ***************************
355dc5a00e7ebadc085ded7e29feacd17e53698486Dianne Hackborn     * These flag values CAN NOT CHANGE because they are written
365dc5a00e7ebadc085ded7e29feacd17e53698486Dianne Hackborn     * directly to storage.
375dc5a00e7ebadc085ded7e29feacd17e53698486Dianne Hackborn     */
385dc5a00e7ebadc085ded7e29feacd17e53698486Dianne Hackborn
395dc5a00e7ebadc085ded7e29feacd17e53698486Dianne Hackborn    /**
404b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani     * Primary user. Only one user can have this flag set. Meaning of this
414b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani     * flag TBD.
424b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani     */
434b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public static final int FLAG_PRIMARY = 0x00000001;
444b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
454b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    /**
464b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani     * User with administrative privileges. Such a user can create and
474b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani     * delete users.
484b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani     */
494b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public static final int FLAG_ADMIN   = 0x00000002;
504b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
514b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    /**
524b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani     * Indicates a guest user that may be transient.
534b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani     */
544b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public static final int FLAG_GUEST   = 0x00000004;
554b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
56258848d2ae04f447ff1c18023fa76b139fcc0862Amith Yamasani    /**
57258848d2ae04f447ff1c18023fa76b139fcc0862Amith Yamasani     * Indicates the user has restrictions in privileges, in addition to those for normal users.
58258848d2ae04f447ff1c18023fa76b139fcc0862Amith Yamasani     * Exact meaning TBD. For instance, maybe they can't install apps or administer WiFi access pts.
59258848d2ae04f447ff1c18023fa76b139fcc0862Amith Yamasani     */
60258848d2ae04f447ff1c18023fa76b139fcc0862Amith Yamasani    public static final int FLAG_RESTRICTED = 0x00000008;
61258848d2ae04f447ff1c18023fa76b139fcc0862Amith Yamasani
625dc5a00e7ebadc085ded7e29feacd17e53698486Dianne Hackborn    /**
635dc5a00e7ebadc085ded7e29feacd17e53698486Dianne Hackborn     * Indicates that this user has gone through its first-time initialization.
645dc5a00e7ebadc085ded7e29feacd17e53698486Dianne Hackborn     */
655dc5a00e7ebadc085ded7e29feacd17e53698486Dianne Hackborn    public static final int FLAG_INITIALIZED = 0x00000010;
665dc5a00e7ebadc085ded7e29feacd17e53698486Dianne Hackborn
67a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy    /**
68a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy     * Indicates that this user is a profile of another user, for example holding a users
69a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy     * corporate data.
70a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy     */
71a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy    public static final int FLAG_MANAGED_PROFILE = 0x00000020;
72a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy
73a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy
74a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy    public static final int NO_RELATED_GROUP_ID = -1;
75a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy
764b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public int id;
772a00329c6d55c6cd9166e01963d7410e95d80d21Amith Yamasani    public int serialNumber;
784b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public String name;
79b8151ecd6ef4faa5c16d0a4c3abb45ec84d1f97aAmith Yamasani    public String iconPath;
804b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public int flags;
81920ace0bbc2d4133dbec991d2636c99a57d6245eAmith Yamasani    public long creationTime;
82920ace0bbc2d4133dbec991d2636c99a57d6245eAmith Yamasani    public long lastLoggedInTime;
83a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy    public int relatedGroupId;
844b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
85d4ac8d7b3de27a9f0e4c6af2496ca71d794e42d1Dianne Hackborn    /** User is only partially created. */
86d4ac8d7b3de27a9f0e4c6af2496ca71d794e42d1Dianne Hackborn    public boolean partial;
87d4ac8d7b3de27a9f0e4c6af2496ca71d794e42d1Dianne Hackborn
884b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public UserInfo(int id, String name, int flags) {
89b8151ecd6ef4faa5c16d0a4c3abb45ec84d1f97aAmith Yamasani        this(id, name, null, flags);
90b8151ecd6ef4faa5c16d0a4c3abb45ec84d1f97aAmith Yamasani    }
91b8151ecd6ef4faa5c16d0a4c3abb45ec84d1f97aAmith Yamasani
92b8151ecd6ef4faa5c16d0a4c3abb45ec84d1f97aAmith Yamasani    public UserInfo(int id, String name, String iconPath, int flags) {
934b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        this.id = id;
944b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        this.name = name;
954b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        this.flags = flags;
96b8151ecd6ef4faa5c16d0a4c3abb45ec84d1f97aAmith Yamasani        this.iconPath = iconPath;
97a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy        this.relatedGroupId = NO_RELATED_GROUP_ID;
984b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    }
994b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
1004b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public boolean isPrimary() {
1014b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        return (flags & FLAG_PRIMARY) == FLAG_PRIMARY;
1024b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    }
1034b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
1044b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public boolean isAdmin() {
1054b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        return (flags & FLAG_ADMIN) == FLAG_ADMIN;
1064b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    }
1074b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
1084b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public boolean isGuest() {
1094b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        return (flags & FLAG_GUEST) == FLAG_GUEST;
1104b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    }
1114b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
11267df64b3a48a8157d08a98fa90135d0ac0ee621cAmith Yamasani    public boolean isRestricted() {
11367df64b3a48a8157d08a98fa90135d0ac0ee621cAmith Yamasani        return (flags & FLAG_RESTRICTED) == FLAG_RESTRICTED;
11467df64b3a48a8157d08a98fa90135d0ac0ee621cAmith Yamasani    }
11567df64b3a48a8157d08a98fa90135d0ac0ee621cAmith Yamasani
116a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy    public boolean isManagedProfile() {
117a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy        return (flags & FLAG_MANAGED_PROFILE) == FLAG_MANAGED_PROFILE;
118a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy    }
119a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy
1201a447535cef7e3739d5f763dfe13e568568b9789Kenny Guy    /**
1211a447535cef7e3739d5f763dfe13e568568b9789Kenny Guy     * @return true if this user can be switched to.
1221a447535cef7e3739d5f763dfe13e568568b9789Kenny Guy     **/
1231a447535cef7e3739d5f763dfe13e568568b9789Kenny Guy    public boolean supportsSwitchTo() {
1241a447535cef7e3739d5f763dfe13e568568b9789Kenny Guy        // TODO remove fw.show_hidden_users when we have finished developing managed profiles.
1251a447535cef7e3739d5f763dfe13e568568b9789Kenny Guy        return !isManagedProfile() || SystemProperties.getBoolean("fw.show_hidden_users", false);
1261a447535cef7e3739d5f763dfe13e568568b9789Kenny Guy    }
1271a447535cef7e3739d5f763dfe13e568568b9789Kenny Guy
1284b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public UserInfo() {
1294b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    }
1304b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
1314b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public UserInfo(UserInfo orig) {
1324b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        name = orig.name;
133b8151ecd6ef4faa5c16d0a4c3abb45ec84d1f97aAmith Yamasani        iconPath = orig.iconPath;
1344b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        id = orig.id;
1354b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        flags = orig.flags;
1362a00329c6d55c6cd9166e01963d7410e95d80d21Amith Yamasani        serialNumber = orig.serialNumber;
137920ace0bbc2d4133dbec991d2636c99a57d6245eAmith Yamasani        creationTime = orig.creationTime;
138920ace0bbc2d4133dbec991d2636c99a57d6245eAmith Yamasani        lastLoggedInTime = orig.lastLoggedInTime;
139d4ac8d7b3de27a9f0e4c6af2496ca71d794e42d1Dianne Hackborn        partial = orig.partial;
140a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy        relatedGroupId = orig.relatedGroupId;
1414b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    }
1424b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
143b049e212ab7fe8967893c202efcb30fecfdb82fbJeff Sharkey    public UserHandle getUserHandle() {
144b049e212ab7fe8967893c202efcb30fecfdb82fbJeff Sharkey        return new UserHandle(id);
145b049e212ab7fe8967893c202efcb30fecfdb82fbJeff Sharkey    }
146b049e212ab7fe8967893c202efcb30fecfdb82fbJeff Sharkey
1474b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    @Override
1484b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public String toString() {
1490b285499db739ba50f2f839d633e763c70e67f96Amith Yamasani        return "UserInfo{" + id + ":" + name + ":" + Integer.toHexString(flags) + "}";
1504b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    }
1514b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
1524b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public int describeContents() {
1534b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        return 0;
1544b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    }
1554b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
1564b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public void writeToParcel(Parcel dest, int parcelableFlags) {
1574b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        dest.writeInt(id);
1584b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        dest.writeString(name);
159b8151ecd6ef4faa5c16d0a4c3abb45ec84d1f97aAmith Yamasani        dest.writeString(iconPath);
1604b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        dest.writeInt(flags);
1612a00329c6d55c6cd9166e01963d7410e95d80d21Amith Yamasani        dest.writeInt(serialNumber);
162920ace0bbc2d4133dbec991d2636c99a57d6245eAmith Yamasani        dest.writeLong(creationTime);
163920ace0bbc2d4133dbec991d2636c99a57d6245eAmith Yamasani        dest.writeLong(lastLoggedInTime);
164d4ac8d7b3de27a9f0e4c6af2496ca71d794e42d1Dianne Hackborn        dest.writeInt(partial ? 1 : 0);
165a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy        dest.writeInt(relatedGroupId);
1664b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    }
1674b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
1684b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    public static final Parcelable.Creator<UserInfo> CREATOR
1694b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani            = new Parcelable.Creator<UserInfo>() {
1704b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        public UserInfo createFromParcel(Parcel source) {
1714b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani            return new UserInfo(source);
1724b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        }
1734b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        public UserInfo[] newArray(int size) {
1744b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani            return new UserInfo[size];
1754b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        }
1764b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    };
1774b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani
1784b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    private UserInfo(Parcel source) {
1794b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        id = source.readInt();
1804b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        name = source.readString();
181b8151ecd6ef4faa5c16d0a4c3abb45ec84d1f97aAmith Yamasani        iconPath = source.readString();
1824b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani        flags = source.readInt();
1832a00329c6d55c6cd9166e01963d7410e95d80d21Amith Yamasani        serialNumber = source.readInt();
184920ace0bbc2d4133dbec991d2636c99a57d6245eAmith Yamasani        creationTime = source.readLong();
185920ace0bbc2d4133dbec991d2636c99a57d6245eAmith Yamasani        lastLoggedInTime = source.readLong();
186d4ac8d7b3de27a9f0e4c6af2496ca71d794e42d1Dianne Hackborn        partial = source.readInt() != 0;
187a52dc3eb40777b055c0ca8d7885bd2c9577bcd1aKenny Guy        relatedGroupId = source.readInt();
1884b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani    }
1894b2e934928a2eb65927bd39197198c28c49efb94Amith Yamasani}
190