Nekomik: update domain, and deobfuscate page list (#17876)
This commit is contained in:
parent
7c194716b5
commit
abe47d81f2
@ -1,14 +1,49 @@
|
|||||||
package eu.kanade.tachiyomi.extension.id.nekomik
|
package eu.kanade.tachiyomi.extension.id.nekomik
|
||||||
|
|
||||||
|
import app.cash.quickjs.QuickJs
|
||||||
import eu.kanade.tachiyomi.multisrc.mangathemesia.MangaThemesia
|
import eu.kanade.tachiyomi.multisrc.mangathemesia.MangaThemesia
|
||||||
import eu.kanade.tachiyomi.network.interceptor.rateLimit
|
import eu.kanade.tachiyomi.network.interceptor.rateLimit
|
||||||
|
import eu.kanade.tachiyomi.source.model.Page
|
||||||
|
import kotlinx.serialization.Serializable
|
||||||
|
import kotlinx.serialization.decodeFromString
|
||||||
import okhttp3.OkHttpClient
|
import okhttp3.OkHttpClient
|
||||||
|
import org.jsoup.nodes.Document
|
||||||
|
|
||||||
class Nekomik : MangaThemesia("Nekomik", "https://nekomik.com", "id") {
|
class Nekomik : MangaThemesia("Nekomik", "https://nekomik.me", "id") {
|
||||||
|
|
||||||
override val client: OkHttpClient = super.client.newBuilder()
|
override val client: OkHttpClient = super.client.newBuilder()
|
||||||
.rateLimit(4)
|
.rateLimit(4)
|
||||||
.build()
|
.build()
|
||||||
|
|
||||||
override val hasProjectPage = true
|
override val hasProjectPage = true
|
||||||
|
|
||||||
|
override fun pageListParse(document: Document): List<Page> {
|
||||||
|
val obfuscatedJs = document.selectFirst("script:containsData(fromCharCode)")?.data()
|
||||||
|
?: return super.pageListParse(document)
|
||||||
|
|
||||||
|
val data = QuickJs.create().use { context ->
|
||||||
|
context.evaluate(
|
||||||
|
"""
|
||||||
|
ts_reader = { run: function(...args) { whatever = args[0] } };
|
||||||
|
$obfuscatedJs;
|
||||||
|
JSON.stringify(whatever);
|
||||||
|
""".trimIndent(),
|
||||||
|
) as String
|
||||||
|
}
|
||||||
|
|
||||||
|
val tsReader = json.decodeFromString<TSReader>(data)
|
||||||
|
val imageUrls = tsReader.sources.firstOrNull()?.images ?: return emptyList()
|
||||||
|
return imageUrls.mapIndexed { index, imageUrl -> Page(index, imageUrl = imageUrl) }
|
||||||
|
}
|
||||||
|
|
||||||
|
@Serializable
|
||||||
|
data class TSReader(
|
||||||
|
val sources: List<ReaderImageSource>,
|
||||||
|
)
|
||||||
|
|
||||||
|
@Serializable
|
||||||
|
data class ReaderImageSource(
|
||||||
|
val source: String,
|
||||||
|
val images: List<String>,
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
@ -91,7 +91,7 @@ class MangaThemesiaGenerator : ThemeSourceGenerator {
|
|||||||
SingleLang("MirrorDesu", "https://mirrordesu.me", "id", isNsfw = true),
|
SingleLang("MirrorDesu", "https://mirrordesu.me", "id", isNsfw = true),
|
||||||
SingleLang("Moon Daisy Scans", "https://moondaisyscans.com", "tr", isNsfw = true),
|
SingleLang("Moon Daisy Scans", "https://moondaisyscans.com", "tr", isNsfw = true),
|
||||||
SingleLang("Mundo Mangá-Kun", "https://mundomangakun.com.br", "pt-BR", className = "MundoMangaKun", isNsfw = true),
|
SingleLang("Mundo Mangá-Kun", "https://mundomangakun.com.br", "pt-BR", className = "MundoMangaKun", isNsfw = true),
|
||||||
SingleLang("Nekomik", "https://nekomik.com", "id"),
|
SingleLang("Nekomik", "https://nekomik.me", "id", overrideVersionCode = 1),
|
||||||
SingleLang("Ngomik", "https://ngomik.net", "id", overrideVersionCode = 2),
|
SingleLang("Ngomik", "https://ngomik.net", "id", overrideVersionCode = 2),
|
||||||
SingleLang("NIGHT SCANS", "https://nightscans.org", "en", isNsfw = true, className = "NightScans", overrideVersionCode = 1),
|
SingleLang("NIGHT SCANS", "https://nightscans.org", "en", isNsfw = true, className = "NightScans", overrideVersionCode = 1),
|
||||||
SingleLang("Nocturnal Scans", "https://nocturnalscans.com", "en", overrideVersionCode = 1),
|
SingleLang("Nocturnal Scans", "https://nocturnalscans.com", "en", overrideVersionCode = 1),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user