mirror of
https://github.com/aniyomiorg/aniyomi.git
synced 2025-01-08 21:47:45 +03:00
135 lines
5.6 KiB
Kotlin
135 lines
5.6 KiB
Kotlin
package eu.kanade.tachiyomi
|
|
|
|
import androidx.core.content.edit
|
|
import androidx.preference.PreferenceManager
|
|
import eu.kanade.tachiyomi.data.backup.BackupCreatorJob
|
|
import eu.kanade.tachiyomi.data.library.LibraryUpdateJob
|
|
import eu.kanade.tachiyomi.data.preference.PreferenceKeys
|
|
import eu.kanade.tachiyomi.data.preference.PreferencesHelper
|
|
import eu.kanade.tachiyomi.data.track.TrackManager
|
|
import eu.kanade.tachiyomi.data.updater.UpdaterJob
|
|
import eu.kanade.tachiyomi.extension.ExtensionUpdateJob
|
|
import eu.kanade.tachiyomi.ui.library.LibrarySort
|
|
import eu.kanade.tachiyomi.util.system.toast
|
|
import eu.kanade.tachiyomi.widget.ExtendedNavigationView
|
|
import uy.kohesive.injekt.Injekt
|
|
import uy.kohesive.injekt.api.get
|
|
import java.io.File
|
|
|
|
object Migrations {
|
|
|
|
/**
|
|
* Performs a migration when the application is updated.
|
|
*
|
|
* @param preferences Preferences of the application.
|
|
* @return true if a migration is performed, false otherwise.
|
|
*/
|
|
fun upgrade(preferences: PreferencesHelper): Boolean {
|
|
val context = preferences.context
|
|
|
|
// Cancel app updater job for debug builds that don't include it
|
|
if (BuildConfig.DEBUG && !BuildConfig.INCLUDE_UPDATER) {
|
|
UpdaterJob.cancelTask(context)
|
|
}
|
|
|
|
val oldVersion = preferences.lastVersionCode().get()
|
|
if (oldVersion < BuildConfig.VERSION_CODE) {
|
|
preferences.lastVersionCode().set(BuildConfig.VERSION_CODE)
|
|
|
|
// Fresh install
|
|
if (oldVersion == 0) {
|
|
// Set up default background tasks
|
|
if (BuildConfig.INCLUDE_UPDATER) {
|
|
UpdaterJob.setupTask(context)
|
|
}
|
|
ExtensionUpdateJob.setupTask(context)
|
|
LibraryUpdateJob.setupTask(context)
|
|
return false
|
|
}
|
|
|
|
if (oldVersion < 14) {
|
|
// Restore jobs after upgrading to Evernote's job scheduler.
|
|
if (BuildConfig.INCLUDE_UPDATER) {
|
|
UpdaterJob.setupTask(context)
|
|
}
|
|
LibraryUpdateJob.setupTask(context)
|
|
}
|
|
if (oldVersion < 15) {
|
|
// Delete internal chapter cache dir.
|
|
File(context.cacheDir, "chapter_disk_cache").deleteRecursively()
|
|
}
|
|
if (oldVersion < 19) {
|
|
// Move covers to external files dir.
|
|
val oldDir = File(context.externalCacheDir, "cover_disk_cache")
|
|
if (oldDir.exists()) {
|
|
val destDir = context.getExternalFilesDir("covers")
|
|
if (destDir != null) {
|
|
oldDir.listFiles()?.forEach {
|
|
it.renameTo(File(destDir, it.name))
|
|
}
|
|
}
|
|
}
|
|
}
|
|
if (oldVersion < 26) {
|
|
// Delete external chapter cache dir.
|
|
val extCache = context.externalCacheDir
|
|
if (extCache != null) {
|
|
val chapterCache = File(extCache, "chapter_disk_cache")
|
|
if (chapterCache.exists()) {
|
|
chapterCache.deleteRecursively()
|
|
}
|
|
}
|
|
}
|
|
if (oldVersion < 43) {
|
|
// Restore jobs after migrating from Evernote's job scheduler to WorkManager.
|
|
if (BuildConfig.INCLUDE_UPDATER) {
|
|
UpdaterJob.setupTask(context)
|
|
}
|
|
LibraryUpdateJob.setupTask(context)
|
|
BackupCreatorJob.setupTask(context)
|
|
|
|
// New extension update check job
|
|
ExtensionUpdateJob.setupTask(context)
|
|
}
|
|
if (oldVersion < 44) {
|
|
// Reset sorting preference if using removed sort by source
|
|
@Suppress("DEPRECATION")
|
|
if (preferences.librarySortingMode().get() == LibrarySort.SOURCE) {
|
|
preferences.librarySortingMode().set(LibrarySort.ALPHA)
|
|
}
|
|
}
|
|
if (oldVersion < 52) {
|
|
// Migrate library filters to tri-state versions
|
|
val prefs = PreferenceManager.getDefaultSharedPreferences(context)
|
|
fun convertBooleanPrefToTriState(key: String): Int {
|
|
val oldPrefValue = prefs.getBoolean(key, false)
|
|
return if (oldPrefValue) ExtendedNavigationView.Item.TriStateGroup.State.INCLUDE.value
|
|
else ExtendedNavigationView.Item.TriStateGroup.State.IGNORE.value
|
|
}
|
|
prefs.edit {
|
|
putInt(PreferenceKeys.filterDownloaded, convertBooleanPrefToTriState("pref_filter_downloaded_key"))
|
|
remove("pref_filter_downloaded_key")
|
|
|
|
putInt(PreferenceKeys.filterUnread, convertBooleanPrefToTriState("pref_filter_unread_key"))
|
|
remove("pref_filter_unread_key")
|
|
|
|
putInt(PreferenceKeys.filterCompleted, convertBooleanPrefToTriState("pref_filter_completed_key"))
|
|
remove("pref_filter_completed_key")
|
|
}
|
|
}
|
|
if (oldVersion < 54) {
|
|
// Force MAL log out due to login flow change
|
|
// v52: switched from scraping to WebView
|
|
// v53: switched from WebView to OAuth
|
|
val trackManager = Injekt.get<TrackManager>()
|
|
if (trackManager.myAnimeList.isLogged) {
|
|
trackManager.myAnimeList.logout()
|
|
context.toast(R.string.myanimelist_relogin)
|
|
}
|
|
}
|
|
return true
|
|
}
|
|
|
|
return false
|
|
}
|
|
}
|