add sources and fix

pull/283/head
devi 3 years ago
parent 400a90464e
commit 09500c0734

@ -0,0 +1,178 @@
package org.koitharu.kotatsu.parsers.site.all
import androidx.collection.ArraySet
import kotlinx.coroutines.async
import kotlinx.coroutines.awaitAll
import kotlinx.coroutines.coroutineScope
import org.jsoup.nodes.Element
import org.koitharu.kotatsu.parsers.MangaLoaderContext
import org.koitharu.kotatsu.parsers.MangaSourceParser
import org.koitharu.kotatsu.parsers.PagedMangaParser
import org.koitharu.kotatsu.parsers.config.ConfigKey
import org.koitharu.kotatsu.parsers.model.*
import org.koitharu.kotatsu.parsers.util.*
import java.util.*
@MangaSourceParser("HENTAIFOX", "Hentai Fox", type = ContentType.HENTAI)
internal class HentaiFox(context: MangaLoaderContext) : PagedMangaParser(context, MangaSource.HENTAIFOX, 20) {
override val sortOrders: Set<SortOrder> = EnumSet.of(SortOrder.UPDATED)
override val configKeyDomain = ConfigKey.Domain("hentaifox.com")
override suspend fun getListPage(
page: Int,
query: String?,
tags: Set<MangaTag>?,
sortOrder: SortOrder,
): List<Manga> {
val tag = tags.oneOrThrowIfMany()
val url = buildString {
append("https://$domain")
if (!tags.isNullOrEmpty()) {
append("/tag/")
append(tag?.key.orEmpty())
if (page > 1) {
append("/pag/")
append(page)
append("/")
}
} else if (!query.isNullOrEmpty()) {
append("/search/?q=")
append(query.urlEncoded())
if (page > 1) {
append("&page=")
append(page)
}
} else {
if (page > 2) {
append("/pag/")
append(page)
append("/")
} else if (page > 1) {
append("/page/")
append(page)
append("/")
}
}
}
val doc = webClient.httpGet(url).parseHtml()
return doc.select(".lc_galleries .thumb").map { div ->
val href = div.selectFirstOrThrow(".inner_thumb a").attrAsRelativeUrl("href")
Manga(
id = generateUid(href),
title = div.select("h2.g_title").text(),
altTitle = null,
url = href,
publicUrl = href.toAbsoluteUrl(domain),
rating = RATING_UNKNOWN,
isNsfw = isNsfwSource,
coverUrl = div.selectFirstOrThrow("img").src().orEmpty(),
tags = emptySet(),
state = null,
author = null,
source = source,
)
}
}
override suspend fun getTags(): Set<MangaTag> {
val root = webClient.httpGet("https://$domain/tags/").parseHtml()
val totalPagesTags = root.select("ul.pagination a.page-link").dropLast(1).last().text().toInt()
return coroutineScope {
(1..totalPagesTags).map { page ->
async { getTags(page) }
}
}.awaitAll().flattenTo(ArraySet(360))
}
private suspend fun getTags(page: Int): Set<MangaTag> {
val url = "https://$domain/tags/pag/$page/"
val root = webClient.httpGet(url).parseHtml()
return root.parseTags()
}
private fun Element.parseTags() = select(".list_tags a.tag_btn").mapToSet { it ->
val key = it.attr("href").removeSuffix('/').substringAfterLast('/')
MangaTag(
key = key,
title = it.selectFirstOrThrow("h3").text(),
source = source,
)
}
override suspend fun getDetails(manga: Manga): Manga {
val doc = webClient.httpGet(manga.url.toAbsoluteUrl(domain)).parseHtml()
val urlChapters = manga.url.replace("/gallery/", "/g/") + "1/"
return manga.copy(
altTitle = null,
tags = doc.select("ul.tags a.tag_btn ").mapNotNullToSet {
val key = it.attr("href").removeSuffix('/').substringAfterLast('/')
MangaTag(
key = key,
title = it.html().substringBefore("<span"),
source = source,
)
},
author = doc.selectFirst("ul.artists a.tag_btn")?.html()?.substringBefore("<span"),
description = null,
chapters = listOf(
MangaChapter(
id = manga.id,
name = manga.title,
number = 1,
url = urlChapters,
scanlator = null,
uploadDate = 0,
branch = doc.selectFirstOrThrow("ul.languages a.tag_btn").html().substringBefore("<span"),
source = source,
),
),
)
}
override suspend fun getRelatedManga(seed: Manga): List<Manga> {
val doc = webClient.httpGet(seed.url.toAbsoluteUrl(domain)).parseHtml()
val root = doc.body().selectFirstOrThrow(".related_galleries")
return root.select("div.thumb").mapNotNull { div ->
val a = div.selectFirst(".inner_thumb a") ?: return@mapNotNull null
val href = a.attrAsRelativeUrl("href")
Manga(
id = generateUid(href),
url = href,
publicUrl = href.toAbsoluteUrl(a.host ?: domain),
altTitle = null,
title = div.selectFirstOrThrow("h2.g_title").text(),
author = null,
coverUrl = div.selectFirst("img")?.src().orEmpty(),
tags = emptySet(),
rating = RATING_UNKNOWN,
state = null,
isNsfw = isNsfwSource,
source = source,
)
}
}
override suspend fun getPages(chapter: MangaChapter): List<MangaPage> {
val doc = webClient.httpGet(chapter.url.toAbsoluteUrl(domain)).parseHtml()
val totalPages = doc.selectFirstOrThrow(".total_pages").text().toInt()
val rawUrl = chapter.url.replace("/1/", "/")
return (1..totalPages).map {
val url = "$rawUrl$it/"
MangaPage(
id = generateUid(url),
url = url,
preview = null,
source = source,
)
}
}
override suspend fun getPageUrl(page: MangaPage): String {
val doc = webClient.httpGet(page.url.toAbsoluteUrl(domain)).parseHtml()
val root = doc.body()
return root.requireElementById("gimg").attr("data-src") ?: doc.parseFailed("Page image not found")
}
}

