summaryrefslogtreecommitdiffstats
path: root/src/com/android/settings
diff options
context:
space:
mode:
authorZoltan Szatmary-Ban <szatmz@google.com>2014-07-17 20:14:34 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2014-07-17 19:45:26 +0000
commitcda76822c49ba80c8e1f2d000bb80058858f4712 (patch)
treebb107af74f0bd60d4357f6a5240e0d04648e3dfb /src/com/android/settings
parentdd82be9c705196d93986f356f464e6ebfed01002 (diff)
parent925560e9a2437e3cb6139a4421a6a5cd4b355fc5 (diff)
downloadpackages_apps_Settings-cda76822c49ba80c8e1f2d000bb80058858f4712.tar.gz
packages_apps_Settings-cda76822c49ba80c8e1f2d000bb80058858f4712.tar.bz2
packages_apps_Settings-cda76822c49ba80c8e1f2d000bb80058858f4712.zip
Merge "Update Location Settings for Enterprise" into lmp-dev
Diffstat (limited to 'src/com/android/settings')
-rw-r--r--src/com/android/settings/location/RecentLocationApps.java84
1 files changed, 43 insertions, 41 deletions
diff --git a/src/com/android/settings/location/RecentLocationApps.java b/src/com/android/settings/location/RecentLocationApps.java
index 164f4e71e..8e1ec0520 100644
--- a/src/com/android/settings/location/RecentLocationApps.java
+++ b/src/com/android/settings/location/RecentLocationApps.java
@@ -16,15 +16,18 @@
package com.android.settings.location;
-import android.app.ActivityManager;
+import android.app.AppGlobals;
import android.app.AppOpsManager;
import android.content.Context;
import android.content.pm.ApplicationInfo;
import android.content.pm.PackageManager;
+import android.content.pm.IPackageManager;
import android.graphics.drawable.Drawable;
import android.os.Bundle;
import android.os.Process;
+import android.os.RemoteException;
import android.os.UserHandle;
+import android.os.UserManager;
import android.preference.Preference;
import android.util.Log;
@@ -89,33 +92,37 @@ public class RecentLocationApps {
}
/**
- * Fills a list of applications which queried location recently within
- * specified time.
+ * Fills a list of applications which queried location recently within specified time.
*/
public List<Preference> getAppList() {
// Retrieve a location usage list from AppOps
AppOpsManager aoManager =
(AppOpsManager) mActivity.getSystemService(Context.APP_OPS_SERVICE);
- List<AppOpsManager.PackageOps> appOps = aoManager.getPackagesForOps(
- new int[] {
- AppOpsManager.OP_MONITOR_LOCATION,
- AppOpsManager.OP_MONITOR_HIGH_POWER_LOCATION,
- });
+ List<AppOpsManager.PackageOps> appOps = aoManager.getPackagesForOps(new int[] {
+ AppOpsManager.OP_MONITOR_LOCATION, AppOpsManager.OP_MONITOR_HIGH_POWER_LOCATION, });
// Process the AppOps list and generate a preference list.
ArrayList<Preference> prefs = new ArrayList<Preference>();
- long now = System.currentTimeMillis();
- for (AppOpsManager.PackageOps ops : appOps) {
+ final long now = System.currentTimeMillis();
+ final UserManager um = (UserManager) mActivity.getSystemService(Context.USER_SERVICE);
+ final List<UserHandle> profiles = um.getUserProfiles();
+
+ final int appOpsN = appOps.size();
+ for (int i = 0; i < appOpsN; ++i) {
+ AppOpsManager.PackageOps ops = appOps.get(i);
// Don't show the Android System in the list - it's not actionable for the user.
- // Also don't show apps belonging to background users.
+ // Also don't show apps belonging to background users except managed users.
+ String packageName = ops.getPackageName();
int uid = ops.getUid();
- boolean isAndroidOs = (uid == Process.SYSTEM_UID)
- && ANDROID_SYSTEM_PACKAGE_NAME.equals(ops.getPackageName());
- if (!isAndroidOs && ActivityManager.getCurrentUser() == UserHandle.getUserId(uid)) {
- Preference pref = getPreferenceFromOps(now, ops);
- if (pref != null) {
- prefs.add(pref);
- }
+ int userId = UserHandle.getUserId(uid);
+ boolean isAndroidOs =
+ (uid == Process.SYSTEM_UID) && ANDROID_SYSTEM_PACKAGE_NAME.equals(packageName);
+ if (isAndroidOs || !profiles.contains(new UserHandle(userId))) {
+ continue;
+ }
+ Preference preference = getPreferenceFromOps(um, now, ops);
+ if (preference != null) {
+ prefs.add(preference);
}
}
@@ -130,7 +137,8 @@ public class RecentLocationApps {
* When the PackageOps is fresh enough, this method returns a Preference pointing to the App
* Info page for that package.
*/
- private Preference getPreferenceFromOps(long now, AppOpsManager.PackageOps ops) {
+ private Preference getPreferenceFromOps(final UserManager um, long now,
+ AppOpsManager.PackageOps ops) {
String packageName = ops.getPackageName();
List<AppOpsManager.OpEntry> entries = ops.getOps();
boolean highBattery = false;
@@ -161,30 +169,24 @@ public class RecentLocationApps {
// The package is fresh enough, continue.
- Preference pref = null;
+ int uid = ops.getUid();
+ int userId = UserHandle.getUserId(uid);
+
+ Preference preference = null;
try {
- ApplicationInfo appInfo = mPackageManager.getApplicationInfo(
- packageName, PackageManager.GET_META_DATA);
- // Multiple users can install the same package. Each user gets a different Uid for
- // the same package.
- //
- // Here we retrieve the Uid with package name, that will be the Uid for that package
- // associated with the current active user. If the Uid differs from the Uid in ops,
- // that means this entry belongs to another inactive user and we should ignore that.
- if (appInfo.uid == ops.getUid()) {
- pref = createRecentLocationEntry(
- mPackageManager.getApplicationIcon(appInfo),
- mPackageManager.getApplicationLabel(appInfo),
- highBattery,
- new PackageEntryClickedListener(packageName));
- } else if (Log.isLoggable(TAG, Log.VERBOSE)) {
- Log.v(TAG, "package " + packageName + " with Uid " + ops.getUid() +
- " belongs to another inactive account, ignored.");
- }
- } catch (PackageManager.NameNotFoundException e) {
- Log.wtf(TAG, "Package not found: " + packageName, e);
+ IPackageManager ipm = AppGlobals.getPackageManager();
+ ApplicationInfo appInfo =
+ ipm.getApplicationInfo(packageName, PackageManager.GET_META_DATA, userId);
+
+ Drawable icon = um.getBadgedDrawableForUser(
+ mPackageManager.getApplicationIcon(appInfo), new UserHandle(userId));
+ preference = createRecentLocationEntry(icon,
+ mPackageManager.getApplicationLabel(appInfo), highBattery,
+ new PackageEntryClickedListener(packageName));
+ } catch (RemoteException e) {
+ Log.w(TAG, "Error while retrieving application info", e);
}
- return pref;
+ return preference;
}
}