diff options
| author | 2021-05-12 17:36:11 +0000 | |
|---|---|---|
| committer | 2021-05-12 17:36:11 +0000 | |
| commit | 2f2fa37a18805dfaa8c222a2184ea7b42d13c173 (patch) | |
| tree | 1e09bcdb11bed02de058474793ccc0bf70b66439 | |
| parent | 80b1e85c126eda3c1e4a1e38f2cf474ac95488a3 (diff) | |
| parent | 387182eb494e596ef670d6fd919f85e92d156c79 (diff) | |
Ensure storage permission revoke happens for all users am: 387182eb49
Original change: https://googleplex-android-review.googlesource.com/c/platform/frameworks/base/+/14357211
Change-Id: Icf0e785e3ee908301240ca5c2eb63a8d21ac7b07
| -rw-r--r-- | services/core/java/com/android/server/pm/permission/PermissionManagerService.java | 37 |
1 files changed, 22 insertions, 15 deletions
diff --git a/services/core/java/com/android/server/pm/permission/PermissionManagerService.java b/services/core/java/com/android/server/pm/permission/PermissionManagerService.java index fe0657e1792b..82f963e1df2a 100644 --- a/services/core/java/com/android/server/pm/permission/PermissionManagerService.java +++ b/services/core/java/com/android/server/pm/permission/PermissionManagerService.java @@ -618,23 +618,30 @@ public class PermissionManagerService { } final int callingUid = Binder.getCallingUid(); - final int userId = UserHandle.getUserId(newPackage.applicationInfo.uid); - int numRequestedPermissions = newPackage.requestedPermissions.size(); - for (int i = 0; i < numRequestedPermissions; i++) { - PermissionInfo permInfo = getPermissionInfo(newPackage.requestedPermissions.get(i), - newPackage.packageName, 0, callingUid); - if (permInfo == null || !STORAGE_PERMISSIONS.contains(permInfo.name)) { - continue; - } - EventLog.writeEvent(0x534e4554, "171430330", newPackage.applicationInfo.uid, - "Revoking permission " + permInfo.name + " from package " - + newPackage.packageName + " as either the sdk downgraded " - + downgradedSdk + " or newly requested legacy full storage " - + newlyRequestsLegacy); + for (int userId: mUserManagerInt.getUserIds()) { + int numRequestedPermissions = newPackage.requestedPermissions.size(); + for (int i = 0; i < numRequestedPermissions; i++) { + PermissionInfo permInfo = getPermissionInfo(newPackage.requestedPermissions.get(i), + newPackage.packageName, 0, callingUid); + if (permInfo == null || !STORAGE_PERMISSIONS.contains(permInfo.name)) { + continue; + } + + EventLog.writeEvent(0x534e4554, "171430330", newPackage.applicationInfo.uid, + "Revoking permission " + permInfo.name + " from package " + + newPackage.packageName + " as either the sdk downgraded " + + downgradedSdk + " or newly requested legacy full storage " + + newlyRequestsLegacy); - revokeRuntimePermission(permInfo.name, newPackage.packageName, - false, userId, permissionCallback); + try { + revokeRuntimePermission(permInfo.name, newPackage.packageName, + false, userId, permissionCallback); + } catch (IllegalStateException | SecurityException e) { + Log.e(TAG, "unable to revoke " + permInfo.name + " for " + + newPackage.packageName + " user " + userId, e); + } + } } } |