@ -0,0 +1,163 @@
package org.koitharu.kotatsu.parsers.site.ar
import kotlinx.coroutines.async
import kotlinx.coroutines.coroutineScope
import org.json.JSONArray
import org.json.JSONObject
import org.koitharu.kotatsu.parsers.MangaLoaderContext
import org.koitharu.kotatsu.parsers.MangaSourceParser
import org.koitharu.kotatsu.parsers.PagedMangaParser
import org.koitharu.kotatsu.parsers.config.ConfigKey
import org.koitharu.kotatsu.parsers.model.*
import org.koitharu.kotatsu.parsers.util.*
import org.koitharu.kotatsu.parsers.util.json.mapJSON
import org.koitharu.kotatsu.parsers.util.json.mapJSONIndexed
import java.text.SimpleDateFormat
import java.util.*
@MangaSourceParser("FLIXSCANS", "Flix Scans", "ar")
internal class FlixScans(context: MangaLoaderContext) : PagedMangaParser(context, MangaSource.FLIXSCANS, 18) {
override val sortOrders: Set<SortOrder> = EnumSet.of(SortOrder.UPDATED)
override val configKeyDomain = ConfigKey.Domain("flixscans.com")
override suspend fun getListPage(
page: Int,
query: String?,
tags: Set<MangaTag>?,
sortOrder: SortOrder,
): List<Manga> {
val json = if (!query.isNullOrEmpty()) {
if (page > 1) {
return emptyList()
}
val url = "https://api.$domain/api/v1/search/serie"
val body = JSONObject()
body.put("title", query.urlEncoded())
webClient.httpPost(url, body).parseJson().getJSONArray("data")
} else if (!tags.isNullOrEmpty()) {
if (page > 1) {
return emptyList()
}
val tagQuery = tags.joinToString(separator = ",") { it.key }
val url = "https://api.$domain/api/v1/search/advance?=&genres=$tagQuery&serie_type=webtoon"
webClient.httpGet(url).parseJson().getJSONArray("data")
} else {
val url = "https://api.$domain/api/v1/webtoon/homepage/latest/home?page=$page"
webClient.httpGet(url).parseJson().getJSONArray("data")
}
return json.mapJSON { j ->
val href = "https://$domain/series/${j.getString("prefix")}-${j.getString("id")}-${j.getString("slug")}"
val cover = "https://api.$domain/storage/" + j.getString("thumbnail")
Manga(
id = generateUid(href),
title = j.getString("title"),
altTitle = null,
url = href,
publicUrl = href.toAbsoluteUrl(domain),
rating = RATING_UNKNOWN,
isNsfw = false,
coverUrl = cover,
tags = emptySet(),
state = when (j.getString("status")) {
"ongoing" -> MangaState.ONGOING
"completed" -> MangaState.FINISHED
else -> null
},
author = null,
source = source,
)
}
}
override suspend fun getTags(): Set<MangaTag> {
val doc = webClient.httpGet("https://$domain/search/advance").parseHtml()
val json = JSONArray(doc.requireElementById("__NUXT_DATA__").data())
val tagsList = json.getJSONArray(3).toString().replace("[", "").replace("]", "").split(",")
return tagsList.mapNotNullToSet { idTag ->
val id = idTag.toInt()
val idKey = json.getJSONObject(id).getInt("id")
val key = json.get(idKey).toString()
val idName = json.getJSONObject(id).getInt("name")
val name = json.get(idName).toString()
MangaTag(
key = key,
title = name,
source = source,
)
}
}
override suspend fun getDetails(manga: Manga): Manga = coroutineScope {
val doc = webClient.httpGet(manga.url.toAbsoluteUrl(domain)).parseHtml()
val chaptersDeferred = async { loadChapters(manga.url) }
val json = JSONArray(doc.requireElementById("__NUXT_DATA__").data())
val descId = json.getJSONObject(6).getInt("story")
val desc = json.getString(descId)
val tagsId = json.getJSONObject(6).getInt("genres")
val tagsList = json.getJSONArray(tagsId).toString().replace("[", "").replace("]", "").split(",")
val ratingId = json.getJSONObject(6).getInt("rating")
val rating = json.getString(ratingId)
val nsfwId = json.getJSONObject(6).getInt("nsfw")
val nsfw = json.getBoolean(nsfwId)
manga.copy(
description = desc,
tags = tagsList.mapToSet { idTag ->
val id = idTag.toInt()
val idKey = json.getJSONObject(id).getInt("id")
val key = json.get(idKey).toString()
val idName = json.getJSONObject(id).getInt("name")
val name = json.get(idName).toString()
MangaTag(
key = key,
title = name,
source = source,
)
},
rating = rating?.toFloatOrNull()?.div(5f) ?: RATING_UNKNOWN,
isNsfw = nsfw,
chapters = chaptersDeferred.await(),
)
}
private val dateFormat = SimpleDateFormat("yyyy-MM-dd", sourceLocale)
private suspend fun loadChapters(baseUrl: String): List<MangaChapter> {
val key = baseUrl.substringAfter("-").substringBefore("-")
val seriesKey = baseUrl.substringAfterLast("/").substringBefore("-")
val json = JSONArray(webClient.httpGet("https://api.$domain/api/v1/webtoon/chapters/$key-desc").parseRaw())
return json.mapJSONIndexed { i, j ->
val url = "https://$domain/read/webtoon/$seriesKey-${j.getString("id")}-${j.getString("slug")}"
val date = j.getString("createdAt").substringBeforeLast("T")
MangaChapter(
id = generateUid(url),
url = url,
name = j.getString("slug").replace("-", " "),
number = i + 1,
branch = null,
uploadDate = dateFormat.tryParse(date),
scanlator = null,
source = source,
)
}
}
override suspend fun getPages(chapter: MangaChapter): List<MangaPage> {
val fullUrl = chapter.url.toAbsoluteUrl(domain)
val doc = webClient.httpGet(fullUrl).parseHtml()
val json = JSONArray(doc.requireElementById("__NUXT_DATA__").data())
val chapterData = json.getJSONObject(6).getInt("chapterData")
val pageLocate = json.getJSONObject(chapterData).getInt("webtoon")
val pages = json.getJSONArray(pageLocate).toString().replace("[", "").replace("]", "").split(",")
return pages.map {
val id = it.toInt()
val url = "https://api.$domain/storage/" + json.getString(id)
MangaPage(
id = generateUid(url),
url = url,
preview = null,
source = source,
)
}
}
}

