MNS: Fetch regex and selectors from repository (#2380)

* Use values from repository
This commit is contained in:
bapeey 2024-04-13 00:53:52 -05:00 committed by Draff
parent 7c27192ab2
commit 440abc28d8
2 changed files with 12 additions and 17 deletions

View File

@ -3,7 +3,7 @@ ext {
extClass = '.MangasNoSekai' extClass = '.MangasNoSekai'
themePkg = 'madara' themePkg = 'madara'
baseUrl = 'https://mangasnosekai.com' baseUrl = 'https://mangasnosekai.com'
overrideVersionCode = 12 overrideVersionCode = 13
} }
apply from: "$rootDir/common.gradle" apply from: "$rootDir/common.gradle"

View File

@ -198,27 +198,30 @@ class MangasNoSekai : Madara(
val document = response.asJsoup() val document = response.asJsoup()
launchIO { countViews(document) } launchIO { countViews(document) }
val txtUrl = "https://raw.githubusercontent.com/bapeey/extensions-tools/main/keiyoushi/mns/values.txt"
val values = client.newCall(GET(txtUrl)).execute().body.string().split("\n")
val mangaSlug = response.request.url.toString().substringAfter(baseUrl).removeSuffix("/") val mangaSlug = response.request.url.toString().substringAfter(baseUrl).removeSuffix("/")
val coreScript = document.selectFirst("script#wp-manga-js")!!.attr("abs:src") val coreScript = document.selectFirst(values[0])!!.attr("abs:src")
val coreScriptBody = client.newCall(GET(coreScript, headers)).execute().body.string() val coreScriptBody = client.newCall(GET(coreScript, headers)).execute().body.string()
val url = URL_REGEX.find(coreScriptBody)?.groupValues?.get(1) val url = values[5].toRegex().find(coreScriptBody)?.groupValues?.get(1)
?: throw Exception("No se pudo obtener la url del capítulo") ?: throw Exception("No se pudo obtener la url del capítulo")
val data = DATA_REGEX.find(coreScriptBody)?.groupValues?.get(1)?.trim() val data = values[5].toRegex().find(coreScriptBody)?.groupValues?.get(2)?.trim()
?: throw Exception("No se pudo obtener la data del capítulo") ?: throw Exception("No se pudo obtener la data del capítulo")
val objects = DATA_OBJECTS_REGEX.findAll(data) val objects = values[6].toRegex().findAll(data)
.mapNotNull { matchResult -> .mapNotNull { matchResult ->
val key = matchResult.groupValues[1] val key = matchResult.groupValues[1]
val value = matchResult.groupValues.getOrNull(2) val value = matchResult.groupValues.getOrNull(2)
if (!value.isNullOrEmpty()) key to value else null if (!value.isNullOrEmpty()) key to value else null
}.toList() }.toList()
val mangaId = document.selectFirst("script#wp-manga-js-extra")?.data() val mangaId = document.selectFirst(values[1])?.data()
?.let { MANGA_ID_REGEX.find(it)?.groupValues?.get(1) } ?.let { values[7].toRegex().find(it)?.groupValues?.get(1) }
?: document.selectFirst("script#manga_disqus_embed-js-extra")?.data() ?: document.selectFirst(values[2])?.data()
?.let { POST_ID_REGEX.find(it)?.groupValues?.get(1) } ?.let { values[8].toRegex().find(it)?.groupValues?.get(1) }
?: throw Exception("No se pudo obtener el id del manga") ?: throw Exception("No se pudo obtener el id del manga")
val chapterElements = mutableListOf<Element>() val chapterElements = mutableListOf<Element>()
@ -250,12 +253,4 @@ class MangasNoSekai : Madara(
val result = json.decodeFromString<PayloadDto>(jsonString) val result = json.decodeFromString<PayloadDto>(jsonString)
return result.manga.first().chapters.map { it.toSChapter(mangaSlug) } return result.manga.first().chapters.map { it.toSChapter(mangaSlug) }
} }
companion object {
val DATA_REGEX = """function\s+loadMoreChapters[\s\S]*?\$.ajax[\s\S]*?data:\s*\{([\s\S]*?)\},?""".toRegex()
val URL_REGEX = """function\s+loadMoreChapters[\s\S]*?\$.ajax[\s\S]*?url:\s*'(.*?)'""".toRegex()
val DATA_OBJECTS_REGEX = """\s*(\w+)\s*:\s*(?:(?:'([^']*)'|([^,\r\n]+))\s*,?\s*)""".toRegex()
val MANGA_ID_REGEX = """\"manga_id"\s*:\s*"(.*)\"""".toRegex()
val POST_ID_REGEX = """\"postId"\s*:\s*"(.*)\"""".toRegex()
}
} }