multiples fix, remove dead source and add source
parent
a39d644094
commit
8278a8f5c3
@ -1,12 +1,10 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.animebootstrap.id
|
package org.koitharu.kotatsu.parsers.site.animebootstrap.id
|
||||||
|
|
||||||
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaSource
|
import org.koitharu.kotatsu.parsers.model.MangaSource
|
||||||
import org.koitharu.kotatsu.parsers.site.animebootstrap.AnimeBootstrapParser
|
import org.koitharu.kotatsu.parsers.site.animebootstrap.AnimeBootstrapParser
|
||||||
|
|
||||||
|
@MangaSourceParser("KOMIKZOID", "Komikzo Id", "id")
|
||||||
@MangaSourceParser("KOMIKZOID", "KomikzoId", "id")
|
|
||||||
internal class KomikzoId(context: MangaLoaderContext) :
|
internal class KomikzoId(context: MangaLoaderContext) :
|
||||||
AnimeBootstrapParser(context, MangaSource.KOMIKZOID, "komikzoid.xyz")
|
AnimeBootstrapParser(context, MangaSource.KOMIKZOID, "komikzoid.xyz")
|
||||||
|
|||||||
@ -1,156 +0,0 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.en
|
|
||||||
|
|
||||||
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("COMICASTLE", "Comicastle", "en")
|
|
||||||
internal class Comicastle(context: MangaLoaderContext) : PagedMangaParser(context, MangaSource.COMICASTLE, 42) {
|
|
||||||
|
|
||||||
override val sortOrders: Set<SortOrder> = EnumSet.of(SortOrder.POPULARITY, SortOrder.UPDATED)
|
|
||||||
|
|
||||||
override val configKeyDomain = ConfigKey.Domain("comicastle.org")
|
|
||||||
|
|
||||||
override val headers: Headers = Headers.Builder()
|
|
||||||
.add("User-Agent", UserAgents.CHROME_DESKTOP)
|
|
||||||
.build()
|
|
||||||
|
|
||||||
init {
|
|
||||||
paginator.firstPage = 0
|
|
||||||
searchPaginator.firstPage = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun getFavicons(): Favicons {
|
|
||||||
return Favicons(
|
|
||||||
listOf(
|
|
||||||
Favicon("https://$domain/assets/static/app-assets/images/logo/logo-primary.png", 54, null),
|
|
||||||
),
|
|
||||||
domain,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun getListPage(
|
|
||||||
page: Int,
|
|
||||||
query: String?,
|
|
||||||
tags: Set<MangaTag>?,
|
|
||||||
sortOrder: SortOrder,
|
|
||||||
): List<Manga> {
|
|
||||||
val tag = tags.oneOrThrowIfMany()
|
|
||||||
val doc = if (!query.isNullOrEmpty()) {
|
|
||||||
val url = buildString {
|
|
||||||
append("https://$domain/library/search/result/")
|
|
||||||
append(page + 1)
|
|
||||||
}
|
|
||||||
val postdata = "submit=Submit&search=" + query.urlEncoded()
|
|
||||||
webClient.httpPost(url, postdata).parseHtml()
|
|
||||||
} else if (!tags.isNullOrEmpty()) {
|
|
||||||
val url = buildString {
|
|
||||||
append("https://$domain/library/search/genre/")
|
|
||||||
append(page + 1)
|
|
||||||
}
|
|
||||||
val postdata = "submit=Submit&search=" + tag?.key.orEmpty()
|
|
||||||
webClient.httpPost(url, postdata).parseHtml()
|
|
||||||
} else {
|
|
||||||
val url = buildString {
|
|
||||||
append("https://$domain")
|
|
||||||
append("/library/")
|
|
||||||
when (sortOrder) {
|
|
||||||
SortOrder.POPULARITY -> append("popular/desc/")
|
|
||||||
SortOrder.UPDATED -> append("postdate/desc")
|
|
||||||
else -> append("postdate/desc")
|
|
||||||
}
|
|
||||||
append("/index/")
|
|
||||||
append(page * pageSize)
|
|
||||||
}
|
|
||||||
webClient.httpGet(url).parseHtml()
|
|
||||||
}
|
|
||||||
|
|
||||||
return doc.select("div.card-body div.match-height div.col-6")
|
|
||||||
.map { div ->
|
|
||||||
val href = div.selectFirstOrThrow("a").attrAsRelativeUrl("href")
|
|
||||||
Manga(
|
|
||||||
id = generateUid(href),
|
|
||||||
title = div.selectFirstOrThrow("p").text(),
|
|
||||||
altTitle = null,
|
|
||||||
url = href,
|
|
||||||
publicUrl = href.toAbsoluteUrl(domain),
|
|
||||||
rating = RATING_UNKNOWN,
|
|
||||||
isNsfw = false,
|
|
||||||
coverUrl = div.selectFirstOrThrow("img").attrAsAbsoluteUrl("data-src"),
|
|
||||||
tags = emptySet(),
|
|
||||||
state = null,
|
|
||||||
author = null,
|
|
||||||
source = source,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun getTags(): Set<MangaTag> {
|
|
||||||
val doc = webClient.httpGet("https://$domain/library/").parseHtml()
|
|
||||||
return doc.requireElementById("sidebar").selectFirstOrThrow(".card-body").select("button")
|
|
||||||
.mapNotNullToSet { button ->
|
|
||||||
MangaTag(
|
|
||||||
key = button.attr("value"),
|
|
||||||
title = button.text(),
|
|
||||||
source = source,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun getDetails(manga: Manga): Manga {
|
|
||||||
val root = webClient.httpGet(manga.url.toAbsoluteUrl(domain)).parseHtml()
|
|
||||||
return manga.copy(
|
|
||||||
altTitle = null,
|
|
||||||
state = when (root.selectFirstOrThrow(".card-body p span.mr-1 strong").text()) {
|
|
||||||
"Ongoing" -> MangaState.ONGOING
|
|
||||||
"Completed" -> MangaState.FINISHED
|
|
||||||
else -> null
|
|
||||||
},
|
|
||||||
tags = root.select("p:contains(Genre) ~ div form").mapNotNullToSet { form ->
|
|
||||||
MangaTag(
|
|
||||||
key = form.selectFirstOrThrow("input").attr("value"),
|
|
||||||
title = form.selectFirstOrThrow("button").text(),
|
|
||||||
source = source,
|
|
||||||
)
|
|
||||||
},
|
|
||||||
author = root.select("thead:contains(Writer) + tbody button").text(),
|
|
||||||
description = root.getElementById("comic-desc")?.text(),
|
|
||||||
chapters = root.select("div.card-body > .table-responsive tr a")
|
|
||||||
.mapChapters { i, a ->
|
|
||||||
val url = a.attrAsRelativeUrl("href")
|
|
||||||
val name = a.text()
|
|
||||||
MangaChapter(
|
|
||||||
id = generateUid(url),
|
|
||||||
name = name,
|
|
||||||
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()
|
|
||||||
|
|
||||||
return doc.selectFirstOrThrow(".card-content .form-control.pr-3").select("option").map { option ->
|
|
||||||
val url = option.attr("alt")
|
|
||||||
MangaPage(
|
|
||||||
id = generateUid(url),
|
|
||||||
url = url,
|
|
||||||
preview = null,
|
|
||||||
source = source,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,12 +1,10 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.fmreader.ja
|
package org.koitharu.kotatsu.parsers.site.fmreader.ja
|
||||||
|
|
||||||
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaSource
|
import org.koitharu.kotatsu.parsers.model.MangaSource
|
||||||
import org.koitharu.kotatsu.parsers.site.fmreader.FmreaderParser
|
import org.koitharu.kotatsu.parsers.site.fmreader.FmreaderParser
|
||||||
|
|
||||||
|
|
||||||
@MangaSourceParser("WELOMA", "Weloma", "ja")
|
@MangaSourceParser("WELOMA", "Weloma", "ja")
|
||||||
internal class Weloma(context: MangaLoaderContext) :
|
internal class Weloma(context: MangaLoaderContext) :
|
||||||
FmreaderParser(context, MangaSource.WELOMA, "weloma.art")
|
FmreaderParser(context, MangaSource.WELOMA, "weloma.art")
|
||||||
|
|||||||
@ -1,12 +1,10 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.foolslide.en
|
package org.koitharu.kotatsu.parsers.site.foolslide.en
|
||||||
|
|
||||||
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaSource
|
import org.koitharu.kotatsu.parsers.model.MangaSource
|
||||||
import org.koitharu.kotatsu.parsers.site.foolslide.FoolSlideParser
|
import org.koitharu.kotatsu.parsers.site.foolslide.FoolSlideParser
|
||||||
|
|
||||||
|
@MangaSourceParser("DEATHTOLLSCANS", "DeathToll Scans", "en")
|
||||||
@MangaSourceParser("DEATHTOLLSCANS", "Deathtollscans", "en")
|
|
||||||
internal class Deathtollscans(context: MangaLoaderContext) :
|
internal class Deathtollscans(context: MangaLoaderContext) :
|
||||||
FoolSlideParser(context, MangaSource.DEATHTOLLSCANS, "reader.deathtollscans.net", 26)
|
FoolSlideParser(context, MangaSource.DEATHTOLLSCANS, "reader.deathtollscans.net", 26)
|
||||||
|
|||||||
@ -1,12 +1,10 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.foolslide.en
|
package org.koitharu.kotatsu.parsers.site.foolslide.en
|
||||||
|
|
||||||
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaSource
|
import org.koitharu.kotatsu.parsers.model.MangaSource
|
||||||
import org.koitharu.kotatsu.parsers.site.foolslide.FoolSlideParser
|
import org.koitharu.kotatsu.parsers.site.foolslide.FoolSlideParser
|
||||||
|
|
||||||
|
@MangaSourceParser("READER_EVILFLOWERS", "Evil Flowers", "en")
|
||||||
@MangaSourceParser("READER_EVILFLOWERS", "Evilflowers", "en")
|
|
||||||
internal class ReaderEvilflowers(context: MangaLoaderContext) :
|
internal class ReaderEvilflowers(context: MangaLoaderContext) :
|
||||||
FoolSlideParser(context, MangaSource.READER_EVILFLOWERS, "reader.evilflowers.com")
|
FoolSlideParser(context, MangaSource.READER_EVILFLOWERS, "reader.evilflowers.com")
|
||||||
|
|||||||
@ -1,14 +0,0 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.foolslide.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.foolslide.FoolSlideParser
|
|
||||||
|
|
||||||
|
|
||||||
@MangaSourceParser("SILENTSKYSCANS", "Silent Sky Scans", "en")
|
|
||||||
internal class SilentskyScans(context: MangaLoaderContext) :
|
|
||||||
FoolSlideParser(context, MangaSource.SILENTSKYSCANS, "reader.silentsky-scans.net") {
|
|
||||||
override val pagination = false
|
|
||||||
}
|
|
||||||
@ -1,12 +0,0 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.foolslide.pl
|
|
||||||
|
|
||||||
|
|
||||||
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.foolslide.FoolSlideParser
|
|
||||||
|
|
||||||
|
|
||||||
@MangaSourceParser("ONEPIECENAKAMA", "Onepiecenakama", "pl")
|
|
||||||
internal class Onepiecenakama(context: MangaLoaderContext) :
|
|
||||||
FoolSlideParser(context, MangaSource.ONEPIECENAKAMA, "reader.onepiecenakama.pl")
|
|
||||||
@ -1,14 +1,12 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.ar
|
package org.koitharu.kotatsu.parsers.site.madara.ar
|
||||||
|
|
||||||
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaSource
|
import org.koitharu.kotatsu.parsers.model.MangaSource
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
@MangaSourceParser("FALCONMANGA", "FalconManga", "ar")
|
@MangaSourceParser("FALCONMANGA", "Falcon Manga", "ar")
|
||||||
internal class FalconManga(context: MangaLoaderContext) :
|
internal class FalconManga(context: MangaLoaderContext) :
|
||||||
MadaraParser(context, MangaSource.FALCONMANGA, "falconmanga.com") {
|
MadaraParser(context, MangaSource.FALCONMANGA, "falconmanga.com") {
|
||||||
|
|
||||||
override val datePattern = "d MMMM، yyyy"
|
override val datePattern = "d MMMM، yyyy"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,11 +1,10 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.ar
|
package org.koitharu.kotatsu.parsers.site.madara.ar
|
||||||
|
|
||||||
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaSource
|
import org.koitharu.kotatsu.parsers.model.MangaSource
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
@MangaSourceParser("KOLMANGA", "KolManga", "ar")
|
@MangaSourceParser("PEWPIECE", "PewPiece", "ar")
|
||||||
internal class KolManga(context: MangaLoaderContext) :
|
internal class PewPiece(context: MangaLoaderContext) :
|
||||||
MadaraParser(context, MangaSource.KOLMANGA, "kolmanga.com")
|
MadaraParser(context, MangaSource.PEWPIECE, "pewpiece.com")
|
||||||
@ -1,17 +1,14 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.en
|
package org.koitharu.kotatsu.parsers.site.madara.en
|
||||||
|
|
||||||
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.ContentType
|
import org.koitharu.kotatsu.parsers.model.ContentType
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaSource
|
import org.koitharu.kotatsu.parsers.model.MangaSource
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
|
||||||
@MangaSourceParser("ADULT_WEBTOON", "Adult Webtoon", "en", ContentType.HENTAI)
|
@MangaSourceParser("ADULT_WEBTOON", "Adult Webtoon", "en", ContentType.HENTAI)
|
||||||
internal class AdultWebtoon(context: MangaLoaderContext) :
|
internal class AdultWebtoon(context: MangaLoaderContext) :
|
||||||
MadaraParser(context, MangaSource.ADULT_WEBTOON, "adultwebtoon.com") {
|
MadaraParser(context, MangaSource.ADULT_WEBTOON, "adultwebtoon.com") {
|
||||||
|
|
||||||
override val tagPrefix = "adult-webtoon-genre/"
|
override val tagPrefix = "adult-webtoon-genre/"
|
||||||
override val postreq = true
|
override val postreq = true
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,10 +0,0 @@
|
|||||||
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("ARCHERSCANS", "ArcherScans", "en")
|
|
||||||
internal class ArcherScans(context: MangaLoaderContext) :
|
|
||||||
MadaraParser(context, MangaSource.ARCHERSCANS, "www.archerscans.com", 10)
|
|
||||||
@ -1,11 +1,13 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.en
|
package org.koitharu.kotatsu.parsers.site.madara.en
|
||||||
|
|
||||||
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaSource
|
import org.koitharu.kotatsu.parsers.model.MangaSource
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
@MangaSourceParser("RIO2MANGA", "Rio2Manga", "en")
|
@MangaSourceParser("HSCANS", "Hscans", "en")
|
||||||
internal class Rio2Manga(context: MangaLoaderContext) :
|
internal class Hscans(context: MangaLoaderContext) :
|
||||||
MadaraParser(context, MangaSource.RIO2MANGA, "rio2manga.com", 10)
|
MadaraParser(context, MangaSource.HSCANS, "hscans.com", 10) {
|
||||||
|
|
||||||
|
override val datePattern = "dd/MM/yyyy"
|
||||||
|
}
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue