diff options
| author | 2020-06-16 14:31:16 -0700 | |
|---|---|---|
| committer | 2020-06-16 16:06:05 -0700 | |
| commit | 257b9e451fa4de9e59f4f562c12c6b00826eb3ba (patch) | |
| tree | 4e2dfcdad76aa6e45bd9705f5c6308e8be075e0e | |
| parent | 0192f737ffa347dee67129938d0133b573d72c5c (diff) | |
Null check on permission request check
This change adds a null check on PackageSetting.pkg before passing it on
to the method that checks for the QUERY_ALL_PACKAGES permission on the
package.
Test: atest AppEnumerationTests AppsFilterTest
Bug: 150405193
Change-Id: Ic92e29c685ff215f1c54dbb4aa8a0c6377a30fa7
| -rw-r--r-- | services/core/java/com/android/server/pm/AppsFilter.java | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/services/core/java/com/android/server/pm/AppsFilter.java b/services/core/java/com/android/server/pm/AppsFilter.java index 85c104ca4714..ccda5875d9fa 100644 --- a/services/core/java/com/android/server/pm/AppsFilter.java +++ b/services/core/java/com/android/server/pm/AppsFilter.java @@ -964,12 +964,14 @@ public class AppsFilter { try { Trace.traceBegin(TRACE_TAG_PACKAGE_MANAGER, "requestsQueryAllPackages"); if (callingPkgSetting != null) { - if (requestsQueryAllPackages(callingPkgSetting)) { - return false; - } + if (callingPkgSetting.pkg != null + && requestsQueryAllPackages(callingPkgSetting.pkg)) { + return false; + } } else { for (int i = callingSharedPkgSettings.size() - 1; i >= 0; i--) { - if (requestsQueryAllPackages(callingSharedPkgSettings.valueAt(i))) { + AndroidPackage pkg = callingSharedPkgSettings.valueAt(i).pkg; + if (pkg != null && requestsQueryAllPackages(pkg)) { return false; } } @@ -1058,10 +1060,10 @@ public class AppsFilter { } - private static boolean requestsQueryAllPackages(PackageSetting pkgSetting) { + private static boolean requestsQueryAllPackages(@NonNull AndroidPackage pkg) { // we're not guaranteed to have permissions yet analyzed at package add, so we inspect the // package directly - return pkgSetting.pkg.getRequestedPermissions().contains( + return pkg.getRequestedPermissions().contains( Manifest.permission.QUERY_ALL_PACKAGES); } |