diff --git a/manager/src/main/AndroidManifest.xml b/manager/src/main/AndroidManifest.xml index a95bf0b7..0032835c 100644 --- a/manager/src/main/AndroidManifest.xml +++ b/manager/src/main/AndroidManifest.xml @@ -7,6 +7,7 @@ tools:ignore="QueryAllPackagesPermission" /> + diff --git a/manager/src/main/java/org/lsposed/lspatch/manager/ModuleService.kt b/manager/src/main/java/org/lsposed/lspatch/manager/ModuleService.kt index c6ceae4c..a695075f 100644 --- a/manager/src/main/java/org/lsposed/lspatch/manager/ModuleService.kt +++ b/manager/src/main/java/org/lsposed/lspatch/manager/ModuleService.kt @@ -4,6 +4,8 @@ import android.app.NotificationChannel import android.app.NotificationManager import android.app.Service import android.content.Intent +import android.content.pm.ServiceInfo +import android.os.Build import android.os.IBinder import android.util.Log import androidx.core.app.NotificationCompat @@ -23,7 +25,19 @@ class ModuleService : Service() { val channel = NotificationChannel(Constants.MANAGER_PACKAGE_NAME, TAG, NotificationManager.IMPORTANCE_DEFAULT) val manager = getSystemService(NOTIFICATION_SERVICE) as NotificationManager manager.createNotificationChannel(channel) - startForeground(1, NotificationCompat.Builder(this, Constants.MANAGER_PACKAGE_NAME).build()) + // TODO: https://developer.android.com/guide/components/bound-services + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.UPSIDE_DOWN_CAKE) { + startForeground( + 1, + NotificationCompat.Builder(this, Constants.MANAGER_PACKAGE_NAME).build(), + ServiceInfo.FOREGROUND_SERVICE_TYPE_SPECIAL_USE + ) + } else { + startForeground( + 1, + NotificationCompat.Builder(this, Constants.MANAGER_PACKAGE_NAME).build() + ) + } } else { stopForeground(STOP_FOREGROUND_REMOVE) }