forked from recloudstream/cloudstream
some small changes for akwam, mycima (#812)
* Update MyCimaProvider.kt * Update AkwamProvider.kt * ah
This commit is contained in:
parent
2cd65246fb
commit
035aa22626
2 changed files with 40 additions and 30 deletions
|
@ -2,7 +2,6 @@ package com.lagradost.cloudstream3.movieproviders
|
||||||
|
|
||||||
import com.lagradost.cloudstream3.*
|
import com.lagradost.cloudstream3.*
|
||||||
import com.lagradost.cloudstream3.LoadResponse.Companion.addActors
|
import com.lagradost.cloudstream3.LoadResponse.Companion.addActors
|
||||||
import com.lagradost.cloudstream3.network.AppResponse
|
|
||||||
import com.lagradost.cloudstream3.utils.ExtractorLink
|
import com.lagradost.cloudstream3.utils.ExtractorLink
|
||||||
import com.lagradost.cloudstream3.utils.Qualities
|
import com.lagradost.cloudstream3.utils.Qualities
|
||||||
import org.jsoup.nodes.Element
|
import org.jsoup.nodes.Element
|
||||||
|
@ -165,10 +164,10 @@ class AkwamProvider : MainAPI() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Maybe possible to not use the url shortener but cba investigating that.
|
// // Maybe possible to not use the url shortener but cba investigating that.
|
||||||
private suspend fun skipUrlShortener(url: String): AppResponse {
|
// private suspend fun skipUrlShortener(url: String): AppResponse {
|
||||||
return app.get(app.get(url).document.select("a.download-link").attr("href"))
|
// return app.get(app.get(url).document.select("a.download-link").attr("href"))
|
||||||
}
|
// }
|
||||||
|
|
||||||
private fun getQualityFromId(id: Int?): Qualities {
|
private fun getQualityFromId(id: Int?): Qualities {
|
||||||
return when (id) {
|
return when (id) {
|
||||||
|
@ -190,14 +189,15 @@ class AkwamProvider : MainAPI() {
|
||||||
|
|
||||||
val links = doc.select("div.tab-content.quality").map {
|
val links = doc.select("div.tab-content.quality").map {
|
||||||
val quality = getQualityFromId(it.attr("id").getIntFromText())
|
val quality = getQualityFromId(it.attr("id").getIntFromText())
|
||||||
it.select(".col-lg-6 > a").map { linkElement ->
|
it.select(".col-lg-6 > a:contains(تحميل)").map { linkElement ->
|
||||||
linkElement.attr("href") to quality
|
if(linkElement.attr("href").contains("/download/")) { linkElement.attr("href") to quality } else {
|
||||||
// Only uses the download links, primarily to prevent unnecessary duplicate requests.
|
"$mainUrl/download${linkElement.attr("href").split("/link")[1]}${data.split("/movie|/episode|/show/episode".toRegex())[1]}" to quality // just in case if they add the shorts urls again
|
||||||
}.filter { link -> link.first.contains("/link/") }
|
}
|
||||||
|
}
|
||||||
}.flatten()
|
}.flatten()
|
||||||
|
|
||||||
links.map {
|
links.map {
|
||||||
val linkDoc = skipUrlShortener(it.first).document
|
val linkDoc = app.get(it.first).document
|
||||||
val button = linkDoc.select("div.btn-loader > a")
|
val button = linkDoc.select("div.btn-loader > a")
|
||||||
val url = button.attr("href")
|
val url = button.attr("href")
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@ class MyCimaProvider : MainAPI() {
|
||||||
override var name = "MyCima"
|
override var name = "MyCima"
|
||||||
override val usesWebView = false
|
override val usesWebView = false
|
||||||
override val hasMainPage = true
|
override val hasMainPage = true
|
||||||
override val supportedTypes = setOf(TvType.TvSeries, TvType.Movie)
|
override val supportedTypes = setOf(TvType.TvSeries, TvType.Movie, TvType.Anime)
|
||||||
|
|
||||||
private fun String.getImageURL(): String? {
|
private fun String.getImageURL(): String? {
|
||||||
return this.replace("--im(age|g):url\\(|\\);".toRegex(), "")
|
return this.replace("--im(age|g):url\\(|\\);".toRegex(), "")
|
||||||
|
@ -63,9 +63,10 @@ class MyCimaProvider : MainAPI() {
|
||||||
override suspend fun search(query: String): List<SearchResponse> {
|
override suspend fun search(query: String): List<SearchResponse> {
|
||||||
val q = query.replace(" ","%20")
|
val q = query.replace(" ","%20")
|
||||||
val result = arrayListOf<SearchResponse>()
|
val result = arrayListOf<SearchResponse>()
|
||||||
listOf("$mainUrl/search/$q", "$mainUrl/search/$q/list/series/").apmap { url ->
|
listOf("$mainUrl/search/$q",
|
||||||
|
"$mainUrl/search/$q/list/series/",
|
||||||
|
"$mainUrl/search/$q/list/anime/").apmap { url ->
|
||||||
val d = app.get(url).document
|
val d = app.get(url).document
|
||||||
if(d.select("a.hoverable.active").text().contains("الانيمي و الكرتون")) return@apmap null
|
|
||||||
d.select("div.Grid--MycimaPosts div.GridItem").mapNotNull {
|
d.select("div.Grid--MycimaPosts div.GridItem").mapNotNull {
|
||||||
if(it.text().contains("اعلان")) return@mapNotNull null
|
if(it.text().contains("اعلان")) return@mapNotNull null
|
||||||
it.toSearchResponse()?.let { it1 -> result.add(it1) }
|
it.toSearchResponse()?.let { it1 -> result.add(it1) }
|
||||||
|
@ -88,7 +89,7 @@ class MyCimaProvider : MainAPI() {
|
||||||
val year = doc.select("div.Title--Content--Single-begin h1 a.unline")?.text()?.getIntFromText()
|
val year = doc.select("div.Title--Content--Single-begin h1 a.unline")?.text()?.getIntFromText()
|
||||||
val title = doc.select("div.Title--Content--Single-begin h1").text()
|
val title = doc.select("div.Title--Content--Single-begin h1").text()
|
||||||
.replace("($year)", "")
|
.replace("($year)", "")
|
||||||
.replace("مشاهدة|فيلم|مسلسل|مترجم".toRegex(), "")
|
.replace("مشاهدة|فيلم|مسلسل|مترجم|انمي".toRegex(), "")
|
||||||
// A bit iffy to parse twice like this, but it'll do.
|
// A bit iffy to parse twice like this, but it'll do.
|
||||||
val duration =
|
val duration =
|
||||||
doc.select("ul.Terms--Content--Single-begin li").firstOrNull {
|
doc.select("ul.Terms--Content--Single-begin li").firstOrNull {
|
||||||
|
@ -106,6 +107,9 @@ class MyCimaProvider : MainAPI() {
|
||||||
?: return@mapNotNull null
|
?: return@mapNotNull null
|
||||||
Actor(name, image)
|
Actor(name, image)
|
||||||
}
|
}
|
||||||
|
val recommendations = doc.select("div.Grid--MycimaPosts div.GridItem")?.mapNotNull { element ->
|
||||||
|
element.toSearchResponse()
|
||||||
|
}
|
||||||
|
|
||||||
return if (isMovie) {
|
return if (isMovie) {
|
||||||
newMovieLoadResponse(
|
newMovieLoadResponse(
|
||||||
|
@ -119,6 +123,7 @@ class MyCimaProvider : MainAPI() {
|
||||||
this.plot = synopsis
|
this.plot = synopsis
|
||||||
this.tags = tags
|
this.tags = tags
|
||||||
this.duration = duration
|
this.duration = duration
|
||||||
|
this.recommendations = recommendations
|
||||||
addActors(actors)
|
addActors(actors)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -133,8 +138,9 @@ class MyCimaProvider : MainAPI() {
|
||||||
if(moreButton.isNotEmpty()) {
|
if(moreButton.isNotEmpty()) {
|
||||||
val n = doc.select("div.Seasons--Episodes div.Episodes--Seasons--Episodes a").size
|
val n = doc.select("div.Seasons--Episodes div.Episodes--Seasons--Episodes a").size
|
||||||
val totals = doc.select("div.Episodes--Seasons--Episodes a").first().text().getIntFromText()
|
val totals = doc.select("div.Episodes--Seasons--Episodes a").first().text().getIntFromText()
|
||||||
arrayListOf(n, n+40, n+80, n+120, n+160, n+200, n+240, n+280, n+320, n+360)
|
val mEPS = arrayListOf(n, n+40, n+80, n+120, n+160, n+200, n+240, n+280, n+320, n+360, n+400, n+440, n+480, n+520, n+660, n+700, n+740, n+780, n+820, n+860, n+900, n+940, n+980, n+1020, n+1060, n+1100, n+1140, n+1180, n+1220, totals)
|
||||||
.apmap { it ->
|
mEPS.apmap { it ->
|
||||||
|
if (it != null) {
|
||||||
if(it > totals!!) return@apmap
|
if(it > totals!!) return@apmap
|
||||||
val ajaxURL = "$mainUrl/AjaxCenter/MoreEpisodes/${moreButton.attr("data-term")}/$it"
|
val ajaxURL = "$mainUrl/AjaxCenter/MoreEpisodes/${moreButton.attr("data-term")}/$it"
|
||||||
val jsonResponse = app.get(ajaxURL)
|
val jsonResponse = app.get(ajaxURL)
|
||||||
|
@ -143,6 +149,7 @@ class MyCimaProvider : MainAPI() {
|
||||||
document.select("a").map { episodes.add(TvSeriesEpisode(it.text(), season, it.text().getIntFromText(), it.attr("href"), null, null)) }
|
document.select("a").map { episodes.add(TvSeriesEpisode(it.text(), season, it.text().getIntFromText(), it.attr("href"), null, null)) }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if(seasons.isNotEmpty()) {
|
if(seasons.isNotEmpty()) {
|
||||||
seasons.apmap { surl ->
|
seasons.apmap { surl ->
|
||||||
if(surl.contains("%d9%85%d8%af%d8%a8%d9%84%d8%ac")) return@apmap
|
if(surl.contains("%d9%85%d8%af%d8%a8%d9%84%d8%ac")) return@apmap
|
||||||
|
@ -154,8 +161,9 @@ class MyCimaProvider : MainAPI() {
|
||||||
if(fmoreButton.isNotEmpty()) {
|
if(fmoreButton.isNotEmpty()) {
|
||||||
val n = seasonsite.select("div.Seasons--Episodes div.Episodes--Seasons--Episodes a").size
|
val n = seasonsite.select("div.Seasons--Episodes div.Episodes--Seasons--Episodes a").size
|
||||||
val totals = seasonsite.select("div.Episodes--Seasons--Episodes a").first().text().getIntFromText()
|
val totals = seasonsite.select("div.Episodes--Seasons--Episodes a").first().text().getIntFromText()
|
||||||
arrayListOf(n, n+40, n+80, n+120, n+160, n+200, n+240, n+280, n+320, n+360)
|
val mEPS = arrayListOf(n, n+40, n+80, n+120, n+160, n+200, n+240, n+280, n+320, n+360, n+400, n+440, n+480, n+520, n+660, n+700, n+740, n+780, n+820, n+860, n+900, n+940, n+980, n+1020, n+1060, n+1100, n+1140, n+1180, n+1220, totals)
|
||||||
.apmap { it ->
|
mEPS.apmap { it ->
|
||||||
|
if (it != null) {
|
||||||
if(it > totals!!) return@apmap
|
if(it > totals!!) return@apmap
|
||||||
val ajaxURL = "$mainUrl/AjaxCenter/MoreEpisodes/${fmoreButton.attr("data-term")}/$it"
|
val ajaxURL = "$mainUrl/AjaxCenter/MoreEpisodes/${fmoreButton.attr("data-term")}/$it"
|
||||||
val jsonResponse = app.get(ajaxURL)
|
val jsonResponse = app.get(ajaxURL)
|
||||||
|
@ -163,6 +171,7 @@ class MyCimaProvider : MainAPI() {
|
||||||
val document = Jsoup.parse(json.output?.replace("""\""", ""))
|
val document = Jsoup.parse(json.output?.replace("""\""", ""))
|
||||||
document.select("a").map { episodes.add(TvSeriesEpisode(it.text(), fseason, it.text().getIntFromText(), it.attr("href"), null, null)) }
|
document.select("a").map { episodes.add(TvSeriesEpisode(it.text(), fseason, it.text().getIntFromText(), it.attr("href"), null, null)) }
|
||||||
}
|
}
|
||||||
|
}
|
||||||
} else return@apmap
|
} else return@apmap
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -172,6 +181,7 @@ class MyCimaProvider : MainAPI() {
|
||||||
this.tags = tags
|
this.tags = tags
|
||||||
this.year = year
|
this.year = year
|
||||||
this.plot = synopsis
|
this.plot = synopsis
|
||||||
|
this.recommendations = recommendations
|
||||||
addActors(actors)
|
addActors(actors)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue