From e935556bffe6f05469e9c2597459cb7bf2afe33d Mon Sep 17 00:00:00 2001 From: bapeey <90949336+bapeey@users.noreply.github.com> Date: Sun, 22 Sep 2024 01:45:42 -0500 Subject: [PATCH] IkigaiMangas: Search domain automatically (#5152) domain --- src/es/ikigaimangas/build.gradle | 2 +- .../extension/es/ikigaimangas/IkigaiMangas.kt | 44 ++++++++++++++++--- 2 files changed, 39 insertions(+), 7 deletions(-) diff --git a/src/es/ikigaimangas/build.gradle b/src/es/ikigaimangas/build.gradle index 6beb44376..a7d931ea7 100644 --- a/src/es/ikigaimangas/build.gradle +++ b/src/es/ikigaimangas/build.gradle @@ -1,7 +1,7 @@ ext { extName = 'Ikigai Mangas' extClass = '.IkigaiMangas' - extVersionCode = 16 + extVersionCode = 17 isNsfw = true } diff --git a/src/es/ikigaimangas/src/eu/kanade/tachiyomi/extension/es/ikigaimangas/IkigaiMangas.kt b/src/es/ikigaimangas/src/eu/kanade/tachiyomi/extension/es/ikigaimangas/IkigaiMangas.kt index 43f6876d5..1b635d730 100644 --- a/src/es/ikigaimangas/src/eu/kanade/tachiyomi/extension/es/ikigaimangas/IkigaiMangas.kt +++ b/src/es/ikigaimangas/src/eu/kanade/tachiyomi/extension/es/ikigaimangas/IkigaiMangas.kt @@ -33,11 +33,13 @@ import kotlin.concurrent.thread class IkigaiMangas : HttpSource(), ConfigurableSource { - private val defaultBaseUrl: String = "https://lectorikigai.erigu.com" + private val defaultBaseUrl: String = "https://lectorikigai.efope.com" private val isCi = System.getenv("CI") == "true" - override val baseUrl get() = when { - isCi -> defaultBaseUrl - else -> preferences.getPrefBaseUrl() + override val baseUrl: String by lazy { + when { + isCi -> defaultBaseUrl + else -> fetchDomain() + } } private val apiBaseUrl: String = "https://panel.ikigaimangas.com" @@ -67,11 +69,28 @@ class IkigaiMangas : HttpSource(), ConfigurableSource { Injekt.get().getSharedPreferences("source_$id", 0x0000) override fun headersBuilder() = super.headersBuilder() - .add("Origin", baseUrl) .add("Referer", "$baseUrl/") private val json: Json by injectLazy() + private fun fetchDomain(): String { + if (!preferences.fetchDomainPref()) return preferences.getPrefBaseUrl() + try { + val initClient = network.cloudflareClient + val headers = super.headersBuilder().build() + val homeDomain = "https://ikigaimangas.com" + val document = initClient.newCall(GET(homeDomain, headers)).execute().asJsoup() + val scriptUrl = document.selectFirst("div[on:click]:containsOwn(Nuevo dominio)")?.attr("on:click") + ?: return defaultBaseUrl + val script = initClient.newCall(GET("$homeDomain/build/$scriptUrl", headers)).execute().body.string() + val domain = script.substringAfter("window.open(\"").substringBefore("\"") + val host = initClient.newCall(GET(domain, headers)).execute().request.url.host + return "https://$host" + } catch (e: Exception) { + return defaultBaseUrl + } + } + private val dateFormat = SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSSSS'Z'", Locale.US).apply { timeZone = TimeZone.getTimeZone("UTC") } @@ -256,6 +275,13 @@ class IkigaiMangas : HttpSource(), ConfigurableSource { setDefaultValue(SHOW_NSFW_PREF_DEFAULT) }.also { screen.addPreference(it) } + SwitchPreferenceCompat(screen.context).apply { + key = FETCH_DOMAIN_PREF + title = FETCH_DOMAIN_PREF_TITLE + summary = FETCH_DOMAIN_PREF_SUMMARY + setDefaultValue(FETCH_DOMAIN_PREF_DEFAULT) + }.also { screen.addPreference(it) } + EditTextPreference(screen.context).apply { key = BASE_URL_PREF title = BASE_URL_PREF_TITLE @@ -272,6 +298,7 @@ class IkigaiMangas : HttpSource(), ConfigurableSource { private fun SharedPreferences.showNsfwPref() = getBoolean(SHOW_NSFW_PREF, SHOW_NSFW_PREF_DEFAULT) private fun SharedPreferences.getPrefBaseUrl() = getString(BASE_URL_PREF, defaultBaseUrl)!! + private fun SharedPreferences.fetchDomainPref() = getBoolean(FETCH_DOMAIN_PREF, FETCH_DOMAIN_PREF_DEFAULT) private inline fun List<*>.firstInstanceOrNull(): R? = filterIsInstance().firstOrNull() @@ -285,9 +312,14 @@ class IkigaiMangas : HttpSource(), ConfigurableSource { private const val BASE_URL_PREF = "overrideBaseUrl" private const val BASE_URL_PREF_TITLE = "Editar URL de la fuente" - private const val BASE_URL_PREF_SUMMARY = "Para uso temporal, si la extensión se actualiza se perderá el cambio." + private const val BASE_URL_PREF_SUMMARY = "Para uso temporal, si la extensión se actualiza se perderá el cambio. No se aplica si se busca el dominio automáticamente." private const val DEFAULT_BASE_URL_PREF = "defaultBaseUrl" private const val RESTART_APP_MESSAGE = "Reinicie la aplicación para aplicar los cambios" + + private const val FETCH_DOMAIN_PREF = "fetchDomain" + private const val FETCH_DOMAIN_PREF_TITLE = "Buscar dominio automáticamente" + private const val FETCH_DOMAIN_PREF_SUMMARY = "Intenta buscar el dominio automáticamente al abrir la fuente." + private const val FETCH_DOMAIN_PREF_DEFAULT = true } init {