summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Nate Myren <ntmyren@google.com> 2021-05-12 17:36:11 +0000
committer Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com> 2021-05-12 17:36:11 +0000
commit2f2fa37a18805dfaa8c222a2184ea7b42d13c173 (patch)
tree1e09bcdb11bed02de058474793ccc0bf70b66439
parent80b1e85c126eda3c1e4a1e38f2cf474ac95488a3 (diff)
parent387182eb494e596ef670d6fd919f85e92d156c79 (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.java37
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);
+ }
+ }
}
}