From 1fc164d5acc54916ed04a6f16dbbf91dc6c7bc3e Mon Sep 17 00:00:00 2001 From: Eshlender <35057681+e-shl@users.noreply.github.com> Date: Tue, 17 Dec 2024 10:21:51 +0500 Subject: [PATCH] [RU]MangaLib fix cloudflare errors (#6608) * [RU]MangaLib fix cloudflare errors * test-front equal main domain * add api domains * api domains summary * fix * change PREF * add api "https://api.mangalib.me" --- lib-multisrc/libgroup/build.gradle.kts | 2 +- .../tachiyomi/multisrc/libgroup/LibGroup.kt | 71 ++++++++++++------- .../extension/ru/mangalib/MangaLib.kt | 2 +- 3 files changed, 47 insertions(+), 28 deletions(-) diff --git a/lib-multisrc/libgroup/build.gradle.kts b/lib-multisrc/libgroup/build.gradle.kts index 759e0cf398..f551e41b8a 100644 --- a/lib-multisrc/libgroup/build.gradle.kts +++ b/lib-multisrc/libgroup/build.gradle.kts @@ -2,4 +2,4 @@ plugins { id("lib-multisrc") } -baseVersionCode = 32 +baseVersionCode = 33 diff --git a/lib-multisrc/libgroup/src/eu/kanade/tachiyomi/multisrc/libgroup/LibGroup.kt b/lib-multisrc/libgroup/src/eu/kanade/tachiyomi/multisrc/libgroup/LibGroup.kt index 9dbb1afefa..70fa855492 100644 --- a/lib-multisrc/libgroup/src/eu/kanade/tachiyomi/multisrc/libgroup/LibGroup.kt +++ b/lib-multisrc/libgroup/src/eu/kanade/tachiyomi/multisrc/libgroup/LibGroup.kt @@ -34,7 +34,6 @@ import kotlinx.serialization.json.Json import okhttp3.Headers import okhttp3.HttpUrl.Companion.toHttpUrl import okhttp3.Interceptor -import okhttp3.OkHttpClient import okhttp3.Request import okhttp3.Response import rx.Observable @@ -65,38 +64,37 @@ abstract class LibGroup( override val supportsLatest = true - private val userAgentMobile = "Mozilla/5.0 (Linux; Android 10; K) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Mobile Safari/537.3" - private var bearerToken: String? = null private var userId: Int? = null abstract val siteId: Int // Important in api calls - private val apiDomain: String = "https://api.lib.social" - - override val client: OkHttpClient = network.cloudflareClient.newBuilder() - .rateLimit(3) - .rateLimitHost(apiDomain.toHttpUrl(), 1) - .connectTimeout(5, TimeUnit.MINUTES) - .readTimeout(30, TimeUnit.SECONDS) - .writeTimeout(15, TimeUnit.SECONDS) - .addInterceptor(::checkForToken) - .addInterceptor { chain -> - val response = chain.proceed(chain.request()) - if (response.code == 419) { - throw IOException("HTTP error ${response.code}. Проверьте сайт. Для завершения авторизации необходимо перезапустить приложение с полной остановкой.") - } - if (response.code == 404) { - throw IOException("HTTP error ${response.code}. Проверьте сайт. Попробуйте авторизоваться через WebView\uD83C\uDF0E︎ и обновите список. Для завершения авторизации может потребоваться перезапустить приложение с полной остановкой.") + private val apiDomain: String = preferences.getString(API_DOMAIN_PREF, API_DOMAIN_DEFAULT).toString() + + override val client by lazy { + network.cloudflareClient.newBuilder() + .rateLimit(3) + .rateLimitHost(apiDomain.toHttpUrl(), 1) + .rateLimitHost(baseUrl.toHttpUrl(), 1) + .connectTimeout(5, TimeUnit.MINUTES) + .readTimeout(30, TimeUnit.SECONDS) + .writeTimeout(15, TimeUnit.SECONDS) + .addInterceptor(::checkForToken) + .addInterceptor { chain -> + val response = chain.proceed(chain.request()) + if (response.code == 419) { + throw IOException("HTTP error ${response.code}. Проверьте сайт. Для завершения авторизации необходимо перезапустить приложение с полной остановкой.") + } + if (response.code == 404) { + throw IOException("HTTP error ${response.code}. Проверьте сайт. Попробуйте авторизоваться через WebView\uD83C\uDF0E︎ и обновите список. Для завершения авторизации может потребоваться перезапустить приложение с полной остановкой.") + } + return@addInterceptor response } - return@addInterceptor response - } - .build() + .build() + } override fun headersBuilder() = Headers.Builder().apply { - // User-Agent required for authorization through third-party accounts (mobile version for correct display in WebView) - add("User-Agent", userAgentMobile) add("Accept", "text/html,application/json,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,image/svg+xml,image/*,*/*;q=0.8") add("Referer", baseUrl) add("Site-Id", siteId.toString()) @@ -385,8 +383,6 @@ abstract class LibGroup( override fun imageRequest(page: Page): Request { val imageHeader = Headers.Builder().apply { - // User-Agent required for authorization through third-party accounts (mobile version for correct display in WebView) - add("User-Agent", userAgentMobile) add("Accept", "image/avif,image/webp,image/apng,image/svg+xml,image/*,*/*;q=0.8") add("Referer", baseUrl) } @@ -578,6 +574,10 @@ abstract class LibGroup( private const val LANGUAGE_PREF = "MangaLibTitleLanguage" private const val LANGUAGE_PREF_TITLE = "Выбор языка на обложке" + private const val API_DOMAIN_PREF = "MangaLibApiDomain" + private const val API_DOMAIN_TITLE = "Выбор домена API" + private const val API_DOMAIN_DEFAULT = "https://api.imglib.info" + private const val TOKEN_STORE = "TokenStore" val simpleDateFormat by lazy { SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSSSS'Z'", Locale.US) } @@ -629,11 +629,30 @@ abstract class LibGroup( true } } + + val domainApiPref = ListPreference(screen.context).apply { + key = API_DOMAIN_PREF + title = API_DOMAIN_TITLE + entries = arrayOf("Официальное приложение (api.imglib.info)", "Основной (api.lib.social)", "Резервный (api.mangalib.me)", "Резервный 2 (api2.mangalib.me)") + entryValues = arrayOf(API_DOMAIN_DEFAULT, "https://api.lib.social", "https://api.mangalib.me", "https://api2.mangalib.me") + summary = "%s" + + "\n\nВыбор домена API, используемого для работы приложения." + + "\n\nПо умолчанию «Официальное приложение»" + + "\n\nⓘВы не увидите его нигде глазами, но источник должен начать работать стибильнее." + setDefaultValue(API_DOMAIN_DEFAULT) + setOnPreferenceChangeListener { _, newValue -> + val warning = "Для смены домена необходимо перезапустить приложение с полной остановкой." + Toast.makeText(screen.context, warning, Toast.LENGTH_LONG).show() + true + } + } + screen.addPreference(serverPref) screen.addPreference(sortingPref) screen.addPreference(screen.editTextPreference(TRANSLATORS_TITLE, TRANSLATORS_DEFAULT, groupTranslates())) screen.addPreference(scanlatorUsername) screen.addPreference(titleLanguagePref) + screen.addPreference(domainApiPref) } private fun PreferenceScreen.editTextPreference(title: String, default: String, value: String): androidx.preference.EditTextPreference { return androidx.preference.EditTextPreference(context).apply { diff --git a/src/ru/mangalib/src/eu/kanade/tachiyomi/extension/ru/mangalib/MangaLib.kt b/src/ru/mangalib/src/eu/kanade/tachiyomi/extension/ru/mangalib/MangaLib.kt index 69396a5581..5d88c35f66 100644 --- a/src/ru/mangalib/src/eu/kanade/tachiyomi/extension/ru/mangalib/MangaLib.kt +++ b/src/ru/mangalib/src/eu/kanade/tachiyomi/extension/ru/mangalib/MangaLib.kt @@ -38,6 +38,6 @@ class MangaLib : LibGroup("MangaLib", "https://mangalib.me", "ru") { companion object { private const val DOMAIN_PREF = "MangaLibDomain" private const val DOMAIN_TITLE = "Домен" - private const val DOMAIN_DEFAULT = "https://test-front.mangalib.me" + private const val DOMAIN_DEFAULT = "https://mangalib.me" } }