Merge "Move a bunch of app restrictions logic to SettingsLib"
This commit is contained in:
@@ -17,7 +17,6 @@
|
|||||||
package com.android.settings.users;
|
package com.android.settings.users;
|
||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.appwidget.AppWidgetManager;
|
|
||||||
import android.content.BroadcastReceiver;
|
import android.content.BroadcastReceiver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
@@ -30,10 +29,7 @@ import android.content.pm.IPackageManager;
|
|||||||
import android.content.pm.PackageInfo;
|
import android.content.pm.PackageInfo;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.pm.PackageManager.NameNotFoundException;
|
import android.content.pm.PackageManager.NameNotFoundException;
|
||||||
import android.content.pm.ParceledListSlice;
|
|
||||||
import android.content.pm.ResolveInfo;
|
import android.content.pm.ResolveInfo;
|
||||||
import android.content.res.Resources;
|
|
||||||
import android.graphics.drawable.Drawable;
|
|
||||||
import android.os.AsyncTask;
|
import android.os.AsyncTask;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.RemoteException;
|
import android.os.RemoteException;
|
||||||
@@ -48,13 +44,10 @@ import android.support.v7.preference.Preference.OnPreferenceChangeListener;
|
|||||||
import android.support.v7.preference.Preference.OnPreferenceClickListener;
|
import android.support.v7.preference.Preference.OnPreferenceClickListener;
|
||||||
import android.support.v7.preference.PreferenceGroup;
|
import android.support.v7.preference.PreferenceGroup;
|
||||||
import android.support.v7.preference.PreferenceViewHolder;
|
import android.support.v7.preference.PreferenceViewHolder;
|
||||||
import android.text.TextUtils;
|
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.View.OnClickListener;
|
import android.view.View.OnClickListener;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.view.inputmethod.InputMethodInfo;
|
|
||||||
import android.view.inputmethod.InputMethodManager;
|
|
||||||
import android.widget.CompoundButton;
|
import android.widget.CompoundButton;
|
||||||
import android.widget.CompoundButton.OnCheckedChangeListener;
|
import android.widget.CompoundButton.OnCheckedChangeListener;
|
||||||
import android.widget.Switch;
|
import android.widget.Switch;
|
||||||
@@ -63,19 +56,19 @@ import com.android.internal.logging.MetricsLogger;
|
|||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.SettingsPreferenceFragment;
|
import com.android.settings.SettingsPreferenceFragment;
|
||||||
import com.android.settings.Utils;
|
import com.android.settings.Utils;
|
||||||
|
import com.android.settingslib.users.AppRestrictionsHelper;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.Comparator;
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.StringTokenizer;
|
import java.util.StringTokenizer;
|
||||||
|
|
||||||
public class AppRestrictionsFragment extends SettingsPreferenceFragment implements
|
public class AppRestrictionsFragment extends SettingsPreferenceFragment implements
|
||||||
OnPreferenceChangeListener, OnClickListener, OnPreferenceClickListener {
|
OnPreferenceChangeListener, OnClickListener, OnPreferenceClickListener,
|
||||||
|
AppRestrictionsHelper.OnDisableUiForPackageListener {
|
||||||
|
|
||||||
private static final String TAG = AppRestrictionsFragment.class.getSimpleName();
|
private static final String TAG = AppRestrictionsFragment.class.getSimpleName();
|
||||||
|
|
||||||
@@ -89,6 +82,8 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
protected UserHandle mUser;
|
protected UserHandle mUser;
|
||||||
private PackageInfo mSysPackageInfo;
|
private PackageInfo mSysPackageInfo;
|
||||||
|
|
||||||
|
private AppRestrictionsHelper mHelper;
|
||||||
|
|
||||||
private PreferenceGroup mAppList;
|
private PreferenceGroup mAppList;
|
||||||
|
|
||||||
private static final int MAX_APP_RESTRICTIONS = 100;
|
private static final int MAX_APP_RESTRICTIONS = 100;
|
||||||
@@ -101,7 +96,6 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
/** Key for extra passed in from calling fragment to indicate if this is a newly created user */
|
/** Key for extra passed in from calling fragment to indicate if this is a newly created user */
|
||||||
public static final String EXTRA_NEW_USER = "new_user";
|
public static final String EXTRA_NEW_USER = "new_user";
|
||||||
|
|
||||||
HashMap<String,Boolean> mSelectedPackages = new HashMap<String,Boolean>();
|
|
||||||
private boolean mFirstTime = true;
|
private boolean mFirstTime = true;
|
||||||
private boolean mNewUser;
|
private boolean mNewUser;
|
||||||
private boolean mAppListChanged;
|
private boolean mAppListChanged;
|
||||||
@@ -110,11 +104,8 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
private static final int CUSTOM_REQUEST_CODE_START = 1000;
|
private static final int CUSTOM_REQUEST_CODE_START = 1000;
|
||||||
private int mCustomRequestCode = CUSTOM_REQUEST_CODE_START;
|
private int mCustomRequestCode = CUSTOM_REQUEST_CODE_START;
|
||||||
|
|
||||||
private HashMap<Integer, AppRestrictionsPreference> mCustomRequestMap =
|
private HashMap<Integer, AppRestrictionsPreference> mCustomRequestMap = new HashMap<>();
|
||||||
new HashMap<Integer,AppRestrictionsPreference>();
|
|
||||||
|
|
||||||
private List<SelectableAppInfo> mVisibleApps;
|
|
||||||
private List<ApplicationInfo> mUserApps;
|
|
||||||
private AsyncTask mAppLoadingTask;
|
private AsyncTask mAppLoadingTask;
|
||||||
|
|
||||||
private BroadcastReceiver mUserBackgrounding = new BroadcastReceiver() {
|
private BroadcastReceiver mUserBackgrounding = new BroadcastReceiver() {
|
||||||
@@ -125,7 +116,7 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
// have been scheduled during user startup.
|
// have been scheduled during user startup.
|
||||||
if (mAppListChanged) {
|
if (mAppListChanged) {
|
||||||
if (DEBUG) Log.d(TAG, "User backgrounding, update app list");
|
if (DEBUG) Log.d(TAG, "User backgrounding, update app list");
|
||||||
applyUserAppsStates();
|
mHelper.applyUserAppsStates(AppRestrictionsFragment.this);
|
||||||
if (DEBUG) Log.d(TAG, "User backgrounding, done updating app list");
|
if (DEBUG) Log.d(TAG, "User backgrounding, done updating app list");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -138,27 +129,13 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static class SelectableAppInfo {
|
|
||||||
String packageName;
|
|
||||||
CharSequence appName;
|
|
||||||
CharSequence activityName;
|
|
||||||
Drawable icon;
|
|
||||||
SelectableAppInfo masterEntry;
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return packageName + ": appName=" + appName + "; activityName=" + activityName
|
|
||||||
+ "; icon=" + icon + "; masterEntry=" + masterEntry;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static class AppRestrictionsPreference extends SwitchPreference {
|
static class AppRestrictionsPreference extends SwitchPreference {
|
||||||
private boolean hasSettings;
|
private boolean hasSettings;
|
||||||
private OnClickListener listener;
|
private OnClickListener listener;
|
||||||
private ArrayList<RestrictionEntry> restrictions;
|
private ArrayList<RestrictionEntry> restrictions;
|
||||||
private boolean panelOpen;
|
private boolean panelOpen;
|
||||||
private boolean immutable;
|
private boolean immutable;
|
||||||
private List<Preference> mChildren = new ArrayList<Preference>();
|
private List<Preference> mChildren = new ArrayList<>();
|
||||||
|
|
||||||
AppRestrictionsPreference(Context context, OnClickListener listener) {
|
AppRestrictionsPreference(Context context, OnClickListener listener) {
|
||||||
super(context);
|
super(context);
|
||||||
@@ -248,6 +225,7 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
mUser = android.os.Process.myUserHandle();
|
mUser = android.os.Process.myUserHandle();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mHelper = new AppRestrictionsHelper(getContext(), mUser);
|
||||||
mPackageManager = getActivity().getPackageManager();
|
mPackageManager = getActivity().getPackageManager();
|
||||||
mIPm = IPackageManager.Stub.asInterface(ServiceManager.getService("package"));
|
mIPm = IPackageManager.Stub.asInterface(ServiceManager.getService("package"));
|
||||||
mUserManager = (UserManager) getActivity().getSystemService(Context.USER_SERVICE);
|
mUserManager = (UserManager) getActivity().getSystemService(Context.USER_SERVICE);
|
||||||
@@ -260,6 +238,7 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
}
|
}
|
||||||
addPreferencesFromResource(R.xml.app_restrictions);
|
addPreferencesFromResource(R.xml.app_restrictions);
|
||||||
mAppList = getAppPreferenceGroup();
|
mAppList = getAppPreferenceGroup();
|
||||||
|
mAppList.setOrderingAsAdded(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -287,7 +266,7 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
|
|
||||||
mAppListChanged = false;
|
mAppListChanged = false;
|
||||||
if (mAppLoadingTask == null || mAppLoadingTask.getStatus() == AsyncTask.Status.FINISHED) {
|
if (mAppLoadingTask == null || mAppLoadingTask.getStatus() == AsyncTask.Status.FINISHED) {
|
||||||
mAppLoadingTask = new AppLoadingTask().execute((Void[]) null);
|
mAppLoadingTask = new AppLoadingTask().execute();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -298,11 +277,13 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
getActivity().unregisterReceiver(mUserBackgrounding);
|
getActivity().unregisterReceiver(mUserBackgrounding);
|
||||||
getActivity().unregisterReceiver(mPackageObserver);
|
getActivity().unregisterReceiver(mPackageObserver);
|
||||||
if (mAppListChanged) {
|
if (mAppListChanged) {
|
||||||
new Thread() {
|
new AsyncTask<Void, Void, Void>() {
|
||||||
public void run() {
|
@Override
|
||||||
applyUserAppsStates();
|
protected Void doInBackground(Void... params) {
|
||||||
|
mHelper.applyUserAppsStates(AppRestrictionsFragment.this);
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
}.start();
|
}.execute();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -324,68 +305,8 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
return getPreferenceScreen();
|
return getPreferenceScreen();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void applyUserAppsStates() {
|
@Override
|
||||||
final int userId = mUser.getIdentifier();
|
public void onDisableUiForPackage(String packageName) {
|
||||||
if (!mUserManager.getUserInfo(userId).isRestricted() && userId != UserHandle.myUserId()) {
|
|
||||||
Log.e(TAG, "Cannot apply application restrictions on another user!");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
for (Map.Entry<String,Boolean> entry : mSelectedPackages.entrySet()) {
|
|
||||||
String packageName = entry.getKey();
|
|
||||||
boolean enabled = entry.getValue();
|
|
||||||
applyUserAppState(packageName, enabled);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void applyUserAppState(String packageName, boolean enabled) {
|
|
||||||
final int userId = mUser.getIdentifier();
|
|
||||||
if (enabled) {
|
|
||||||
// Enable selected apps
|
|
||||||
try {
|
|
||||||
ApplicationInfo info = mIPm.getApplicationInfo(packageName,
|
|
||||||
PackageManager.GET_UNINSTALLED_PACKAGES, userId);
|
|
||||||
if (info == null || info.enabled == false
|
|
||||||
|| (info.flags&ApplicationInfo.FLAG_INSTALLED) == 0) {
|
|
||||||
mIPm.installExistingPackageAsUser(packageName, mUser.getIdentifier());
|
|
||||||
if (DEBUG) {
|
|
||||||
Log.d(TAG, "Installing " + packageName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (info != null && (info.privateFlags&ApplicationInfo.PRIVATE_FLAG_HIDDEN) != 0
|
|
||||||
&& (info.flags&ApplicationInfo.FLAG_INSTALLED) != 0) {
|
|
||||||
disableUiForPackage(packageName);
|
|
||||||
mIPm.setApplicationHiddenSettingAsUser(packageName, false, userId);
|
|
||||||
if (DEBUG) {
|
|
||||||
Log.d(TAG, "Unhiding " + packageName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (RemoteException re) {
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// Blacklist all other apps, system or downloaded
|
|
||||||
try {
|
|
||||||
ApplicationInfo info = mIPm.getApplicationInfo(packageName, 0, userId);
|
|
||||||
if (info != null) {
|
|
||||||
if (mRestrictedProfile) {
|
|
||||||
mIPm.deletePackageAsUser(packageName, null, mUser.getIdentifier(),
|
|
||||||
PackageManager.DELETE_SYSTEM_APP);
|
|
||||||
if (DEBUG) {
|
|
||||||
Log.d(TAG, "Uninstalling " + packageName);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
disableUiForPackage(packageName);
|
|
||||||
mIPm.setApplicationHiddenSettingAsUser(packageName, true, userId);
|
|
||||||
if (DEBUG) {
|
|
||||||
Log.d(TAG, "Hiding " + packageName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (RemoteException re) {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void disableUiForPackage(String packageName) {
|
|
||||||
AppRestrictionsPreference pref = (AppRestrictionsPreference) findPreference(
|
AppRestrictionsPreference pref = (AppRestrictionsPreference) findPreference(
|
||||||
getKeyForPackage(packageName));
|
getKeyForPackage(packageName));
|
||||||
if (pref != null) {
|
if (pref != null) {
|
||||||
@@ -393,106 +314,11 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isSystemPackage(String packageName) {
|
|
||||||
try {
|
|
||||||
final PackageInfo pi = mPackageManager.getPackageInfo(packageName, 0);
|
|
||||||
if (pi.applicationInfo == null) return false;
|
|
||||||
final int flags = pi.applicationInfo.flags;
|
|
||||||
if ((flags & ApplicationInfo.FLAG_SYSTEM) != 0
|
|
||||||
|| (flags & ApplicationInfo.FLAG_UPDATED_SYSTEM_APP) != 0) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
} catch (NameNotFoundException nnfe) {
|
|
||||||
// Missing package?
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Find all pre-installed input methods that are marked as default
|
|
||||||
* and add them to an exclusion list so that they aren't
|
|
||||||
* presented to the user for toggling.
|
|
||||||
* Don't add non-default ones, as they may include other stuff that we
|
|
||||||
* don't need to auto-include.
|
|
||||||
* @param excludePackages the set of package names to append to
|
|
||||||
*/
|
|
||||||
private void addSystemImes(Set<String> excludePackages) {
|
|
||||||
final Context context = getActivity();
|
|
||||||
if (context == null) return;
|
|
||||||
InputMethodManager imm = (InputMethodManager)
|
|
||||||
context.getSystemService(Context.INPUT_METHOD_SERVICE);
|
|
||||||
List<InputMethodInfo> imis = imm.getInputMethodList();
|
|
||||||
for (InputMethodInfo imi : imis) {
|
|
||||||
try {
|
|
||||||
if (imi.isDefault(context) && isSystemPackage(imi.getPackageName())) {
|
|
||||||
excludePackages.add(imi.getPackageName());
|
|
||||||
}
|
|
||||||
} catch (Resources.NotFoundException rnfe) {
|
|
||||||
// Not default
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Add system apps that match an intent to the list, excluding any packages in the exclude list.
|
|
||||||
* @param visibleApps list of apps to append the new list to
|
|
||||||
* @param intent the intent to match
|
|
||||||
* @param excludePackages the set of package names to be excluded, since they're required
|
|
||||||
*/
|
|
||||||
private void addSystemApps(List<SelectableAppInfo> visibleApps, Intent intent,
|
|
||||||
Set<String> excludePackages) {
|
|
||||||
if (getActivity() == null) return;
|
|
||||||
final PackageManager pm = mPackageManager;
|
|
||||||
List<ResolveInfo> launchableApps = pm.queryIntentActivities(intent,
|
|
||||||
PackageManager.GET_DISABLED_COMPONENTS | PackageManager.GET_UNINSTALLED_PACKAGES);
|
|
||||||
for (ResolveInfo app : launchableApps) {
|
|
||||||
if (app.activityInfo != null && app.activityInfo.applicationInfo != null) {
|
|
||||||
final String packageName = app.activityInfo.packageName;
|
|
||||||
int flags = app.activityInfo.applicationInfo.flags;
|
|
||||||
if ((flags & ApplicationInfo.FLAG_SYSTEM) != 0
|
|
||||||
|| (flags & ApplicationInfo.FLAG_UPDATED_SYSTEM_APP) != 0) {
|
|
||||||
// System app
|
|
||||||
// Skip excluded packages
|
|
||||||
if (excludePackages.contains(packageName)) continue;
|
|
||||||
int enabled = pm.getApplicationEnabledSetting(packageName);
|
|
||||||
if (enabled == PackageManager.COMPONENT_ENABLED_STATE_DISABLED_UNTIL_USED
|
|
||||||
|| enabled == PackageManager.COMPONENT_ENABLED_STATE_DISABLED) {
|
|
||||||
// Check if the app is already enabled for the target user
|
|
||||||
ApplicationInfo targetUserAppInfo = getAppInfoForUser(packageName,
|
|
||||||
0, mUser);
|
|
||||||
if (targetUserAppInfo == null
|
|
||||||
|| (targetUserAppInfo.flags&ApplicationInfo.FLAG_INSTALLED) == 0) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
SelectableAppInfo info = new SelectableAppInfo();
|
|
||||||
info.packageName = app.activityInfo.packageName;
|
|
||||||
info.appName = app.activityInfo.applicationInfo.loadLabel(pm);
|
|
||||||
info.icon = app.activityInfo.loadIcon(pm);
|
|
||||||
info.activityName = app.activityInfo.loadLabel(pm);
|
|
||||||
if (info.activityName == null) info.activityName = info.appName;
|
|
||||||
|
|
||||||
visibleApps.add(info);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private ApplicationInfo getAppInfoForUser(String packageName, int flags, UserHandle user) {
|
|
||||||
try {
|
|
||||||
ApplicationInfo targetUserAppInfo = mIPm.getApplicationInfo(packageName, flags,
|
|
||||||
user.getIdentifier());
|
|
||||||
return targetUserAppInfo;
|
|
||||||
} catch (RemoteException re) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private class AppLoadingTask extends AsyncTask<Void, Void, Void> {
|
private class AppLoadingTask extends AsyncTask<Void, Void, Void> {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Void doInBackground(Void... params) {
|
protected Void doInBackground(Void... params) {
|
||||||
fetchAndMergeApps();
|
mHelper.fetchAndMergeApps();
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -500,117 +326,6 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
protected void onPostExecute(Void result) {
|
protected void onPostExecute(Void result) {
|
||||||
populateApps();
|
populateApps();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void onPreExecute() {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void fetchAndMergeApps() {
|
|
||||||
mAppList.setOrderingAsAdded(false);
|
|
||||||
mVisibleApps = new ArrayList<SelectableAppInfo>();
|
|
||||||
final Context context = getActivity();
|
|
||||||
if (context == null) return;
|
|
||||||
final PackageManager pm = mPackageManager;
|
|
||||||
final IPackageManager ipm = mIPm;
|
|
||||||
|
|
||||||
final HashSet<String> excludePackages = new HashSet<String>();
|
|
||||||
addSystemImes(excludePackages);
|
|
||||||
|
|
||||||
// Add launchers
|
|
||||||
Intent launcherIntent = new Intent(Intent.ACTION_MAIN);
|
|
||||||
launcherIntent.addCategory(Intent.CATEGORY_LAUNCHER);
|
|
||||||
addSystemApps(mVisibleApps, launcherIntent, excludePackages);
|
|
||||||
|
|
||||||
// Add widgets
|
|
||||||
Intent widgetIntent = new Intent(AppWidgetManager.ACTION_APPWIDGET_UPDATE);
|
|
||||||
addSystemApps(mVisibleApps, widgetIntent, excludePackages);
|
|
||||||
|
|
||||||
List<ApplicationInfo> installedApps = pm.getInstalledApplications(
|
|
||||||
PackageManager.GET_UNINSTALLED_PACKAGES);
|
|
||||||
for (ApplicationInfo app : installedApps) {
|
|
||||||
// If it's not installed, skip
|
|
||||||
if ((app.flags & ApplicationInfo.FLAG_INSTALLED) == 0) continue;
|
|
||||||
|
|
||||||
if ((app.flags & ApplicationInfo.FLAG_SYSTEM) == 0
|
|
||||||
&& (app.flags & ApplicationInfo.FLAG_UPDATED_SYSTEM_APP) == 0) {
|
|
||||||
// Downloaded app
|
|
||||||
SelectableAppInfo info = new SelectableAppInfo();
|
|
||||||
info.packageName = app.packageName;
|
|
||||||
info.appName = app.loadLabel(pm);
|
|
||||||
info.activityName = info.appName;
|
|
||||||
info.icon = app.loadIcon(pm);
|
|
||||||
mVisibleApps.add(info);
|
|
||||||
} else {
|
|
||||||
try {
|
|
||||||
PackageInfo pi = pm.getPackageInfo(app.packageName, 0);
|
|
||||||
// If it's a system app that requires an account and doesn't see restricted
|
|
||||||
// accounts, mark for removal. It might get shown in the UI if it has an icon
|
|
||||||
// but will still be marked as false and immutable.
|
|
||||||
if (mRestrictedProfile
|
|
||||||
&& pi.requiredAccountType != null && pi.restrictedAccountType == null) {
|
|
||||||
mSelectedPackages.put(app.packageName, false);
|
|
||||||
}
|
|
||||||
} catch (NameNotFoundException re) {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get the list of apps already installed for the user
|
|
||||||
mUserApps = null;
|
|
||||||
try {
|
|
||||||
ParceledListSlice listSlice = ipm.getInstalledApplications(
|
|
||||||
PackageManager.GET_UNINSTALLED_PACKAGES, mUser.getIdentifier());
|
|
||||||
if (listSlice != null) {
|
|
||||||
mUserApps = listSlice.getList();
|
|
||||||
}
|
|
||||||
} catch (RemoteException re) {
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mUserApps != null) {
|
|
||||||
for (ApplicationInfo app : mUserApps) {
|
|
||||||
if ((app.flags & ApplicationInfo.FLAG_INSTALLED) == 0) continue;
|
|
||||||
|
|
||||||
if ((app.flags & ApplicationInfo.FLAG_SYSTEM) == 0
|
|
||||||
&& (app.flags & ApplicationInfo.FLAG_UPDATED_SYSTEM_APP) == 0) {
|
|
||||||
// Downloaded app
|
|
||||||
SelectableAppInfo info = new SelectableAppInfo();
|
|
||||||
info.packageName = app.packageName;
|
|
||||||
info.appName = app.loadLabel(pm);
|
|
||||||
info.activityName = info.appName;
|
|
||||||
info.icon = app.loadIcon(pm);
|
|
||||||
mVisibleApps.add(info);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Sort the list of visible apps
|
|
||||||
Collections.sort(mVisibleApps, new AppLabelComparator());
|
|
||||||
|
|
||||||
// Remove dupes
|
|
||||||
Set<String> dedupPackageSet = new HashSet<String>();
|
|
||||||
for (int i = mVisibleApps.size() - 1; i >= 0; i--) {
|
|
||||||
SelectableAppInfo info = mVisibleApps.get(i);
|
|
||||||
if (DEBUG) Log.i(TAG, info.toString());
|
|
||||||
String both = info.packageName + "+" + info.activityName;
|
|
||||||
if (!TextUtils.isEmpty(info.packageName)
|
|
||||||
&& !TextUtils.isEmpty(info.activityName)
|
|
||||||
&& dedupPackageSet.contains(both)) {
|
|
||||||
mVisibleApps.remove(i);
|
|
||||||
} else {
|
|
||||||
dedupPackageSet.add(both);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Establish master/slave relationship for entries that share a package name
|
|
||||||
HashMap<String,SelectableAppInfo> packageMap = new HashMap<String,SelectableAppInfo>();
|
|
||||||
for (SelectableAppInfo info : mVisibleApps) {
|
|
||||||
if (packageMap.containsKey(info.packageName)) {
|
|
||||||
info.masterEntry = packageMap.get(info.packageName);
|
|
||||||
} else {
|
|
||||||
packageMap.put(info.packageName, info);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isPlatformSigned(PackageInfo pi) {
|
private boolean isPlatformSigned(PackageInfo pi) {
|
||||||
@@ -641,7 +356,7 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
mAppList.removeAll();
|
mAppList.removeAll();
|
||||||
Intent restrictionsIntent = new Intent(Intent.ACTION_GET_RESTRICTION_ENTRIES);
|
Intent restrictionsIntent = new Intent(Intent.ACTION_GET_RESTRICTION_ENTRIES);
|
||||||
final List<ResolveInfo> receivers = pm.queryBroadcastReceivers(restrictionsIntent, 0);
|
final List<ResolveInfo> receivers = pm.queryBroadcastReceivers(restrictionsIntent, 0);
|
||||||
for (SelectableAppInfo app : mVisibleApps) {
|
for (AppRestrictionsHelper.SelectableAppInfo app : mHelper.getVisibleApps()) {
|
||||||
String packageName = app.packageName;
|
String packageName = app.packageName;
|
||||||
if (packageName == null) continue;
|
if (packageName == null) continue;
|
||||||
final boolean isSettingsApp = packageName.equals(context.getPackageName());
|
final boolean isSettingsApp = packageName.equals(context.getPackageName());
|
||||||
@@ -650,15 +365,16 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
if (isSettingsApp) {
|
if (isSettingsApp) {
|
||||||
addLocationAppRestrictionsPreference(app, p);
|
addLocationAppRestrictionsPreference(app, p);
|
||||||
// Settings app should be available to restricted user
|
// Settings app should be available to restricted user
|
||||||
mSelectedPackages.put(packageName, true);
|
mHelper.setPackageSelected(packageName, true);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
PackageInfo pi = null;
|
PackageInfo pi = null;
|
||||||
try {
|
try {
|
||||||
pi = ipm.getPackageInfo(packageName,
|
pi = ipm.getPackageInfo(packageName,
|
||||||
PackageManager.GET_UNINSTALLED_PACKAGES
|
PackageManager.MATCH_UNINSTALLED_PACKAGES
|
||||||
| PackageManager.GET_SIGNATURES, userId);
|
| PackageManager.GET_SIGNATURES, userId);
|
||||||
} catch (RemoteException e) {
|
} catch (RemoteException e) {
|
||||||
|
// Ignore
|
||||||
}
|
}
|
||||||
if (pi == null) {
|
if (pi == null) {
|
||||||
continue;
|
continue;
|
||||||
@@ -692,10 +408,10 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
}
|
}
|
||||||
if (app.masterEntry != null) {
|
if (app.masterEntry != null) {
|
||||||
p.setImmutable(true);
|
p.setImmutable(true);
|
||||||
p.setChecked(mSelectedPackages.get(packageName));
|
p.setChecked(mHelper.isPackageSelected(packageName));
|
||||||
}
|
}
|
||||||
p.setOrder(MAX_APP_RESTRICTIONS * (mAppList.getPreferenceCount() + 2));
|
p.setOrder(MAX_APP_RESTRICTIONS * (mAppList.getPreferenceCount() + 2));
|
||||||
mSelectedPackages.put(packageName, p.isChecked());
|
mHelper.setPackageSelected(packageName, p.isChecked());
|
||||||
mAppList.addPreference(p);
|
mAppList.addPreference(p);
|
||||||
}
|
}
|
||||||
mAppListChanged = true;
|
mAppListChanged = true;
|
||||||
@@ -703,11 +419,11 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
// to avoid taking the hit in onPause(), which can cause race conditions on user switch.
|
// to avoid taking the hit in onPause(), which can cause race conditions on user switch.
|
||||||
if (mNewUser && mFirstTime) {
|
if (mNewUser && mFirstTime) {
|
||||||
mFirstTime = false;
|
mFirstTime = false;
|
||||||
applyUserAppsStates();
|
mHelper.applyUserAppsStates(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private String getPackageSummary(PackageInfo pi, SelectableAppInfo app) {
|
private String getPackageSummary(PackageInfo pi, AppRestrictionsHelper.SelectableAppInfo app) {
|
||||||
// Check for 3 cases:
|
// Check for 3 cases:
|
||||||
// - Slave entry that can see primary user accounts
|
// - Slave entry that can see primary user accounts
|
||||||
// - Slave entry that cannot see primary user accounts
|
// - Slave entry that cannot see primary user accounts
|
||||||
@@ -730,7 +446,7 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
return pi.requiredAccountType != null && pi.restrictedAccountType == null;
|
return pi.requiredAccountType != null && pi.restrictedAccountType == null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addLocationAppRestrictionsPreference(SelectableAppInfo app,
|
private void addLocationAppRestrictionsPreference(AppRestrictionsHelper.SelectableAppInfo app,
|
||||||
AppRestrictionsPreference p) {
|
AppRestrictionsPreference p) {
|
||||||
String packageName = app.packageName;
|
String packageName = app.packageName;
|
||||||
p.setIcon(R.drawable.ic_settings_location);
|
p.setIcon(R.drawable.ic_settings_location);
|
||||||
@@ -752,16 +468,6 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
return PKG_PREFIX + packageName;
|
return PKG_PREFIX + packageName;
|
||||||
}
|
}
|
||||||
|
|
||||||
private class AppLabelComparator implements Comparator<SelectableAppInfo> {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int compare(SelectableAppInfo lhs, SelectableAppInfo rhs) {
|
|
||||||
String lhsLabel = lhs.activityName.toString();
|
|
||||||
String rhsLabel = rhs.activityName.toString();
|
|
||||||
return lhsLabel.toLowerCase().compareTo(rhsLabel.toLowerCase());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean resolveInfoListHasPackage(List<ResolveInfo> receivers, String packageName) {
|
private boolean resolveInfoListHasPackage(List<ResolveInfo> receivers, String packageName) {
|
||||||
for (ResolveInfo info : receivers) {
|
for (ResolveInfo info : receivers) {
|
||||||
if (info.activityInfo.packageName.equals(packageName)) {
|
if (info.activityInfo.packageName.equals(packageName)) {
|
||||||
@@ -797,7 +503,7 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
RestrictionUtils.setRestrictions(getActivity(), pref.restrictions, mUser);
|
RestrictionUtils.setRestrictions(getActivity(), pref.restrictions, mUser);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
mSelectedPackages.put(packageName, pref.isChecked());
|
mHelper.setPackageSelected(packageName, pref.isChecked());
|
||||||
if (pref.isChecked() && pref.hasSettings
|
if (pref.isChecked() && pref.hasSettings
|
||||||
&& pref.restrictions == null) {
|
&& pref.restrictions == null) {
|
||||||
// The restrictions have not been initialized, get and save them
|
// The restrictions have not been initialized, get and save them
|
||||||
@@ -806,7 +512,7 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
mAppListChanged = true;
|
mAppListChanged = true;
|
||||||
// If it's not a restricted profile, apply the changes immediately
|
// If it's not a restricted profile, apply the changes immediately
|
||||||
if (!mRestrictedProfile) {
|
if (!mRestrictedProfile) {
|
||||||
applyUserAppState(packageName, pref.isChecked());
|
mHelper.applyUserAppState(packageName, pref.isChecked(), this);
|
||||||
}
|
}
|
||||||
updateAllEntries(pref.getKey(), pref.isChecked());
|
updateAllEntries(pref.getKey(), pref.isChecked());
|
||||||
}
|
}
|
||||||
@@ -917,9 +623,9 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
Bundle results = getResultExtras(true);
|
Bundle results = getResultExtras(true);
|
||||||
final ArrayList<RestrictionEntry> restrictions = results.getParcelableArrayList(
|
final ArrayList<RestrictionEntry> restrictions = results.getParcelableArrayList(
|
||||||
Intent.EXTRA_RESTRICTIONS_LIST);
|
Intent.EXTRA_RESTRICTIONS_LIST);
|
||||||
Intent restrictionsIntent = (Intent) results.getParcelable(CUSTOM_RESTRICTIONS_INTENT);
|
Intent restrictionsIntent = results.getParcelable(CUSTOM_RESTRICTIONS_INTENT);
|
||||||
if (restrictions != null && restrictionsIntent == null) {
|
if (restrictions != null && restrictionsIntent == null) {
|
||||||
onRestrictionsReceived(preference, packageName, restrictions);
|
onRestrictionsReceived(preference, restrictions);
|
||||||
if (mRestrictedProfile) {
|
if (mRestrictedProfile) {
|
||||||
mUserManager.setApplicationRestrictions(packageName,
|
mUserManager.setApplicationRestrictions(packageName,
|
||||||
RestrictionsManager.convertRestrictionsToBundle(restrictions), mUser);
|
RestrictionsManager.convertRestrictionsToBundle(restrictions), mUser);
|
||||||
@@ -952,16 +658,15 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
if (!packageName.equals(activityInfo.packageName)) {
|
if (!packageName.equals(activityInfo.packageName)) {
|
||||||
throw new SecurityException("Application " + packageName
|
throw new SecurityException("Application " + packageName
|
||||||
+ " is not allowed to start activity " + intent);
|
+ " is not allowed to start activity " + intent);
|
||||||
};
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onRestrictionsReceived(AppRestrictionsPreference preference, String packageName,
|
private void onRestrictionsReceived(AppRestrictionsPreference preference,
|
||||||
ArrayList<RestrictionEntry> restrictions) {
|
ArrayList<RestrictionEntry> restrictions) {
|
||||||
// Remove any earlier restrictions
|
// Remove any earlier restrictions
|
||||||
removeRestrictionsForApp(preference);
|
removeRestrictionsForApp(preference);
|
||||||
// Non-custom-activity case - expand the restrictions in-place
|
// Non-custom-activity case - expand the restrictions in-place
|
||||||
final Context context = preference.getContext();
|
|
||||||
int count = 1;
|
int count = 1;
|
||||||
for (RestrictionEntry entry : restrictions) {
|
for (RestrictionEntry entry : restrictions) {
|
||||||
Preference p = null;
|
Preference p = null;
|
||||||
@@ -992,7 +697,7 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
p.setTitle(entry.getTitle());
|
p.setTitle(entry.getTitle());
|
||||||
((MultiSelectListPreference)p).setEntryValues(entry.getChoiceValues());
|
((MultiSelectListPreference)p).setEntryValues(entry.getChoiceValues());
|
||||||
((MultiSelectListPreference)p).setEntries(entry.getChoiceEntries());
|
((MultiSelectListPreference)p).setEntries(entry.getChoiceEntries());
|
||||||
HashSet<String> set = new HashSet<String>();
|
HashSet<String> set = new HashSet<>();
|
||||||
Collections.addAll(set, entry.getAllSelectedStrings());
|
Collections.addAll(set, entry.getAllSelectedStrings());
|
||||||
((MultiSelectListPreference)p).setValues(set);
|
((MultiSelectListPreference)p).setValues(set);
|
||||||
((MultiSelectListPreference)p).setDialogTitle(entry.getTitle());
|
((MultiSelectListPreference)p).setDialogTitle(entry.getTitle());
|
||||||
@@ -1025,8 +730,6 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
/**
|
/**
|
||||||
* Generates a request code that is stored in a map to retrieve the associated
|
* Generates a request code that is stored in a map to retrieve the associated
|
||||||
* AppRestrictionsPreference.
|
* AppRestrictionsPreference.
|
||||||
* @param preference
|
|
||||||
* @return
|
|
||||||
*/
|
*/
|
||||||
private int generateCustomActivityRequestCode(AppRestrictionsPreference preference) {
|
private int generateCustomActivityRequestCode(AppRestrictionsPreference preference) {
|
||||||
mCustomRequestCode++;
|
mCustomRequestCode++;
|
||||||
@@ -1081,10 +784,10 @@ public class AppRestrictionsFragment extends SettingsPreferenceFragment implemen
|
|||||||
final String packageName = arp.getKey().substring(PKG_PREFIX.length());
|
final String packageName = arp.getKey().substring(PKG_PREFIX.length());
|
||||||
final boolean newEnabledState = !arp.isChecked();
|
final boolean newEnabledState = !arp.isChecked();
|
||||||
arp.setChecked(newEnabledState);
|
arp.setChecked(newEnabledState);
|
||||||
mSelectedPackages.put(packageName, newEnabledState);
|
mHelper.setPackageSelected(packageName, newEnabledState);
|
||||||
updateAllEntries(arp.getKey(), newEnabledState);
|
updateAllEntries(arp.getKey(), newEnabledState);
|
||||||
mAppListChanged = true;
|
mAppListChanged = true;
|
||||||
applyUserAppState(packageName, newEnabledState);
|
mHelper.applyUserAppState(packageName, newEnabledState, this);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user