mirror of
https://github.com/null2264/yokai.git
synced 2025-06-21 10:44:42 +00:00
add extension info to crashlog (#1635)
* add extension info to crashlog * do requested changes
This commit is contained in:
parent
5044a75562
commit
5b8e9bcd7c
1 changed files with 47 additions and 10 deletions
|
@ -7,11 +7,17 @@ import eu.kanade.tachiyomi.BuildConfig
|
||||||
import eu.kanade.tachiyomi.R
|
import eu.kanade.tachiyomi.R
|
||||||
import eu.kanade.tachiyomi.data.notification.NotificationReceiver
|
import eu.kanade.tachiyomi.data.notification.NotificationReceiver
|
||||||
import eu.kanade.tachiyomi.data.notification.Notifications
|
import eu.kanade.tachiyomi.data.notification.Notifications
|
||||||
|
import eu.kanade.tachiyomi.extension.ExtensionManager
|
||||||
import eu.kanade.tachiyomi.util.storage.getUriCompat
|
import eu.kanade.tachiyomi.util.storage.getUriCompat
|
||||||
import eu.kanade.tachiyomi.util.system.createFileInCacheDir
|
import eu.kanade.tachiyomi.util.system.createFileInCacheDir
|
||||||
import eu.kanade.tachiyomi.util.system.notificationBuilder
|
import eu.kanade.tachiyomi.util.system.notificationBuilder
|
||||||
import eu.kanade.tachiyomi.util.system.notificationManager
|
import eu.kanade.tachiyomi.util.system.notificationManager
|
||||||
import eu.kanade.tachiyomi.util.system.toast
|
import eu.kanade.tachiyomi.util.system.toast
|
||||||
|
import kotlinx.coroutines.CoroutineScope
|
||||||
|
import kotlinx.coroutines.Dispatchers
|
||||||
|
import kotlinx.coroutines.launch
|
||||||
|
import uy.kohesive.injekt.Injekt
|
||||||
|
import uy.kohesive.injekt.api.get
|
||||||
import java.io.IOException
|
import java.io.IOException
|
||||||
|
|
||||||
class CrashLogUtil(private val context: Context) {
|
class CrashLogUtil(private val context: Context) {
|
||||||
|
@ -20,17 +26,20 @@ class CrashLogUtil(private val context: Context) {
|
||||||
setSmallIcon(R.drawable.ic_tachij2k_notification)
|
setSmallIcon(R.drawable.ic_tachij2k_notification)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
val scope = CoroutineScope(Dispatchers.IO)
|
||||||
fun dumpLogs() {
|
fun dumpLogs() {
|
||||||
|
scope.launch {
|
||||||
try {
|
try {
|
||||||
val file = context.createFileInCacheDir("tachiyomi_crash_logs.txt")
|
val file = context.createFileInCacheDir("tachiyomi_crash_logs.txt")
|
||||||
file.appendText(getDebugInfo() + "\n\n")
|
file.appendText(getDebugInfo() + "\n\n")
|
||||||
|
file.appendText(getExtensionsInfo() + "\n\n")
|
||||||
Runtime.getRuntime().exec("logcat *:E -d -f ${file.absolutePath}")
|
Runtime.getRuntime().exec("logcat *:E -d -f ${file.absolutePath}")
|
||||||
|
|
||||||
showNotification(file.getUriCompat(context))
|
showNotification(file.getUriCompat(context))
|
||||||
} catch (e: IOException) {
|
} catch (e: IOException) {
|
||||||
context.toast("Failed to get logs")
|
context.toast("Failed to get logs")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
fun getDebugInfo(): String {
|
fun getDebugInfo(): String {
|
||||||
return """
|
return """
|
||||||
App version: ${BuildConfig.VERSION_NAME} (${BuildConfig.FLAVOR}, ${BuildConfig.COMMIT_SHA}, ${BuildConfig.VERSION_CODE}, ${BuildConfig.BUILD_TIME})
|
App version: ${BuildConfig.VERSION_NAME} (${BuildConfig.FLAVOR}, ${BuildConfig.COMMIT_SHA}, ${BuildConfig.VERSION_CODE}, ${BuildConfig.BUILD_TIME})
|
||||||
|
@ -43,9 +52,37 @@ class CrashLogUtil(private val context: Context) {
|
||||||
Device product name: ${Build.PRODUCT}
|
Device product name: ${Build.PRODUCT}
|
||||||
""".trimIndent()
|
""".trimIndent()
|
||||||
}
|
}
|
||||||
private fun showNotification(uri: Uri) {
|
|
||||||
context.notificationManager.cancel(Notifications.ID_CRASH_LOGS)
|
|
||||||
|
|
||||||
|
suspend fun getExtensionsInfo(): String {
|
||||||
|
val extensionManager: ExtensionManager = Injekt.get()
|
||||||
|
extensionManager.findAvailableExtensions()
|
||||||
|
val installedExtensions = extensionManager.installedExtensionsFlow.value
|
||||||
|
val availableExtensions = extensionManager.availableExtensionsFlow.value
|
||||||
|
|
||||||
|
val extensionInfoList = mutableListOf<String>()
|
||||||
|
|
||||||
|
for (installedExtension in installedExtensions) {
|
||||||
|
val availableExtension = availableExtensions.find { it.pkgName == installedExtension.pkgName }
|
||||||
|
|
||||||
|
val hasUpdate = availableExtension?.versionCode ?: 0 > installedExtension.versionCode
|
||||||
|
if (hasUpdate || installedExtension.isObsolete) {
|
||||||
|
val extensionInfo =
|
||||||
|
"Extension Name: ${installedExtension.name}\n" +
|
||||||
|
"Installed Version: ${installedExtension.versionName}\n" +
|
||||||
|
"Available Version: ${availableExtension?.versionName ?: "N/A"}\n" +
|
||||||
|
"Obsolete: ${installedExtension.isObsolete}\n"
|
||||||
|
extensionInfoList.add(extensionInfo)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (extensionInfoList.isNotEmpty()) {
|
||||||
|
extensionInfoList.add(0, "Extensions that are outdated or obsolete")
|
||||||
|
}
|
||||||
|
return extensionInfoList.joinToString("\n")
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun showNotification(uri: Uri) {
|
||||||
|
ExtensionManager(context)
|
||||||
|
context.notificationManager.cancel(Notifications.ID_CRASH_LOGS)
|
||||||
with(notificationBuilder) {
|
with(notificationBuilder) {
|
||||||
setContentTitle(context.getString(R.string.crash_log_saved))
|
setContentTitle(context.getString(R.string.crash_log_saved))
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue