Fix foreground Service background launch restriction
Remove setForeground() in BluetoothPairingService. Refactor the behavior to not holding service in the background. Bug: 184901840 Test: make RunSettingsRoboTests -j56 Change-Id: Iaeb96943971f55dbeb3dba4b06b28abe770ba3c2
This commit is contained in:
@@ -31,6 +31,9 @@ import android.os.IBinder;
|
||||
import android.text.TextUtils;
|
||||
import android.util.Log;
|
||||
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
import androidx.core.app.NotificationCompat;
|
||||
|
||||
import com.android.settings.R;
|
||||
|
||||
/**
|
||||
@@ -39,10 +42,14 @@ import com.android.settings.R;
|
||||
*/
|
||||
public final class BluetoothPairingService extends Service {
|
||||
|
||||
private static final int NOTIFICATION_ID = android.R.drawable.stat_sys_data_bluetooth;
|
||||
|
||||
private static final String ACTION_DISMISS_PAIRING =
|
||||
@VisibleForTesting
|
||||
static final int NOTIFICATION_ID = android.R.drawable.stat_sys_data_bluetooth;
|
||||
@VisibleForTesting
|
||||
static final String ACTION_DISMISS_PAIRING =
|
||||
"com.android.settings.bluetooth.ACTION_DISMISS_PAIRING";
|
||||
@VisibleForTesting
|
||||
static final String ACTION_PAIRING_DIALOG =
|
||||
"com.android.settings.bluetooth.ACTION_PAIRING_DIALOG";
|
||||
|
||||
private static final String BLUETOOTH_NOTIFICATION_CHANNEL =
|
||||
"bluetooth_notification_channel";
|
||||
@@ -51,6 +58,9 @@ public final class BluetoothPairingService extends Service {
|
||||
|
||||
private BluetoothDevice mDevice;
|
||||
|
||||
@VisibleForTesting
|
||||
NotificationManager mNm;
|
||||
|
||||
public static Intent getPairingDialogIntent(Context context, Intent intent, int initiator) {
|
||||
BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
|
||||
int type = intent.getIntExtra(BluetoothDevice.EXTRA_PAIRING_VARIANT,
|
||||
@@ -80,33 +90,35 @@ public final class BluetoothPairingService extends Service {
|
||||
if (action.equals(BluetoothDevice.ACTION_BOND_STATE_CHANGED)) {
|
||||
int bondState = intent.getIntExtra(BluetoothDevice.EXTRA_BOND_STATE,
|
||||
BluetoothDevice.ERROR);
|
||||
Log.d(TAG, "onReceive() Bond state change : " + bondState + ", device name : "
|
||||
+ mDevice.getName());
|
||||
if ((bondState != BluetoothDevice.BOND_NONE) && (bondState != BluetoothDevice.BOND_BONDED)) {
|
||||
return;
|
||||
}
|
||||
} else if (action.equals(ACTION_DISMISS_PAIRING)) {
|
||||
Log.d(TAG, "Notification cancel " + mDevice.getAddress() + " (" +
|
||||
Log.d(TAG, "Notification cancel " + " (" +
|
||||
mDevice.getName() + ")");
|
||||
mDevice.cancelPairing();
|
||||
} else {
|
||||
int bondState = intent.getIntExtra(BluetoothDevice.EXTRA_BOND_STATE,
|
||||
BluetoothDevice.ERROR);
|
||||
Log.d(TAG, "Dismiss pairing for " + mDevice.getAddress() + " (" +
|
||||
Log.d(TAG, "Dismiss pairing for " + " (" +
|
||||
mDevice.getName() + "), BondState: " + bondState);
|
||||
}
|
||||
stopForeground(true);
|
||||
|
||||
mNm.cancel(NOTIFICATION_ID);
|
||||
stopSelf();
|
||||
}
|
||||
};
|
||||
|
||||
@Override
|
||||
public void onCreate() {
|
||||
NotificationManager mgr = (NotificationManager)this
|
||||
.getSystemService(Context.NOTIFICATION_SERVICE);
|
||||
NotificationChannel notificationChannel = new NotificationChannel(
|
||||
BLUETOOTH_NOTIFICATION_CHANNEL,
|
||||
this.getString(R.string.bluetooth),
|
||||
NotificationManager.IMPORTANCE_HIGH);
|
||||
mgr.createNotificationChannel(notificationChannel);
|
||||
mNm = getSystemService(NotificationManager.class);
|
||||
NotificationChannel notificationChannel = new NotificationChannel(
|
||||
BLUETOOTH_NOTIFICATION_CHANNEL,
|
||||
this.getString(R.string.bluetooth),
|
||||
NotificationManager.IMPORTANCE_HIGH);
|
||||
mNm.createNotificationChannel(notificationChannel);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -116,23 +128,8 @@ public final class BluetoothPairingService extends Service {
|
||||
stopSelf();
|
||||
return START_NOT_STICKY;
|
||||
}
|
||||
|
||||
Resources res = getResources();
|
||||
Notification.Builder builder = new Notification.Builder(this,
|
||||
BLUETOOTH_NOTIFICATION_CHANNEL)
|
||||
.setSmallIcon(android.R.drawable.stat_sys_data_bluetooth)
|
||||
.setTicker(res.getString(R.string.bluetooth_notif_ticker))
|
||||
.setLocalOnly(true);
|
||||
|
||||
PendingIntent pairIntent = PendingIntent.getActivity(this, 0,
|
||||
getPairingDialogIntent(this, intent,
|
||||
BluetoothDevice.EXTRA_PAIRING_INITIATOR_BACKGROUND),
|
||||
PendingIntent.FLAG_ONE_SHOT | PendingIntent.FLAG_UPDATE_CURRENT
|
||||
| PendingIntent.FLAG_IMMUTABLE);
|
||||
|
||||
PendingIntent dismissIntent = PendingIntent.getBroadcast(this, 0,
|
||||
new Intent(ACTION_DISMISS_PAIRING), PendingIntent.FLAG_ONE_SHOT
|
||||
| PendingIntent.FLAG_IMMUTABLE);
|
||||
String action = intent.getAction();
|
||||
Log.d(TAG, "onStartCommand() action : " + action);
|
||||
|
||||
mDevice = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
|
||||
|
||||
@@ -142,36 +139,76 @@ public final class BluetoothPairingService extends Service {
|
||||
return START_NOT_STICKY;
|
||||
}
|
||||
|
||||
if (TextUtils.equals(action, BluetoothDevice.ACTION_PAIRING_REQUEST)) {
|
||||
createPairingNotification(intent);
|
||||
} else if (TextUtils.equals(action, ACTION_DISMISS_PAIRING)) {
|
||||
Log.d(TAG, "Notification cancel " + " (" + mDevice.getName() + ")");
|
||||
mDevice.cancelPairing();
|
||||
mNm.cancel(NOTIFICATION_ID);
|
||||
stopSelf();
|
||||
} else if (TextUtils.equals(action, ACTION_PAIRING_DIALOG)) {
|
||||
Intent pairingDialogIntent = getPairingDialogIntent(this, intent,
|
||||
BluetoothDevice.EXTRA_PAIRING_INITIATOR_BACKGROUND);
|
||||
|
||||
IntentFilter filter = new IntentFilter();
|
||||
filter.addAction(BluetoothDevice.ACTION_BOND_STATE_CHANGED);
|
||||
filter.addAction(BluetoothDevice.ACTION_PAIRING_CANCEL);
|
||||
filter.addAction(ACTION_DISMISS_PAIRING);
|
||||
registerReceiver(mCancelReceiver, filter);
|
||||
mRegistered = true;
|
||||
|
||||
startActivity(pairingDialogIntent);
|
||||
}
|
||||
|
||||
return START_STICKY;
|
||||
}
|
||||
|
||||
private void createPairingNotification(Intent intent) {
|
||||
Resources res = getResources();
|
||||
NotificationCompat.Builder builder = new NotificationCompat.Builder(this,
|
||||
BLUETOOTH_NOTIFICATION_CHANNEL)
|
||||
.setSmallIcon(android.R.drawable.stat_sys_data_bluetooth)
|
||||
.setTicker(res.getString(R.string.bluetooth_notif_ticker))
|
||||
.setLocalOnly(true);
|
||||
|
||||
int type = intent.getIntExtra(BluetoothDevice.EXTRA_PAIRING_VARIANT,
|
||||
BluetoothDevice.ERROR);
|
||||
Intent pairingDialogIntent = new Intent(ACTION_PAIRING_DIALOG);
|
||||
pairingDialogIntent.setClass(this, BluetoothPairingService.class);
|
||||
pairingDialogIntent.putExtra(BluetoothDevice.EXTRA_DEVICE, mDevice);
|
||||
pairingDialogIntent.putExtra(BluetoothDevice.EXTRA_PAIRING_VARIANT, type);
|
||||
PendingIntent pairIntent = PendingIntent.getService(this, 0, pairingDialogIntent,
|
||||
PendingIntent.FLAG_ONE_SHOT | PendingIntent.FLAG_IMMUTABLE);
|
||||
|
||||
Intent serviceIntent = new Intent(ACTION_DISMISS_PAIRING);
|
||||
serviceIntent.setClass(this, BluetoothPairingService.class);
|
||||
serviceIntent.putExtra(BluetoothDevice.EXTRA_DEVICE, mDevice);
|
||||
PendingIntent dismissIntent = PendingIntent.getService(this, 0,
|
||||
serviceIntent, PendingIntent.FLAG_ONE_SHOT | PendingIntent.FLAG_IMMUTABLE);
|
||||
|
||||
String name = intent.getStringExtra(BluetoothDevice.EXTRA_NAME);
|
||||
if (TextUtils.isEmpty(name)) {
|
||||
BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
|
||||
name = device != null ? device.getAlias() : res.getString(android.R.string.unknownName);
|
||||
}
|
||||
|
||||
Log.d(TAG, "Show pairing notification for " + mDevice.getAddress() + " (" + name + ")");
|
||||
Log.d(TAG, "Show pairing notification for " + " (" + name + ")");
|
||||
|
||||
Notification.Action pairAction = new Notification.Action.Builder(0,
|
||||
NotificationCompat.Action pairAction = new NotificationCompat.Action.Builder(0,
|
||||
res.getString(R.string.bluetooth_device_context_pair_connect), pairIntent).build();
|
||||
Notification.Action dismissAction = new Notification.Action.Builder(0,
|
||||
NotificationCompat.Action dismissAction = new NotificationCompat.Action.Builder(0,
|
||||
res.getString(android.R.string.cancel), dismissIntent).build();
|
||||
|
||||
builder.setContentTitle(res.getString(R.string.bluetooth_notif_title))
|
||||
.setContentText(res.getString(R.string.bluetooth_notif_message, name))
|
||||
.setContentIntent(pairIntent)
|
||||
.setDefaults(Notification.DEFAULT_SOUND)
|
||||
.setOngoing(true)
|
||||
.setColor(getColor(com.android.internal.R.color.system_notification_accent_color))
|
||||
.addAction(pairAction)
|
||||
.addAction(dismissAction);
|
||||
|
||||
IntentFilter filter = new IntentFilter();
|
||||
filter.addAction(BluetoothDevice.ACTION_BOND_STATE_CHANGED);
|
||||
filter.addAction(BluetoothDevice.ACTION_PAIRING_CANCEL);
|
||||
filter.addAction(ACTION_DISMISS_PAIRING);
|
||||
registerReceiver(mCancelReceiver, filter);
|
||||
mRegistered = true;
|
||||
|
||||
startForeground(NOTIFICATION_ID, builder.getNotification());
|
||||
return START_REDELIVER_INTENT;
|
||||
mNm.notify(NOTIFICATION_ID, builder.build());
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -180,7 +217,6 @@ public final class BluetoothPairingService extends Service {
|
||||
unregisterReceiver(mCancelReceiver);
|
||||
mRegistered = false;
|
||||
}
|
||||
stopForeground(true);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
Reference in New Issue
Block a user