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