Merge "Only show restricted apps that belong to the user." into pi-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
5464549257
@@ -19,6 +19,8 @@ package com.android.settings.fuelgauge;
|
||||
|
||||
import android.app.AppOpsManager;
|
||||
import android.content.Context;
|
||||
import android.os.UserHandle;
|
||||
import android.os.UserManager;
|
||||
import android.support.annotation.VisibleForTesting;
|
||||
import android.support.v7.preference.Preference;
|
||||
|
||||
@@ -38,14 +40,17 @@ public class RestrictAppPreferenceController extends BasePreferenceController {
|
||||
@VisibleForTesting
|
||||
static final String KEY_RESTRICT_APP = "restricted_app";
|
||||
|
||||
@VisibleForTesting
|
||||
List<AppInfo> mAppInfos;
|
||||
private AppOpsManager mAppOpsManager;
|
||||
private List<AppInfo> mAppInfos;
|
||||
private SettingsActivity mSettingsActivity;
|
||||
private InstrumentedPreferenceFragment mPreferenceFragment;
|
||||
private UserManager mUserManager;
|
||||
|
||||
public RestrictAppPreferenceController(Context context) {
|
||||
super(context, KEY_RESTRICT_APP);
|
||||
mAppOpsManager = (AppOpsManager) context.getSystemService(Context.APP_OPS_SERVICE);
|
||||
mUserManager = context.getSystemService(UserManager.class);
|
||||
}
|
||||
|
||||
public RestrictAppPreferenceController(SettingsActivity settingsActivity,
|
||||
@@ -64,7 +69,7 @@ public class RestrictAppPreferenceController extends BasePreferenceController {
|
||||
public void updateState(Preference preference) {
|
||||
super.updateState(preference);
|
||||
|
||||
mAppInfos = BatteryTipUtils.getRestrictedAppsList(mAppOpsManager);
|
||||
mAppInfos = BatteryTipUtils.getRestrictedAppsList(mAppOpsManager, mUserManager);
|
||||
|
||||
final int num = mAppInfos.size();
|
||||
// Enable the preference if some apps already been restricted, otherwise disable it
|
||||
|
@@ -18,6 +18,7 @@ package com.android.settings.fuelgauge.batterytip;
|
||||
|
||||
import android.app.AppOpsManager;
|
||||
import android.content.Context;
|
||||
import android.os.UserManager;
|
||||
import android.provider.Settings;
|
||||
import android.support.annotation.VisibleForTesting;
|
||||
import android.support.v7.preference.Preference;
|
||||
@@ -35,12 +36,14 @@ public class BatteryManagerPreferenceController extends BasePreferenceController
|
||||
private static final int ON = 1;
|
||||
private PowerUsageFeatureProvider mPowerUsageFeatureProvider;
|
||||
private AppOpsManager mAppOpsManager;
|
||||
private UserManager mUserManager;
|
||||
|
||||
public BatteryManagerPreferenceController(Context context) {
|
||||
super(context, KEY_BATTERY_MANAGER);
|
||||
mPowerUsageFeatureProvider = FeatureFactory.getFactory(
|
||||
context).getPowerUsageFeatureProvider(context);
|
||||
mAppOpsManager = context.getSystemService(AppOpsManager.class);
|
||||
mUserManager = context.getSystemService(UserManager.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -51,7 +54,7 @@ public class BatteryManagerPreferenceController extends BasePreferenceController
|
||||
@Override
|
||||
public void updateState(Preference preference) {
|
||||
super.updateState(preference);
|
||||
final int num = BatteryTipUtils.getRestrictedAppsList(mAppOpsManager).size();
|
||||
final int num = BatteryTipUtils.getRestrictedAppsList(mAppOpsManager, mUserManager).size();
|
||||
final String setting = mPowerUsageFeatureProvider.isSmartBatterySupported()
|
||||
? Settings.Global.APP_STANDBY_ENABLED
|
||||
: Settings.Global.APP_AUTO_RESTRICTION_ENABLED;
|
||||
|
@@ -21,6 +21,8 @@ import android.app.PendingIntent;
|
||||
import android.app.StatsManager;
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.os.UserHandle;
|
||||
import android.os.UserManager;
|
||||
import android.support.annotation.NonNull;
|
||||
|
||||
import com.android.internal.util.CollectionUtils;
|
||||
@@ -49,7 +51,9 @@ public class BatteryTipUtils {
|
||||
* Get a list of restricted apps with {@link AppOpsManager#OP_RUN_ANY_IN_BACKGROUND}
|
||||
*/
|
||||
@NonNull
|
||||
public static List<AppInfo> getRestrictedAppsList(AppOpsManager appOpsManager) {
|
||||
public static List<AppInfo> getRestrictedAppsList(AppOpsManager appOpsManager,
|
||||
UserManager userManager) {
|
||||
final List<UserHandle> userHandles = userManager.getUserProfiles();
|
||||
final List<AppOpsManager.PackageOps> packageOpsList = appOpsManager.getPackagesForOps(
|
||||
new int[]{AppOpsManager.OP_RUN_ANY_IN_BACKGROUND});
|
||||
final List<AppInfo> appInfos = new ArrayList<>();
|
||||
@@ -62,7 +66,9 @@ public class BatteryTipUtils {
|
||||
if (entry.getOp() != AppOpsManager.OP_RUN_ANY_IN_BACKGROUND) {
|
||||
continue;
|
||||
}
|
||||
if (entry.getMode() != AppOpsManager.MODE_ALLOWED) {
|
||||
if (entry.getMode() != AppOpsManager.MODE_ALLOWED
|
||||
&& userHandles.contains(
|
||||
new UserHandle(UserHandle.getUserId(packageOps.getUid())))) {
|
||||
appInfos.add(new AppInfo.Builder()
|
||||
.setPackageName(packageOps.getPackageName())
|
||||
.setUid(packageOps.getUid())
|
||||
|
Reference in New Issue
Block a user