From 6bf7516d91668ae57930a5eb04838666953c4b8e Mon Sep 17 00:00:00 2001 From: schroda <50052685+schroda@users.noreply.github.com> Date: Fri, 30 Aug 2024 23:13:59 +0200 Subject: [PATCH 1/2] Optionally delete existing downloads of new chapters The downloader checks if pages are already downloaded to prevent unnecessary downloads. However, in case this is e.g. a re-uploaded chapter, this will prevent the new pages from getting downloaded --- .../tachidesk/graphql/mutations/SettingsMutation.kt | 1 + .../kotlin/suwayomi/tachidesk/graphql/types/SettingsType.kt | 4 ++++ .../main/kotlin/suwayomi/tachidesk/manga/impl/Chapter.kt | 6 ++++++ .../main/kotlin/suwayomi/tachidesk/server/ServerConfig.kt | 1 + server/src/main/resources/server-reference.conf | 1 + 5 files changed, 13 insertions(+) diff --git a/server/src/main/kotlin/suwayomi/tachidesk/graphql/mutations/SettingsMutation.kt b/server/src/main/kotlin/suwayomi/tachidesk/graphql/mutations/SettingsMutation.kt index 325f749f7..1479774e0 100644 --- a/server/src/main/kotlin/suwayomi/tachidesk/graphql/mutations/SettingsMutation.kt +++ b/server/src/main/kotlin/suwayomi/tachidesk/graphql/mutations/SettingsMutation.kt @@ -59,6 +59,7 @@ class SettingsMutation { updateSetting(settings.autoDownloadAheadLimit, serverConfig.autoDownloadNewChaptersLimit) // deprecated updateSetting(settings.autoDownloadNewChaptersLimit, serverConfig.autoDownloadNewChaptersLimit) updateSetting(settings.autoDownloadIgnoreReUploads, serverConfig.autoDownloadIgnoreReUploads) + updateSetting(settings.autoDownloadDeleteExistingFiles, serverConfig.autoDownloadDeleteExistingFiles) // extension updateSetting(settings.extensionRepos, serverConfig.extensionRepos) diff --git a/server/src/main/kotlin/suwayomi/tachidesk/graphql/types/SettingsType.kt b/server/src/main/kotlin/suwayomi/tachidesk/graphql/types/SettingsType.kt index 8e0c09781..2a62d07e2 100644 --- a/server/src/main/kotlin/suwayomi/tachidesk/graphql/types/SettingsType.kt +++ b/server/src/main/kotlin/suwayomi/tachidesk/graphql/types/SettingsType.kt @@ -50,6 +50,7 @@ interface Settings : Node { val autoDownloadAheadLimit: Int? val autoDownloadNewChaptersLimit: Int? val autoDownloadIgnoreReUploads: Boolean? + val autoDownloadDeleteExistingFiles: Boolean? // extension val extensionRepos: List? @@ -121,6 +122,7 @@ data class PartialSettingsType( override val autoDownloadAheadLimit: Int?, override val autoDownloadNewChaptersLimit: Int?, override val autoDownloadIgnoreReUploads: Boolean?, + override val autoDownloadDeleteExistingFiles: Boolean?, // extension override val extensionRepos: List?, // requests @@ -184,6 +186,7 @@ class SettingsType( override val autoDownloadAheadLimit: Int, override val autoDownloadNewChaptersLimit: Int, override val autoDownloadIgnoreReUploads: Boolean?, + override val autoDownloadDeleteExistingFiles: Boolean, // extension override val extensionRepos: List, // requests @@ -242,6 +245,7 @@ class SettingsType( config.autoDownloadNewChaptersLimit.value, // deprecated config.autoDownloadNewChaptersLimit.value, config.autoDownloadIgnoreReUploads.value, + config.autoDownloadDeleteExistingFiles.value, // extension config.extensionRepos.value, // requests diff --git a/server/src/main/kotlin/suwayomi/tachidesk/manga/impl/Chapter.kt b/server/src/main/kotlin/suwayomi/tachidesk/manga/impl/Chapter.kt index 43d8d19bd..69165060d 100644 --- a/server/src/main/kotlin/suwayomi/tachidesk/manga/impl/Chapter.kt +++ b/server/src/main/kotlin/suwayomi/tachidesk/manga/impl/Chapter.kt @@ -377,6 +377,12 @@ object Chapter { return } + // The downloader checks if pages are already downloaded to prevent unnecessary downloads. However, in case this + // is e.g. a re-uploaded chapter, this will prevent the new pages from getting downloaded + if (serverConfig.autoDownloadDeleteExistingFiles.value) { + deleteChapters(chapterIdsToDownload) + } + log.info { "download ${chapterIdsToDownload.size} new chapter(s)..." } DownloadManager.enqueue(EnqueueInput(chapterIdsToDownload)) diff --git a/server/src/main/kotlin/suwayomi/tachidesk/server/ServerConfig.kt b/server/src/main/kotlin/suwayomi/tachidesk/server/ServerConfig.kt index 71655d571..782354cfb 100644 --- a/server/src/main/kotlin/suwayomi/tachidesk/server/ServerConfig.kt +++ b/server/src/main/kotlin/suwayomi/tachidesk/server/ServerConfig.kt @@ -102,6 +102,7 @@ class ServerConfig(getConfig: () -> Config, val moduleName: String = SERVER_CONF val excludeEntryWithUnreadChapters: MutableStateFlow by OverrideConfigValue(BooleanConfigAdapter) val autoDownloadNewChaptersLimit: MutableStateFlow by OverrideConfigValue(IntConfigAdapter) val autoDownloadIgnoreReUploads: MutableStateFlow by OverrideConfigValue(BooleanConfigAdapter) + val autoDownloadDeleteExistingFiles: MutableStateFlow by OverrideConfigValue(BooleanConfigAdapter) // extensions val extensionRepos: MutableStateFlow> by OverrideConfigValues(StringConfigAdapter) diff --git a/server/src/main/resources/server-reference.conf b/server/src/main/resources/server-reference.conf index dee08efb4..974f1805e 100644 --- a/server/src/main/resources/server-reference.conf +++ b/server/src/main/resources/server-reference.conf @@ -26,6 +26,7 @@ server.autoDownloadNewChapters = false # if new chapters that have been retrieve server.excludeEntryWithUnreadChapters = true # ignore automatic chapter downloads of entries with unread chapters server.autoDownloadNewChaptersLimit = 0 # 0 to disable it - how many unread downloaded chapters should be available - if the limit is reached, new chapters won't be downloaded automatically. this limit will also be applied to the auto download of new chapters on an update server.autoDownloadIgnoreReUploads = false # decides if re-uploads should be ignored during auto download of new chapters +server.autoDownloadDeleteExistingFiles = false # WARNING: this can cause a lot of downloads in case the app incorrectly detects "new" chapters due to a source changing chapter urls - delete existing downloads for new chapters to prevent pages from getting detected as already downloaded due to outdated pages of the existing download. # extension repos server.extensionRepos = [ From 8e12e36310d34920d3685a945088cee7a233d553 Mon Sep 17 00:00:00 2001 From: schroda <50052685+schroda@users.noreply.github.com> Date: Sun, 1 Sep 2024 03:41:56 +0200 Subject: [PATCH 2/2] Change autoDownloadIgnoreReUploads to not nullable This should not have been nullable at all in the first place --- .../kotlin/suwayomi/tachidesk/graphql/types/SettingsType.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/server/src/main/kotlin/suwayomi/tachidesk/graphql/types/SettingsType.kt b/server/src/main/kotlin/suwayomi/tachidesk/graphql/types/SettingsType.kt index 2a62d07e2..7f4171a5c 100644 --- a/server/src/main/kotlin/suwayomi/tachidesk/graphql/types/SettingsType.kt +++ b/server/src/main/kotlin/suwayomi/tachidesk/graphql/types/SettingsType.kt @@ -185,7 +185,7 @@ class SettingsType( ) override val autoDownloadAheadLimit: Int, override val autoDownloadNewChaptersLimit: Int, - override val autoDownloadIgnoreReUploads: Boolean?, + override val autoDownloadIgnoreReUploads: Boolean, override val autoDownloadDeleteExistingFiles: Boolean, // extension override val extensionRepos: List,