@ -0,0 +1,123 @@
package org.koitharu.kotatsu.parsers.site.ar
import okhttp3.Headers
import org.koitharu.kotatsu.parsers.MangaLoaderContext
import org.koitharu.kotatsu.parsers.MangaSourceParser
import org.koitharu.kotatsu.parsers.PagedMangaParser
import org.koitharu.kotatsu.parsers.config.ConfigKey
import org.koitharu.kotatsu.parsers.model.*
import org.koitharu.kotatsu.parsers.network.UserAgents
import org.koitharu.kotatsu.parsers.util.*
import java.util.*
@MangaSourceParser("MANGASTORM", "Manga Storm", "ar")
internal class MangaStorm(context: MangaLoaderContext) : PagedMangaParser(context, MangaSource.MANGASTORM, 30) {
override val sortOrders: Set<SortOrder> = EnumSet.of(SortOrder.POPULARITY)
override val configKeyDomain = ConfigKey.Domain("mangastorm.org")
override val headers: Headers = Headers.Builder()
.add("User-Agent", UserAgents.CHROME_DESKTOP)
.build()
override suspend fun getListPage(
page: Int,
query: String?,
tags: Set<MangaTag>?,
sortOrder: SortOrder,
): List<Manga> {
val tag = tags.oneOrThrowIfMany()
val url =
if (!tags.isNullOrEmpty()) {
buildString {
append("https://")
append(domain)
append("/categories/")
append(tag?.key.orEmpty())
append("?page=")
append(page)
}
} else {
buildString {
append("https://")
append(domain)
append("/mangas?page=")
append(page)
if (!query.isNullOrEmpty()) {
append("&query=")
append(query.urlEncoded())
}
}
}
val doc = webClient.httpGet(url).parseHtml()
return doc.select("div.row div.col").map { div ->
val href = div.selectFirstOrThrow("a").attrAsRelativeUrl("href")
Manga(
id = generateUid(href),
title = div.select(".manga-ct-title").text(),
altTitle = null,
url = href,
publicUrl = href.toAbsoluteUrl(domain),
rating = RATING_UNKNOWN,
isNsfw = false,
coverUrl = div.selectFirstOrThrow("img").src().orEmpty(),
tags = emptySet(),
state = null,
author = null,
source = source,
)
}
}
override suspend fun getTags(): Set<MangaTag> = emptySet()
override suspend fun getDetails(manga: Manga): Manga {
val doc = webClient.httpGet(manga.url.toAbsoluteUrl(domain)).parseHtml()
val root = doc.selectFirstOrThrow(".card-body .col-lg-9")
return manga.copy(
altTitle = null,
state = null,
tags = root.select(".flex-wrap a").mapNotNullToSet { a ->
MangaTag(
key = a.attr("href").substringAfterLast('/'),
title = a.text(),
source = source,
)
},
author = null,
description = root.selectFirstOrThrow(".card-text").text(),
chapters = doc.select(".card-body a.btn-fixed-width").mapChapters(reversed = true) { i, a ->
val url = a.attrAsRelativeUrl("href")
MangaChapter(
id = generateUid(url),
name = a.text(),
number = i + 1,
url = url,
scanlator = null,
uploadDate = 0,
branch = null,
source = source,
)
},
)
}
override suspend fun getPages(chapter: MangaChapter): List<MangaPage> {
val fullUrl = chapter.url.toAbsoluteUrl(domain)
val doc = webClient.httpGet(fullUrl).parseHtml().requireElementById("content")
return doc.select("div.text-center .img-fluid").map { img ->
val url = img.src()?.toRelativeUrl(domain) ?: img.parseFailed("Image src not found")
MangaPage(
id = generateUid(url),
url = url,
preview = null,
source = source,
)
}
}
}

