Fix settings crash when disabling listener.

Bug: 32092445
Test: manual
Change-Id: Iaa26e755381ba202cccf6d518dacb86eae4c6d10
This commit is contained in:
Julia Reynolds
2016-09-21 09:36:02 -04:00
parent 36a6cb0370
commit 6e99b3ee4e
2 changed files with 18 additions and 27 deletions

View File

@@ -18,33 +18,30 @@ package com.android.settings.notification;
import android.app.AlertDialog; import android.app.AlertDialog;
import android.app.Dialog; import android.app.Dialog;
import android.app.DialogFragment; import android.app.Fragment;
import android.app.NotificationManager; import android.app.NotificationManager;
import android.content.ComponentName; import android.content.ComponentName;
import android.content.Context; import android.content.Context;
import android.content.DialogInterface; import android.content.DialogInterface;
import android.content.pm.PackageManager;
import android.os.AsyncTask; import android.os.AsyncTask;
import android.os.Bundle; import android.os.Bundle;
import android.provider.Settings; import android.provider.Settings;
import android.service.notification.NotificationListenerService; import android.service.notification.NotificationListenerService;
import android.util.Log;
import com.android.internal.logging.MetricsProto.MetricsEvent; import com.android.internal.logging.MetricsProto.MetricsEvent;
import com.android.settings.R; import com.android.settings.R;
import com.android.settings.core.instrumentation.InstrumentedDialogFragment; import com.android.settings.core.instrumentation.InstrumentedDialogFragment;
import com.android.settings.utils.ManagedServiceSettings; import com.android.settings.utils.ManagedServiceSettings;
import com.android.settings.utils.ServiceListing;
public class NotificationAccessSettings extends ManagedServiceSettings { public class NotificationAccessSettings extends ManagedServiceSettings {
private static final String TAG = NotificationAccessSettings.class.getSimpleName(); private static final String TAG = NotificationAccessSettings.class.getSimpleName();
private static final Config CONFIG = getNotificationListenerConfig(); private static final Config CONFIG = getNotificationListenerConfig();
private NotificationManager mNm;
@Override @Override
public void onCreate(Bundle icicle) { public void onCreate(Bundle icicle) {
super.onCreate(icicle); super.onCreate(icicle);
mNm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
} }
private static Config getNotificationListenerConfig() { private static Config getNotificationListenerConfig() {
@@ -70,14 +67,6 @@ public class NotificationAccessSettings extends ManagedServiceSettings {
return CONFIG; return CONFIG;
} }
public static int getListenersCount(PackageManager pm) {
return ServiceListing.getServicesCount(CONFIG, pm);
}
public static int getEnabledListenersCount(Context context) {
return ServiceListing.getEnabledServicesCount(CONFIG, context);
}
protected boolean setEnabled(ComponentName service, String title, boolean enable) { protected boolean setEnabled(ComponentName service, String title, boolean enable) {
if (!enable) { if (!enable) {
if (!mServiceListing.isEnabled(service)) { if (!mServiceListing.isEnabled(service)) {
@@ -85,7 +74,7 @@ public class NotificationAccessSettings extends ManagedServiceSettings {
} }
// show a friendly dialog // show a friendly dialog
new FriendlyWarningDialogFragment() new FriendlyWarningDialogFragment()
.setServiceInfo(service, title) .setServiceInfo(service, title, this)
.show(getFragmentManager(), "friendlydialog"); .show(getFragmentManager(), "friendlydialog");
return false; return false;
} else { } else {
@@ -93,25 +82,33 @@ public class NotificationAccessSettings extends ManagedServiceSettings {
} }
} }
private static void deleteRules(final Context context, final String pkg) { private static void disable(final Context context, final NotificationAccessSettings parent,
final ComponentName cn) {
parent.mServiceListing.setEnabled(cn, false);
AsyncTask.execute(new Runnable() { AsyncTask.execute(new Runnable() {
@Override @Override
public void run() { public void run() {
final NotificationManager mgr = context.getSystemService(NotificationManager.class); final NotificationManager mgr = context.getSystemService(NotificationManager.class);
mgr.removeAutomaticZenRules(pkg);
if (!mgr.isNotificationPolicyAccessGrantedForPackage(
cn.getPackageName())) {
mgr.removeAutomaticZenRules(cn.getPackageName());
}
} }
}); });
} }
public class FriendlyWarningDialogFragment extends InstrumentedDialogFragment { public static class FriendlyWarningDialogFragment extends InstrumentedDialogFragment {
static final String KEY_COMPONENT = "c"; static final String KEY_COMPONENT = "c";
static final String KEY_LABEL = "l"; static final String KEY_LABEL = "l";
public FriendlyWarningDialogFragment setServiceInfo(ComponentName cn, String label) { public FriendlyWarningDialogFragment setServiceInfo(ComponentName cn, String label,
Fragment target) {
Bundle args = new Bundle(); Bundle args = new Bundle();
args.putString(KEY_COMPONENT, cn.flattenToString()); args.putString(KEY_COMPONENT, cn.flattenToString());
args.putString(KEY_LABEL, label); args.putString(KEY_LABEL, label);
setArguments(args); setArguments(args);
setTargetFragment(target, 0);
return this; return this;
} }
@@ -122,25 +119,21 @@ public class NotificationAccessSettings extends ManagedServiceSettings {
@Override @Override
public Dialog onCreateDialog(Bundle savedInstanceState) { public Dialog onCreateDialog(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
final Bundle args = getArguments(); final Bundle args = getArguments();
final String label = args.getString(KEY_LABEL); final String label = args.getString(KEY_LABEL);
final ComponentName cn = ComponentName.unflattenFromString(args final ComponentName cn = ComponentName.unflattenFromString(args
.getString(KEY_COMPONENT)); .getString(KEY_COMPONENT));
NotificationAccessSettings parent = (NotificationAccessSettings) getTargetFragment();
final String summary = getResources().getString( final String summary = getResources().getString(
R.string.notification_listener_disable_warning_summary, label); R.string.notification_listener_disable_warning_summary, label);
return new AlertDialog.Builder(mContext) return new AlertDialog.Builder(getContext())
.setMessage(summary) .setMessage(summary)
.setCancelable(true) .setCancelable(true)
.setPositiveButton(R.string.notification_listener_disable_warning_confirm, .setPositiveButton(R.string.notification_listener_disable_warning_confirm,
new DialogInterface.OnClickListener() { new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int id) { public void onClick(DialogInterface dialog, int id) {
mServiceListing.setEnabled(cn, false); disable(getContext(), parent, cn);
if (!mNm.isNotificationPolicyAccessGrantedForPackage(
cn.getPackageName())) {
deleteRules(mContext, cn.getPackageName());
}
} }
}) })
.setNegativeButton(R.string.notification_listener_disable_warning_cancel, .setNegativeButton(R.string.notification_listener_disable_warning_cancel,

View File

@@ -49,7 +49,6 @@ public abstract class ManagedServiceSettings extends EmptyTextSettings {
protected Context mContext; protected Context mContext;
private PackageManager mPM; private PackageManager mPM;
protected ServiceListing mServiceListing; protected ServiceListing mServiceListing;
private TextView mEmpty;
abstract protected Config getConfig(); abstract protected Config getConfig();
@@ -153,7 +152,6 @@ public abstract class ManagedServiceSettings extends EmptyTextSettings {
@Override @Override
public Dialog onCreateDialog(Bundle savedInstanceState) { public Dialog onCreateDialog(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
final Bundle args = getArguments(); final Bundle args = getArguments();
final String label = args.getString(KEY_LABEL); final String label = args.getString(KEY_LABEL);
final ComponentName cn = ComponentName.unflattenFromString(args final ComponentName cn = ComponentName.unflattenFromString(args