mirror of
https://github.com/hexated/cloudstream-extensions-hexated.git
synced 2024-08-15 00:03:22 +00:00
Nodrakorid: fix missing episode
This commit is contained in:
parent
eb1a1ff98e
commit
4f4d9f63de
2 changed files with 122 additions and 2 deletions
|
@ -1,5 +1,5 @@
|
||||||
// use an integer for version numbers
|
// use an integer for version numbers
|
||||||
version = 3
|
version = 4
|
||||||
|
|
||||||
|
|
||||||
cloudstream {
|
cloudstream {
|
||||||
|
|
|
@ -1,6 +1,12 @@
|
||||||
package com.hexated
|
package com.hexated
|
||||||
|
|
||||||
import com.lagradost.cloudstream3.mainPageOf
|
import com.fasterxml.jackson.annotation.JsonProperty
|
||||||
|
import com.lagradost.cloudstream3.*
|
||||||
|
import com.lagradost.cloudstream3.utils.*
|
||||||
|
import com.lagradost.cloudstream3.utils.AppUtils.toJson
|
||||||
|
import com.lagradost.cloudstream3.utils.AppUtils.tryParseJson
|
||||||
|
import org.jsoup.nodes.Element
|
||||||
|
import java.net.URI
|
||||||
|
|
||||||
class Nodrakorid : DutaMovie() {
|
class Nodrakorid : DutaMovie() {
|
||||||
override var mainUrl = "https://no-drak-or.xyz"
|
override var mainUrl = "https://no-drak-or.xyz"
|
||||||
|
@ -13,4 +19,118 @@ class Nodrakorid : DutaMovie() {
|
||||||
"genre/c-drama/c-drama-c-drama/page/%d/" to "Drama China",
|
"genre/c-drama/c-drama-c-drama/page/%d/" to "Drama China",
|
||||||
"genre/thai-drama/page/%d/" to "Drama Thailand",
|
"genre/thai-drama/page/%d/" to "Drama Thailand",
|
||||||
)
|
)
|
||||||
|
|
||||||
|
override suspend fun load(url: String): LoadResponse {
|
||||||
|
return super.load(url).apply {
|
||||||
|
when (this) {
|
||||||
|
is TvSeriesLoadResponse -> {
|
||||||
|
val doc = app.get(url).document
|
||||||
|
this.comingSoon = false
|
||||||
|
this.episodes = doc.select("div.entry-content p:contains(Episode)").distinctBy {
|
||||||
|
it.text()
|
||||||
|
}.map { eps ->
|
||||||
|
val num = eps.text()
|
||||||
|
val endSibling = eps.nextElementSiblings().select("p:contains(Episode)").firstOrNull() ?: eps.nextElementSiblings().select("div.content-moviedata").firstOrNull()
|
||||||
|
val siblings = eps.nextElementSiblingsUntil(endSibling).map { ele ->
|
||||||
|
ele.ownText().filter { it.isDigit() }.toIntOrNull() to ele.select("a")
|
||||||
|
.map { it.attr("href") to it.text() }
|
||||||
|
}.filter { it.first != null }
|
||||||
|
Episode(siblings.toJson(), episode = num.filter { it.isDigit() }.toIntOrNull())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
override suspend fun loadLinks(
|
||||||
|
data: String,
|
||||||
|
isCasting: Boolean,
|
||||||
|
subtitleCallback: (SubtitleFile) -> Unit,
|
||||||
|
callback: (ExtractorLink) -> Unit
|
||||||
|
): Boolean {
|
||||||
|
return if (data.startsWith("[")) {
|
||||||
|
tryParseJson<ArrayList<LinkData>>(data)?.filter { it.first != 360 }?.map {
|
||||||
|
it.second.apmap { link ->
|
||||||
|
loadFixedExtractor(
|
||||||
|
fixEmbed(link.first, link.second),
|
||||||
|
it.first,
|
||||||
|
"$mainUrl/",
|
||||||
|
subtitleCallback,
|
||||||
|
callback
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
true
|
||||||
|
} else {
|
||||||
|
super.loadLinks(data, isCasting, subtitleCallback, callback)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun fixEmbed(url: String, server: String): String {
|
||||||
|
return when {
|
||||||
|
server.contains("streamsb", true) -> {
|
||||||
|
val host = getBaseUrl(url)
|
||||||
|
url.replace("$host/", "$host/e/")
|
||||||
|
}
|
||||||
|
|
||||||
|
server.contains("hxfile", true) -> {
|
||||||
|
val host = getBaseUrl(url)
|
||||||
|
val id = url.substringAfterLast("/")
|
||||||
|
"$host/embed-$id.html"
|
||||||
|
}
|
||||||
|
|
||||||
|
else -> url
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun getBaseUrl(url: String): String {
|
||||||
|
return URI(url).let {
|
||||||
|
"${it.scheme}://${it.host}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private suspend fun loadFixedExtractor(
|
||||||
|
url: String,
|
||||||
|
quality: Int?,
|
||||||
|
referer: String? = null,
|
||||||
|
subtitleCallback: (SubtitleFile) -> Unit,
|
||||||
|
callback: (ExtractorLink) -> Unit
|
||||||
|
) {
|
||||||
|
loadExtractor(url, referer, subtitleCallback) { link ->
|
||||||
|
callback.invoke(
|
||||||
|
ExtractorLink(
|
||||||
|
link.name,
|
||||||
|
link.name,
|
||||||
|
link.url,
|
||||||
|
link.referer,
|
||||||
|
if(link.isM3u8) link.quality else quality ?: Qualities.Unknown.value,
|
||||||
|
link.isM3u8,
|
||||||
|
link.headers,
|
||||||
|
link.extractorData
|
||||||
|
)
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun Element.nextElementSiblingsUntil(untilElement: Element?): List<Element> {
|
||||||
|
val siblings = mutableListOf<Element>()
|
||||||
|
var currentElement = this.nextElementSibling()
|
||||||
|
|
||||||
|
while (currentElement != null && currentElement != untilElement) {
|
||||||
|
siblings.add(currentElement)
|
||||||
|
currentElement = currentElement.nextElementSibling()
|
||||||
|
}
|
||||||
|
|
||||||
|
return siblings
|
||||||
|
}
|
||||||
|
|
||||||
|
data class LinkData(
|
||||||
|
@JsonProperty("first") var first: Int? = null,
|
||||||
|
@JsonProperty("second") var second: ArrayList<Second> = arrayListOf()
|
||||||
|
)
|
||||||
|
|
||||||
|
data class Second(
|
||||||
|
@JsonProperty("first") var first: String,
|
||||||
|
@JsonProperty("second") var second: String
|
||||||
|
)
|
||||||
}
|
}
|
Loading…
Reference in a new issue