Previously many usages of UserManager.getProfiles and getEnabledProfiles
were only using ids of returned users. Given that the list of users needs
to be parceled and unparceled for Binder calls, returning array of ids
minimizes memory usage and serialization time.
A new method getProfileIds was introduced which returns an array of userIds.
Existing method calls were updated where appropriate.
Bug:
27705805
Change-Id: Ib042f38d53d95d3b07cda7f824e5cb8c06cd10f5
// Clear all the users credentials could have been installed in for this user.
final UserManager um = (UserManager) getSystemService(USER_SERVICE);
- for (UserInfo pi : um.getProfiles(UserHandle.getUserId(Process.myUid()))) {
+ for (int userId : um.getProfileIdsWithDisabled(UserHandle.myUserId())) {
for (int uid : SYSTEM_CREDENTIAL_UIDS) {
- mKeyStore.clearUid(UserHandle.getUid(pi.id, uid));
+ mKeyStore.clearUid(UserHandle.getUid(userId, uid));
}
}
-
try {
KeyChainConnection keyChainConnection = KeyChain.bind(CredentialStorage.this);
try {
* @return the managed profile id or UserHandle.USER_NULL if there is none.
*/
public static int getManagedProfileId(UserManager um, int parentUserId) {
- List<UserInfo> profiles = um.getProfiles(parentUserId);
- int numProfiles = profiles.size();
- for (int i = 0; i < numProfiles; ++i) {
- UserInfo profile = profiles.get(i);
- if (profile.id != parentUserId) {
- return profile.id;
+ int[] profileIds = um.getProfileIdsWithDisabled(parentUserId);
+ for (int profileId : profileIds) {
+ if (profileId != parentUserId) {
+ return profileId;
}
}
return UserHandle.USER_NULL;