mirror of
https://github.com/gedoor/legado.git
synced 2025-08-10 00:52:30 +00:00
优化
This commit is contained in:
@@ -18,6 +18,8 @@ import io.legado.app.utils.*
|
||||
import io.legado.app.utils.compress.ZipUtils
|
||||
import kotlinx.coroutines.Dispatchers.IO
|
||||
import kotlinx.coroutines.ensureActive
|
||||
import kotlinx.coroutines.sync.Mutex
|
||||
import kotlinx.coroutines.sync.withLock
|
||||
import kotlinx.coroutines.withContext
|
||||
import splitties.init.appCtx
|
||||
import java.io.File
|
||||
@@ -38,6 +40,8 @@ object Backup {
|
||||
}
|
||||
val zipFilePath = "${appCtx.externalFiles.absolutePath}${File.separator}tmp_backup.zip"
|
||||
|
||||
private val mutex = Mutex()
|
||||
|
||||
private val backupFileNames by lazy {
|
||||
arrayOf(
|
||||
"bookshelf.json",
|
||||
@@ -74,15 +78,23 @@ object Backup {
|
||||
}
|
||||
}
|
||||
|
||||
fun autoBack(context: Context) {
|
||||
private fun shouldBackup(): Boolean {
|
||||
val lastBackup = LocalConfig.lastBackup
|
||||
if (lastBackup + TimeUnit.DAYS.toMillis(1) < System.currentTimeMillis()) {
|
||||
return lastBackup + TimeUnit.DAYS.toMillis(1) < System.currentTimeMillis()
|
||||
}
|
||||
|
||||
fun autoBack(context: Context) {
|
||||
if (shouldBackup()) {
|
||||
Coroutine.async {
|
||||
val backupZipFileName = getNowZipFileName()
|
||||
if (!AppWebDav.hasBackUp(backupZipFileName)) {
|
||||
backup(context, context.getPrefString(PreferKey.backupPath))
|
||||
} else {
|
||||
LocalConfig.lastBackup = System.currentTimeMillis()
|
||||
mutex.withLock {
|
||||
if (shouldBackup()) {
|
||||
val backupZipFileName = getNowZipFileName()
|
||||
if (!AppWebDav.hasBackUp(backupZipFileName)) {
|
||||
backup(context, AppConfig.backupPath)
|
||||
} else {
|
||||
LocalConfig.lastBackup = System.currentTimeMillis()
|
||||
}
|
||||
}
|
||||
}
|
||||
}.onError {
|
||||
AppLog.put("自动备份失败\n${it.localizedMessage}")
|
||||
|
||||
Reference in New Issue
Block a user