@ -49,6 +49,10 @@ internal class LugnicaScans(context: MangaLoaderContext) : PagedMangaParser(cont
sortOrder: SortOrder,
): List<Manga> {
if (!query.isNullOrEmpty()) {
return emptyList()
}
if (sortOrder == SortOrder.ALPHABETICAL) {
if (page > 1) {

@ -33,9 +33,8 @@ internal abstract class MadaraParser(
protected open val tagPrefix = "manga-genre/"
protected open val datePattern = "MMMM d, yyyy"
protected open val stylepage = "?style=list"
protected open val postreq = false
protected open val stylePage = "?style=list"
protected open val postReq = false
init {
paginator.firstPage = 0
@ -52,7 +51,6 @@ internal abstract class MadaraParser(
parseFailed("Cannot find tableValue for node ${text()}")
}
@JvmField
protected val ongoing: Set<String> = hashSetOf(
"مستمرة",
@ -358,7 +356,7 @@ internal abstract class MadaraParser(
return doc.body().select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirst("a")
val href = a?.attrAsRelativeUrlOrNull("href") ?: li.parseFailed("Link is missing")
val link = href + stylepage
val link = href + stylePage
val dateText = li.selectFirst("a.c-new-tag")?.attr("title") ?: li.selectFirst(selectDate)?.text()
val name = a.selectFirst("p")?.text() ?: a.ownText()
MangaChapter(
@ -378,8 +376,7 @@ internal abstract class MadaraParser(
}
protected open suspend fun loadChapters(mangaUrl: String, document: Document): List<MangaChapter> {
val doc = if (postreq) {
val doc = if (postReq) {
val mangaId = document.select("div#manga-chapters-holder").attr("data-id")
val url = "https://$domain/wp-admin/admin-ajax.php"
val postdata = "action=manga_get_chapters&manga=$mangaId"
@ -388,13 +385,11 @@ internal abstract class MadaraParser(
val url = mangaUrl.toAbsoluteUrl(domain).removeSuffix('/') + "/ajax/chapters/"
webClient.httpPost(url, emptyMap()).parseHtml()
}
val dateFormat = SimpleDateFormat(datePattern, sourceLocale)
return doc.select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirst("a")
val href = a?.attrAsRelativeUrlOrNull("href") ?: li.parseFailed("Link is missing")
val link = href + stylepage
val link = href + stylePage
val dateText = li.selectFirst("a.c-new-tag")?.attr("title") ?: li.selectFirst(selectDate)?.text()
val name = a.selectFirst("p")?.text() ?: a.ownText()
MangaChapter(
@ -413,13 +408,35 @@ internal abstract class MadaraParser(
}
}
override suspend fun getRelatedManga(seed: Manga): List<Manga> {
val doc = webClient.httpGet(seed.url.toAbsoluteUrl(domain)).parseHtml()
val root = doc.body().selectFirstOrThrow(".related-manga")
return root.select("div.related-reading-wrap").mapNotNull { div ->
val a = div.selectFirst("a") ?: return@mapNotNull null
val href = a.attrAsRelativeUrl("href")
Manga(
id = generateUid(href),
url = href,
publicUrl = href.toAbsoluteUrl(a.host ?: domain),
altTitle = null,
title = div.selectFirstOrThrow(".widget-title").text(),
author = null,
coverUrl = div.selectFirst("img")?.src().orEmpty(),
tags = emptySet(),
rating = RATING_UNKNOWN,
state = null,
isNsfw = isNsfwSource,
source = source,
)
}
}
protected open val selectBodyPage = "div.main-col-inner div.reading-content"
protected open val selectPage = "div.page-break, div.login-required"
override suspend fun getPages(chapter: MangaChapter): List<MangaPage> {
val fullUrl = chapter.url.toAbsoluteUrl(domain)
val doc = webClient.httpGet(fullUrl).parseHtml()
val chapterProtector = doc.getElementById("chapter-protector-data")
if (chapterProtector == null) {
val root = doc.body().selectFirstOrThrow(selectBodyPage)

@ -21,7 +21,7 @@ internal class Ero18x(context: MangaLoaderContext) :
return doc.body().select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirstOrThrow("a")
val href = a.attrAsRelativeUrl("href")
val link = href + stylepage
val link = href + stylePage
val dateText = li.selectFirst("a.c-new-tag")?.attr("title") ?: li.selectFirst(selectDate)?.text()
val name = a.selectFirst("p")?.text() ?: a.ownText()
MangaChapter(

@ -12,5 +12,5 @@ internal class MangaTop(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGATOP, "mangatop.site") {
override val datePattern = "d MMMM yyyy"
override val sourceLocale: Locale = Locale.ENGLISH
override val stylepage = ""
override val stylePage = ""
}

@ -27,7 +27,7 @@ internal class ManhwaRaw(context: MangaLoaderContext) :
return doc.body().select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirst("a")
val href = a?.attrAsRelativeUrlOrNull("href") ?: li.parseFailed("Link is missing")
val link = href + stylepage
val link = href + stylePage
val dateText = li.selectFirst("a.c-new-tag")?.attr("title") ?: li.selectFirst(selectDate)?.text()
val name = a.selectFirst("p")?.text() ?: a.ownText()

@ -10,7 +10,7 @@ import java.util.Locale
@MangaSourceParser("MANYTOON_CLUB", "Many Toon .Club", "", ContentType.HENTAI)
internal class ManyToonClub(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANYTOON_CLUB, "manytoon.club") {
override val postreq = true
override val postReq = true
override val listUrl = "manhwa-raw/"
override val tagPrefix = "manhwa-raw-genre/"
override val sourceLocale: Locale = Locale.ENGLISH

@ -8,7 +8,7 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("GATEMANGA", "Gate Manga", "ar")
internal class GateManga(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.GATEMANGA, "gatemanga.com") {
override val postreq = true
override val postReq = true
override val datePattern = "d MMMM، yyyy"
override val listUrl = "ar/"
override val withoutAjax = true

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
internal class MangaLeks(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGALEKS, "mangaleks.com") {
override val datePattern = "yyyy/MM/dd"
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
internal class Manga_Lek(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGA_LEK, "manga-lek.com") {
override val listUrl = "mangalek/"
override val postreq = true
override val postReq = true
}

@ -8,6 +8,6 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGARBIC", "Mangarbic", "ar")
internal class Mangarbic(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGARBIC, "mangarabic.com") {
override val postreq = true
override val postReq = true
override val datePattern = "yyyy/MM/dd"
}

@ -8,6 +8,6 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGASPARK", "Manga Spark", "ar")
internal class Mangaspark(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGASPARK, "mangaspark.org", pageSize = 10) {
override val postreq = true
override val postReq = true
override val datePattern = "d MMMM، yyyy"
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("NIJITRANSLATIONS", "Niji Translations", "ar")
internal class NijiTranslations(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.NIJITRANSLATIONS, "niji-translations.com") {
override val postreq = true
override val postReq = true
}

@ -10,5 +10,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
internal class AdultWebtoon(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.ADULT_WEBTOON, "adultwebtoon.com") {
override val tagPrefix = "adult-webtoon-genre/"
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
internal class Astrallibrary(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.ASTRALLIBRARY, "astrallibrary.net", 18) {
override val datePattern = "dd MMM"
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("BLOG_MANGA", "Blog Manga", "en")
internal class BlogManga(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.BLOG_MANGA, "blogmanga.net") {
override val postreq = true
override val postReq = true
}

@ -11,5 +11,5 @@ internal class BoysLove(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.BOYS_LOVE, "boyslove.me", 20) {
override val tagPrefix = "boyslove-genre/"
override val listUrl = "boyslove/"
override val postreq = true
override val postReq = true
}

@ -110,7 +110,7 @@ internal class CoffeeMangaTop(context: MangaLoaderContext) :
return doc.select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirst("a")
val href = a?.attrAsRelativeUrlOrNull("href") ?: li.parseFailed("Link is missing")
val link = href + stylepage
val link = href + stylePage
MangaChapter(
id = generateUid(href),
url = link,

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("CREEPYSCANS", "Creepy Scans", "en")
internal class CreepyScans(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.CREEPYSCANS, "creepyscans.com") {
override val stylepage = ""
override val stylePage = ""
}

@ -9,7 +9,7 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("FREECOMICONLINE", "Free Comic Online", "en", ContentType.HENTAI)
internal class FreeComicOnline(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.FREECOMICONLINE, "freecomiconline.me") {
override val postreq = true
override val postReq = true
override val listUrl = "comic/"
override val tagPrefix = "comic-genre/"
}

@ -10,5 +10,5 @@ internal class GourmetScans(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.GOURMETSCANS, "gourmetscans.net") {
override val listUrl = "project/"
override val tagPrefix = "genre/"
override val stylepage = ""
override val stylePage = ""
}

@ -12,5 +12,5 @@ internal class HManhwa(context: MangaLoaderContext) :
override val tagPrefix = "manhwa-genre/"
override val listUrl = "manhwa/"
override val datePattern = "dd MMM"
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("HENTAIMANGA", "Hentai Manga", "en", ContentType.HENTAI)
internal class HentaiManga(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.HENTAIMANGA, "hentaimanga.me", 36) {
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("HENTAIWEBTOON", "Hentai Webtoon", "en", ContentType.HENTAI)
internal class HentaiWebtoon(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.HENTAIWEBTOON, "hentaiwebtoon.com") {
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("HENTAIXCOMIC", "Hentai x Comic", "en", ContentType.HENTAI)
internal class HentaixComic(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.HENTAIXCOMIC, "hentaixcomic.com", 16) {
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("HENTAIXYURI", "Hentai x Yuri", "en", ContentType.HENTAI)
internal class HentaixYuri(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.HENTAIXYURI, "hentaixyuri.com", 16) {
override val postreq = true
override val postReq = true
}

@ -14,15 +14,15 @@ import java.text.SimpleDateFormat
@MangaSourceParser("HENTAIXDICKGIRL", "Hentai x Dickgirl", "en", ContentType.HENTAI)
internal class Hentaixdickgirl(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.HENTAIXDICKGIRL, "hentaixdickgirl.com", 16) {
override val postReq = true
override val postreq = true
override suspend fun getChapters(manga: Manga, doc: Document): List<MangaChapter> {
val root2 = doc.body().selectFirstOrThrow("div.listing-chapters_wrap")
val dateFormat = SimpleDateFormat(datePattern, sourceLocale)
return root2.select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirst("a")
val href = a?.attrAsRelativeUrlOrNull("href") ?: li.parseFailed("Link is missing")
val link = href + stylepage
val link = href + stylePage
val dateText = li.selectFirst("a.c-new-tag")?.attr("title") ?: li.selectFirst(selectDate)?.text()
val name = a.selectFirst("p")?.text() ?: a.ownText()
MangaChapter(

@ -14,7 +14,7 @@ internal class InstaManhwa(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.INSTAMANHWA, "www.instamanhwa.com", 15) {
override val tagPrefix = "genre/"
override val listUrl = "latest/"
override val postreq = true
override val postReq = true
override val datePattern = "d MMMM, yyyy"
override val sortOrders: Set<SortOrder> = EnumSet.of(
@ -113,7 +113,7 @@ internal class InstaManhwa(context: MangaLoaderContext) :
return doc.select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirst("a")
val href = a?.attrAsRelativeUrlOrNull("href") ?: li.parseFailed("Link is missing")
val link = href + stylepage
val link = href + stylePage
val dateText = li.selectFirst("a.c-new-tag")?.attr("title") ?: li.selectFirst(selectDate)?.text()
val name = a.selectFirst("p")?.text() ?: a.ownText()
MangaChapter(

@ -113,7 +113,7 @@ internal class IsekaiScan(context: MangaLoaderContext) :
return doc.select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirst("a")
val href = a?.attrAsRelativeUrlOrNull("href") ?: li.parseFailed("Link is missing")
val link = href + stylepage
val link = href + stylePage
MangaChapter(
id = generateUid(href),
url = link,

@ -9,6 +9,6 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("LOLICONMOBI", "Lolicon Mobi", "en", ContentType.HENTAI)
internal class LoliconMobi(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.LOLICONMOBI, "lolicon.mobi") {
override val postreq = true
override val postReq = true
override val tagPrefix = "lolicon-genre/"
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGABOB", "Manga Bob", "en")
internal class MangaBob(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGABOB, "mangabob.com") {
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
internal class MangaClashTv(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGACLASH_TV, "mangaclash.tv", pageSize = 10) {
override val datePattern = "MM/dd/yyyy"
override val postreq = true
override val postReq = true
}

@ -146,7 +146,7 @@ internal class MangaDass(context: MangaLoaderContext) :
return root2.select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirst("a")
val href = a?.attrAsRelativeUrlOrNull("href") ?: li.parseFailed("Link is missing")
val link = href + stylepage
val link = href + stylePage
val dateText = li.selectFirst("a.c-new-tag")?.attr("title") ?: li.selectFirst(selectDate)?.text()
val name = a.selectFirst("p")?.text() ?: a.ownText()
MangaChapter(

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGADINOTOP", "Manga Dino", "en")
internal class MangaDinoTop(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGADINOTOP, "mangadino.top", 10) {
override val postreq = true
override val postReq = true
}

@ -144,7 +144,7 @@ internal class MangaDna(context: MangaLoaderContext) :
return root2.select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirst("a")
val href = a?.attrAsRelativeUrlOrNull("href") ?: li.parseFailed("Link is missing")
val link = href + stylepage
val link = href + stylePage
val dateText = li.selectFirst("a.c-new-tag")?.attr("title") ?: li.selectFirst(selectDate)?.text()
val name = a.selectFirst("p")?.text() ?: a.ownText()
MangaChapter(

@ -9,6 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGAFORFREE", "Manga For Free", "en", ContentType.HENTAI)
internal class MangaForFree(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGAFORFREE, "mangaforfree.com", 10) {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGAFOXFULL", "Manga Fox Full", "en")
internal class MangaFoxFull(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGAFOXFULL, "mangafoxfull.com") {
override val postreq = true
override val postReq = true
}

@ -8,6 +8,6 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGAFREAK", "Manga Freak", "en")
internal class MangaFreak(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGAFREAK, "mangafreak.online") {
override val postreq = true
override val postReq = true
override val datePattern = "dd MMMM، yyyy"
}

@ -8,7 +8,7 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGALEVELING", "Manga Leveling", "en")
internal class MangaLeveling(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGALEVELING, "mangaleveling.com", 30) {
override val postreq = true
override val postReq = true
override val tagPrefix = "comics-genre/"
override val listUrl = "comics/"
override val datePattern = "MM/dd/yyyy"

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGAOWLBLOG", "MangaOwl .Blog", "en", ContentType.HENTAI)
internal class MangaOwlBlog(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGAOWLBLOG, "mangaowl.blog", 20) {
override val postreq = true
override val postReq = true
}

@ -112,7 +112,7 @@ internal class MangaPure(context: MangaLoaderContext) :
return doc.select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirst("a")
val href = a?.attrAsRelativeUrlOrNull("href") ?: li.parseFailed("Link is missing")
val link = href + stylepage
val link = href + stylePage
MangaChapter(
id = generateUid(href),
url = link,

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGARAWINFO", "Manga-Raw .Info", "en")
internal class MangaRawInfo(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGARAWINFO, "manga-raw.info", 20) {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGAROCKY", "Manga Rocky", "en")
internal class MangaRocky(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGAROCKY, "mangarocky.com") {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGAUPDATESTOP", "Manga Updates .Top", "en")
internal class MangaUpdatesTop(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGAUPDATESTOP, "mangaupdates.top", 10) {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGANELO", "Manga Nelo", "en")
internal class Manganelo(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGANELO, "manganelo.biz", 10) {
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGAOWL_ONE", "MangaOwl .One", "en", ContentType.HENTAI)
internal class MangaowlOne(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGAOWL_ONE, "mangaowl.one") {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANGAX1", "MangaX1", "en")
internal class Mangax1(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGAX1, "mangax1.com") {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANHUASCANINFO", "Manhua Scan .Info", "en")
internal class ManhuaScanInfo(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANHUASCANINFO, "manhuascan.info", 10) {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANHUAES", "Manhuaes", "en")
internal class Manhuaes(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANHUAES, "manhuaes.com") {
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANHWA18APP", "Manhwa18 .App", "en", ContentType.HENTAI)
internal class Manhwa18App(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANHWA18APP, "manhwa18.app") {
override val postreq = true
override val postReq = true
}

@ -9,6 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANHWA18ORG", "Manhwa18 .Org", "en", ContentType.HENTAI)
internal class Manhwa18Org(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANHWA18ORG, "manhwa18.org") {
override val postreq = true
override val postReq = true
}

@ -9,7 +9,7 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANHWARAW_COM", "Manhwa Raw .Com", "en", ContentType.HENTAI)
internal class ManhwaRawCom(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANHWARAW_COM, "manhwaraw.com") {
override val postreq = true
override val postReq = true
override val listUrl = "manhwa-raw/"
override val tagPrefix = "manhwa-raw-genre/"
}

@ -13,7 +13,7 @@ import java.text.SimpleDateFormat
internal class ManhwaTop(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANHWATOP, "manhwatop.com") {
override val postreq = true
override val postReq = true
override suspend fun loadChapters(mangaUrl: String, document: Document): List<MangaChapter> {
@ -27,7 +27,7 @@ internal class ManhwaTop(context: MangaLoaderContext) :
return doc.select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirst("a")
val href = a?.attrAsRelativeUrlOrNull("href") ?: li.parseFailed("Link is missing")
val link = href + stylepage
val link = href + stylePage
val dateText = li.selectFirst("a.c-new-tag")?.attr("title") ?: li.selectFirst(selectDate)?.text()
val name = a.selectFirst("p")?.text() ?: a.ownText()
val dateText2 = if (dateText != "Complete") {

@ -9,6 +9,6 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MANYCOMIC", "Many Comic", "en", ContentType.HENTAI)
internal class ManyComic(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANYCOMIC, "manycomic.com") {
override val postreq = true
override val postReq = true
override val tagPrefix = "comic-genre/"
}

@ -9,6 +9,6 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MILFTOON", "Milf Toon", "en", ContentType.HENTAI)
internal class MilfToon(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MILFTOON, "milftoon.xxx", 20) {
override val postreq = true
override val postReq = true
override val datePattern = "d MMMM, yyyy"
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("MORTALSGROOVE", "Mortals Groove", "en")
internal class MortalsGroove(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MORTALSGROOVE, "mortalsgroove.com") {
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
internal class MurimScan(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MURIMSCAN, "murimscan.run", 100) {
override val withoutAjax = true
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("NIGHTCOMIC", "Night Comic", "en")
internal class NightComic(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.NIGHTCOMIC, "www.nightcomic.com") {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("NOVELMIC", "Novel Mic", "en")
internal class Novelmic(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.NOVELMIC, "novelmic.com", 20) {
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("PETROTECHSOCIETY", "PetrotechSociety", "en", ContentType.HENTAI)
internal class PetrotechSociety(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.PETROTECHSOCIETY, "www.petrotechsociety.org", pageSize = 10) {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("PLATINUMSCANS", "Platinum Scans", "en")
internal class PlatinumScans(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.PLATINUMSCANS, "platinumscans.com", pageSize = 10) {
override val postreq = true
override val postReq = true
}

@ -9,6 +9,6 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("READMANHUA", "Read Manhua", "en", ContentType.HENTAI)
internal class ReadManhua(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.READMANHUA, "readmanhua.net", 20) {
override val postreq = true
override val postReq = true
override val datePattern = "d MMM yy"
}

@ -0,0 +1,12 @@
package org.koitharu.kotatsu.parsers.site.madara.en
import org.koitharu.kotatsu.parsers.MangaLoaderContext
import org.koitharu.kotatsu.parsers.MangaSourceParser
import org.koitharu.kotatsu.parsers.model.MangaSource
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("SECTSCANS", "Sect Scans", "en")
internal class SectScans(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.SECTSCANS, "sectscans.com") {
override val listUrl = "comics/"
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("STKISSMANGABLOG", "StkissManga .Blog", "en")
internal class StkissMangaBlog(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.STKISSMANGABLOG, "1stkissmanga.blog", 10) {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("STKISSMANGA_TV", "1stKissManga .Tv", "en")
internal class StkissMangaTv(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.STKISSMANGA_TV, "1stkissmanga.tv", 20) {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("THEGUILDSCANS", "The Guild Scans", "en")
internal class Theguildscans(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.THEGUILDSCANS, "theguildscans.com") {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("WEBCOMIC", "WebComic", "en")
internal class WebComic(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.WEBCOMIC, "webcomic.me") {
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
internal class Webtoon(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.WEBTOON, "webtoon.uk", 20) {
override val tagPrefix = "manhwa-genre/"
override val postreq = true
override val postReq = true
}

@ -10,5 +10,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
internal class Webtoons(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.WEBTOONS, "webtoons.top", 20) {
override val listUrl = "read/"
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("YAOIMOBI", "Yaoi .Mobi", "en", ContentType.HENTAI)
internal class YaoiMobi(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.YAOIMOBI, "yaoi.mobi") {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("ZUTTOMANGA", "Zutto Manga", "en")
internal class ZuttoManga(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.ZUTTOMANGA, "zuttomanga.com") {
override val postreq = true
override val postReq = true
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("KOINOBORISCAN", "Koinobori Scan", "es")
internal class KoinoboriScan(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.KOINOBORISCAN, "koinoboriscan.com") {
override val postreq = true
override val postReq = true
}

@ -20,7 +20,7 @@ internal class ManhwaEs(context: MangaLoaderContext) :
return doc.body().select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirstOrThrow("a")
val href = a.attrAsRelativeUrl("href")
val link = href + stylepage
val link = href + stylePage
val dateText = li.selectFirst("a.c-new-tag")?.attr("title") ?: li.selectFirst(selectDate)?.text()
val name = li.selectFirstOrThrow(".mini-letters a").text()

@ -24,7 +24,7 @@ internal class ManhwaLatino(context: MangaLoaderContext) :
return root2.select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirst("a")
val href = a?.attrAsRelativeUrlOrNull("href") ?: li.parseFailed("Link is missing")
val link = href + stylepage
val link = href + stylePage
val dateText = li.selectFirst("a.c-new-tag")?.attr("title") ?: li.selectFirst(selectDate)?.text()
val dateText2 = if (dateText == "¡Recién publicado!") {
"1 mins ago"

@ -8,7 +8,7 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("RAGNAROKSCAN", "Ragnarok Scan", "es")
internal class RagnarokScan(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.RAGNAROKSCAN, "ragnarokscan.com") {
override val stylepage = ""
override val stylePage = ""
override val listUrl = "series/"
override val tagPrefix = "genero/"
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("STICKHORSE", "Stickhorse", "es")
internal class Stickhorse(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.STICKHORSE, "www.stickhorse.cl") {
override val postreq = true
override val postReq = true
}

@ -86,7 +86,7 @@ internal class TmoManga(context: MangaLoaderContext) :
return doc.body().select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirstOrThrow("a")
val href = a.attrAsRelativeUrl("href")
val link = href + stylepage
val link = href + stylePage
val name = a.selectFirst("p")?.text() ?: a.ownText()
MangaChapter(
id = generateUid(href),

@ -4,7 +4,10 @@ import org.koitharu.kotatsu.parsers.MangaLoaderContext
import org.koitharu.kotatsu.parsers.MangaSourceParser
import org.koitharu.kotatsu.parsers.model.MangaSource
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
import java.util.Locale
@MangaSourceParser("FRSCAN", "Fr-Scan", "fr")
internal class FrScan(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.FRSCAN, "fr-scan.cc")
MadaraParser(context, MangaSource.FRSCAN, "fr-scan.cc") {
override val sourceLocale: Locale = Locale.ENGLISH
}

@ -11,5 +11,5 @@ internal class Kataitake(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.KATAITAKE, "www.kataitake.fr", 10) {
override val datePattern = "dd/MM/yyyy"
override val tagPrefix = "genre/"
override val postreq = true
override val postReq = true
}

@ -10,5 +10,5 @@ internal class GourmetScansId(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.GOURMETSCANS_ID, "id.gourmetscans.net") {
override val listUrl = "project/"
override val tagPrefix = "genre/"
override val stylepage = ""
override val stylePage = ""
}

@ -12,6 +12,6 @@ internal class Mgkomik(context: MangaLoaderContext) :
override val tagPrefix = "genres/"
override val listUrl = "komik/"
override val datePattern = "dd MMM yy"
override val stylepage = ""
override val stylePage = ""
override val sourceLocale: Locale = Locale.ENGLISH
}

@ -153,7 +153,7 @@ internal class HachiManga(context: MangaLoaderContext) : MadaraParser(context, M
return root2.select(selectChapter).mapChapters(reversed = true) { i, li ->
val a = li.selectFirst("a")
val href = a?.attrAsRelativeUrlOrNull("href") ?: li.parseFailed("Link is missing")
val link = href + stylepage
val link = href + stylePage
val dateText = li.selectFirst("a.c-new-tag")?.attr("title") ?: li.selectFirst(selectDate)?.text()
val name = a.selectFirst("p")?.text() ?: a.ownText()
MangaChapter(

@ -11,5 +11,5 @@ internal class AkumanoTenshi(context: MangaLoaderContext) :
override val listUrl = "series/"
override val tagPrefix = "series-genre/"
override val datePattern = "dd/MM/yyyy"
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
internal class CafecomYaoi(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.CAFECOMYAOI, "cafecomyaoi.com.br") {
override val datePattern = "dd/MM/yyyy"
override val postreq = true
override val postReq = true
}

@ -9,6 +9,6 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("PIRULITOROSA", "Pirulitorosa", "pt", ContentType.HENTAI)
internal class Pirulitorosa(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.PIRULITOROSA, "pirulitorosa.site") {
override val postreq = true
override val postReq = true
override val datePattern: String = "dd/MM/yyyy"
}

@ -8,5 +8,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("WICKEDWITCHSCAN", "WickedWitch Scan", "pt")
internal class WickedWitchScan(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.WICKEDWITCHSCAN, "wickedwitchscan.com", pageSize = 10) {
override val postreq = true
override val postReq = true
}

@ -8,6 +8,6 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("ZEROSCAN", "Zero Scan", "pt")
internal class ZeroScan(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.ZEROSCAN, "zeroscan.com.br") {
override val postreq = true
override val postReq = true
override val datePattern: String = "dd/MM/yyyy"
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
internal class BestManga(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.BEST_MANGA, "bestmanga.club") {
override val datePattern = "dd.MM.yyyy"
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
internal class MangaMammy(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGAMAMMY, "mangamammy.ru") {
override val datePattern = "dd.MM.yyyy"
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
internal class MangaoneLove(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.MANGAONELOVE, "mangaonelove.site", 10) {
override val datePattern = "dd.MM.yyyy"
override val postreq = true
override val postReq = true
}

@ -8,6 +8,6 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("KINGS_MANGA", "Kings Manga", "th")
internal class KingsManga(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.KINGS_MANGA, "www.kings-manga.co") {
override val postreq = true
override val postReq = true
override val datePattern = "d MMMM yyyy"
}

@ -8,6 +8,6 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("NEKOPOST", "Neko Post", "th")
internal class NekoPost(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.NEKOPOST, "www.nekopost.co") {
override val postreq = true
override val postReq = true
override val datePattern = "d MMMM yyyy"
}

@ -10,5 +10,5 @@ internal class Anikiga(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.ANIKIGA, "anikiga.com") {
override val tagPrefix = "manga-tur/"
override val datePattern = "d MMMM yyyy"
override val postreq = true
override val postReq = true
}

@ -9,5 +9,5 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
internal class ArazNovel(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.ARAZNOVEL, "araznovel.com", 10) {
override val datePattern = "d MMMM yyyy"
override val postreq = true
override val postReq = true
}

@ -8,7 +8,7 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("CIZGIROMANARSIVI", "Cizgiromanarsivi", "tr")
internal class Cizgiromanarsivi(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.CIZGIROMANARSIVI, "cizgiromanarsivi.com", 24) {
override val stylepage = ""
override val stylePage = ""
override val tagPrefix = "kategori/"
override val listUrl = "seri/"
override val datePattern = "dd.MM.yyyy"

@ -8,7 +8,7 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("ESOMANGA", "Eso Manga", "tr")
internal class EsoManga(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.ESOMANGA, "esomanga.com", 10) {
override val postreq = true
override val postReq = true
override val datePattern = "dd/MM/yyyy"
override val tagPrefix = "manga-kategoriler/"
}

@ -9,6 +9,6 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("JIANGZAITOON", "Jiangzaitoon", "tr", ContentType.HENTAI)
internal class Jiangzaitoon(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.JIANGZAITOON, "jiangzaitoon.cc") {
override val postreq = true
override val postReq = true
override val datePattern = "d MMMM yyyy"
}

@ -8,6 +8,6 @@ import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
@MangaSourceParser("TIMENAIGHT", "Timenaight", "tr")
internal class Timenaight(context: MangaLoaderContext) :
MadaraParser(context, MangaSource.TIMENAIGHT, "timenaight.com") {
override val postreq = true
override val postReq = true
override val datePattern = "dd/MM/yyyy"
}

Some files were not shown because too many files have changed in this diff Show More

Loading…
Cancel
Save