[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"
This commit is contained in:
Eshlender 2024-12-17 10:21:51 +05:00 committed by Draff
parent d3054332eb
commit dfc8f73cb5
No known key found for this signature in database
GPG Key ID: E8A89F3211677653
3 changed files with 46 additions and 27 deletions

View File

@ -2,4 +2,4 @@ plugins {
id("lib-multisrc") id("lib-multisrc")
} }
baseVersionCode = 32 baseVersionCode = 33

View File

@ -34,7 +34,6 @@ import kotlinx.serialization.json.Json
import okhttp3.Headers import okhttp3.Headers
import okhttp3.HttpUrl.Companion.toHttpUrl import okhttp3.HttpUrl.Companion.toHttpUrl
import okhttp3.Interceptor import okhttp3.Interceptor
import okhttp3.OkHttpClient
import okhttp3.Request import okhttp3.Request
import okhttp3.Response import okhttp3.Response
import rx.Observable import rx.Observable
@ -65,38 +64,37 @@ abstract class LibGroup(
override val supportsLatest = true 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 bearerToken: String? = null
private var userId: Int? = null private var userId: Int? = null
abstract val siteId: Int // Important in api calls abstract val siteId: Int // Important in api calls
private val apiDomain: String = "https://api.lib.social" private val apiDomain: String = preferences.getString(API_DOMAIN_PREF, API_DOMAIN_DEFAULT).toString()
override val client: OkHttpClient = network.cloudflareClient.newBuilder() override val client by lazy {
.rateLimit(3) network.cloudflareClient.newBuilder()
.rateLimitHost(apiDomain.toHttpUrl(), 1) .rateLimit(3)
.connectTimeout(5, TimeUnit.MINUTES) .rateLimitHost(apiDomain.toHttpUrl(), 1)
.readTimeout(30, TimeUnit.SECONDS) .rateLimitHost(baseUrl.toHttpUrl(), 1)
.writeTimeout(15, TimeUnit.SECONDS) .connectTimeout(5, TimeUnit.MINUTES)
.addInterceptor(::checkForToken) .readTimeout(30, TimeUnit.SECONDS)
.addInterceptor { chain -> .writeTimeout(15, TimeUnit.SECONDS)
val response = chain.proceed(chain.request()) .addInterceptor(::checkForToken)
if (response.code == 419) { .addInterceptor { chain ->
throw IOException("HTTP error ${response.code}. Проверьте сайт. Для завершения авторизации необходимо перезапустить приложение с полной остановкой.") 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
} }
if (response.code == 404) { .build()
throw IOException("HTTP error ${response.code}. Проверьте сайт. Попробуйте авторизоваться через WebView\uD83C\uDF0E и обновите список. Для завершения авторизации может потребоваться перезапустить приложение с полной остановкой.") }
}
return@addInterceptor response
}
.build()
override fun headersBuilder() = Headers.Builder().apply { 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("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("Referer", baseUrl)
add("Site-Id", siteId.toString()) add("Site-Id", siteId.toString())
@ -385,8 +383,6 @@ abstract class LibGroup(
override fun imageRequest(page: Page): Request { override fun imageRequest(page: Page): Request {
val imageHeader = Headers.Builder().apply { 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("Accept", "image/avif,image/webp,image/apng,image/svg+xml,image/*,*/*;q=0.8")
add("Referer", baseUrl) add("Referer", baseUrl)
} }
@ -578,6 +574,10 @@ abstract class LibGroup(
private const val LANGUAGE_PREF = "MangaLibTitleLanguage" private const val LANGUAGE_PREF = "MangaLibTitleLanguage"
private const val LANGUAGE_PREF_TITLE = "Выбор языка на обложке" 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" private const val TOKEN_STORE = "TokenStore"
val simpleDateFormat by lazy { SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSSSS'Z'", Locale.US) } val simpleDateFormat by lazy { SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSSSS'Z'", Locale.US) }
@ -629,11 +629,30 @@ abstract class LibGroup(
true 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(serverPref)
screen.addPreference(sortingPref) screen.addPreference(sortingPref)
screen.addPreference(screen.editTextPreference(TRANSLATORS_TITLE, TRANSLATORS_DEFAULT, groupTranslates())) screen.addPreference(screen.editTextPreference(TRANSLATORS_TITLE, TRANSLATORS_DEFAULT, groupTranslates()))
screen.addPreference(scanlatorUsername) screen.addPreference(scanlatorUsername)
screen.addPreference(titleLanguagePref) screen.addPreference(titleLanguagePref)
screen.addPreference(domainApiPref)
} }
private fun PreferenceScreen.editTextPreference(title: String, default: String, value: String): androidx.preference.EditTextPreference { private fun PreferenceScreen.editTextPreference(title: String, default: String, value: String): androidx.preference.EditTextPreference {
return androidx.preference.EditTextPreference(context).apply { return androidx.preference.EditTextPreference(context).apply {

View File

@ -38,6 +38,6 @@ class MangaLib : LibGroup("MangaLib", "https://mangalib.me", "ru") {
companion object { companion object {
private const val DOMAIN_PREF = "MangaLibDomain" private const val DOMAIN_PREF = "MangaLibDomain"
private const val DOMAIN_TITLE = "Домен" private const val DOMAIN_TITLE = "Домен"
private const val DOMAIN_DEFAULT = "https://test-front.mangalib.me" private const val DOMAIN_DEFAULT = "https://mangalib.me"
} }
} }