Fix missing chapters at MP (#8625)

* Fix missing chapters at MP.

* Make rate limit more harsher.
This commit is contained in:
Alessandro Jean 2021-08-18 12:16:45 -03:00 committed by GitHub
parent 00439cfd35
commit eb255c0b78
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 11 additions and 7 deletions

View File

@ -18,9 +18,11 @@ class LeitorNet : MangasProject("Leitor.net", "https://leitor.net", "pt-BR") {
override val id: Long = 2225174659569980836 override val id: Long = 2225174659569980836
override val client: OkHttpClient = super.client.newBuilder() override val client: OkHttpClient = super.client.newBuilder()
.addInterceptor(RateLimitInterceptor(1, 2, TimeUnit.SECONDS)) .addInterceptor(RateLimitInterceptor(1, 3, TimeUnit.SECONDS))
.build() .build()
override val licensedCheck = true
/** /**
* Temporary fix to bypass Cloudflare. * Temporary fix to bypass Cloudflare.
*/ */

View File

@ -17,7 +17,7 @@ class MangaLivre : MangasProject("Mangá Livre", "https://mangalivre.net", "pt-B
override val id: Long = 4762777556012432014 override val id: Long = 4762777556012432014
override val client: OkHttpClient = super.client.newBuilder() override val client: OkHttpClient = super.client.newBuilder()
.addInterceptor(RateLimitInterceptor(1, 2, TimeUnit.SECONDS)) .addInterceptor(RateLimitInterceptor(1, 3, TimeUnit.SECONDS))
.build() .build()
override fun popularMangaRequest(page: Int): Request { override fun popularMangaRequest(page: Int): Request {

View File

@ -56,6 +56,8 @@ abstract class MangasProject(
private val json: Json by injectLazy() private val json: Json by injectLazy()
protected open val licensedCheck: Boolean = false
override fun popularMangaRequest(page: Int): Request { override fun popularMangaRequest(page: Int): Request {
return GET("$baseUrl/home/most_read?page=$page&type=", sourceHeaders) return GET("$baseUrl/home/most_read?page=$page&type=", sourceHeaders)
} }
@ -136,7 +138,7 @@ abstract class MangasProject(
val isCompleted = seriesData.select("span.series-author i.complete-series").first() != null val isCompleted = seriesData.select("span.series-author i.complete-series").first() != null
// Check if the manga was removed by the publisher. // Check if the manga was removed by the publisher.
val seriesBlocked = document.select("div.series-blocked-img").first() val seriesBlocked = document.select("div.series-blocked-img:has(img[src$=blocked.svg])").first()
val seriesAuthors = document.select("div#series-data span.series-author").text() val seriesAuthors = document.select("div#series-data span.series-author").text()
.substringAfter("Completo") .substringAfter("Completo")
@ -166,7 +168,7 @@ abstract class MangasProject(
} }
private fun parseStatus(seriesBlocked: Element?, isCompleted: Boolean) = when { private fun parseStatus(seriesBlocked: Element?, isCompleted: Boolean) = when {
seriesBlocked != null -> SManga.LICENSED seriesBlocked != null && licensedCheck -> SManga.LICENSED
isCompleted -> SManga.COMPLETED isCompleted -> SManga.COMPLETED
else -> SManga.ONGOING else -> SManga.ONGOING
} }
@ -188,9 +190,9 @@ abstract class MangasProject(
override fun chapterListParse(response: Response): List<SChapter> { override fun chapterListParse(response: Response): List<SChapter> {
val document = response.asJsoup() val document = response.asJsoup()
val licensedMessage = document.select("div.series-blocked-img").firstOrNull() val licensedMessage = document.select("div.series-blocked-img:has(img[src$=blocked.svg])").firstOrNull()
if (licensedMessage != null) { if (licensedMessage != null && licensedCheck) {
// If the manga is licensed and has been removed from the source, // If the manga is licensed and has been removed from the source,
// the extension will not fetch the chapters, even if they are returned // the extension will not fetch the chapters, even if they are returned
// by the API. This is just to mimic the website behavior. // by the API. This is just to mimic the website behavior.

View File

@ -9,7 +9,7 @@ class MangasProjectGenerator : ThemeSourceGenerator {
override val themeClass = "MangasProject" override val themeClass = "MangasProject"
override val baseVersionCode: Int = 9 override val baseVersionCode: Int = 10
override val sources = listOf( override val sources = listOf(
SingleLang("Leitor.net", "https://leitor.net", "pt-BR", className = "LeitorNet", isNsfw = true), SingleLang("Leitor.net", "https://leitor.net", "pt-BR", className = "LeitorNet", isNsfw = true),