mirror of
https://github.com/tachiyomiorg/tachiyomi.git
synced 2025-01-11 15:19:09 +01:00
Filter out extensions that have already been updated via other means from update service
This commit is contained in:
parent
3e3e6ee19f
commit
5da21660a3
@ -5,10 +5,13 @@ import android.content.Context
|
|||||||
import android.content.Intent
|
import android.content.Intent
|
||||||
import android.os.IBinder
|
import android.os.IBinder
|
||||||
import android.os.PowerManager
|
import android.os.PowerManager
|
||||||
|
import eu.kanade.tachiyomi.R
|
||||||
import eu.kanade.tachiyomi.data.notification.Notifications
|
import eu.kanade.tachiyomi.data.notification.Notifications
|
||||||
|
import eu.kanade.tachiyomi.data.preference.PreferencesHelper
|
||||||
import eu.kanade.tachiyomi.extension.ExtensionManager.ExtensionInfo
|
import eu.kanade.tachiyomi.extension.ExtensionManager.ExtensionInfo
|
||||||
import eu.kanade.tachiyomi.extension.model.Extension
|
import eu.kanade.tachiyomi.extension.model.Extension
|
||||||
import eu.kanade.tachiyomi.util.system.notificationManager
|
import eu.kanade.tachiyomi.util.system.notificationManager
|
||||||
|
import eu.kanade.tachiyomi.util.system.toast
|
||||||
import kotlinx.coroutines.CoroutineScope
|
import kotlinx.coroutines.CoroutineScope
|
||||||
import kotlinx.coroutines.Dispatchers
|
import kotlinx.coroutines.Dispatchers
|
||||||
import kotlinx.coroutines.Job
|
import kotlinx.coroutines.Job
|
||||||
@ -41,6 +44,8 @@ class ExtensionInstallService(
|
|||||||
|
|
||||||
private val requestSemaphore = Semaphore(3)
|
private val requestSemaphore = Semaphore(3)
|
||||||
|
|
||||||
|
private val preferences: PreferencesHelper = Injekt.get()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method needs to be implemented, but it's not used/needed.
|
* This method needs to be implemented, but it's not used/needed.
|
||||||
*/
|
*/
|
||||||
@ -58,10 +63,20 @@ class ExtensionInstallService(
|
|||||||
*/
|
*/
|
||||||
override fun onStartCommand(intent: Intent?, flags: Int, startId: Int): Int {
|
override fun onStartCommand(intent: Intent?, flags: Int, startId: Int): Int {
|
||||||
if (intent == null) return START_NOT_STICKY
|
if (intent == null) return START_NOT_STICKY
|
||||||
|
if (!preferences.hasPromptedBeforeUpdateAll().get()) {
|
||||||
|
toast(R.string.some_extensions_may_prompt)
|
||||||
|
preferences.hasPromptedBeforeUpdateAll().set(true)
|
||||||
|
}
|
||||||
|
|
||||||
instance = this
|
instance = this
|
||||||
|
|
||||||
val list = intent.getParcelableArrayListExtra<ExtensionInfo>(KEY_EXTENSION)
|
val list = intent.getParcelableArrayListExtra<ExtensionInfo>(KEY_EXTENSION)?.filter {
|
||||||
|
(
|
||||||
|
extensionManager.installedExtensions.find { installed ->
|
||||||
|
installed.pkgName == it.pkgName
|
||||||
|
}?.versionCode ?: 0
|
||||||
|
) < it.versionCode
|
||||||
|
}
|
||||||
?: return START_NOT_STICKY
|
?: return START_NOT_STICKY
|
||||||
var installed = 0
|
var installed = 0
|
||||||
job = serviceScope.launch {
|
job = serviceScope.launch {
|
||||||
|
@ -411,11 +411,13 @@ class ExtensionManager(
|
|||||||
val apkName: String,
|
val apkName: String,
|
||||||
val pkgName: String,
|
val pkgName: String,
|
||||||
val name: String,
|
val name: String,
|
||||||
|
val versionCode: Int,
|
||||||
) : Parcelable {
|
) : Parcelable {
|
||||||
constructor(extension: Extension.Available) : this(
|
constructor(extension: Extension.Available) : this(
|
||||||
apkName = extension.apkName,
|
apkName = extension.apkName,
|
||||||
pkgName = extension.pkgName,
|
pkgName = extension.pkgName,
|
||||||
name = extension.name
|
name = extension.name,
|
||||||
|
versionCode = extension.versionCode
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user