()
+ val doc = app.get("$mainUrl/page/1/?s=$query").document
+ val paginationElement = doc.select("ul[aria-label=\"pagination\"]")
+ doc.select("section article a").map {
+ val postUrl = it.attr("href")
+ if(it.select("li[aria-label=\"episode\"]").isNotEmpty()) return@map
+ if(postUrl.contains("$mainUrl/expired-download/|$mainUrl/افلام-اون-لاين/".toRegex())) return@map
+ result.add(it.toSearchResponse()!!)
+ }
+ if(paginationElement.isNotEmpty()) {
+ val max = paginationElement.select("li").not("li.active").last()?.text()?.toIntOrNull()
+ if (max != null) {
+ if(max > 5) return result.distinct().sortedBy { it.name }
+ (2..max!!).toList().apmap {
+ app.get("$mainUrl/page/$it/?s=$query\"").document.select("section article a").map { element ->
+ val postUrl = element.attr("href")
+ if(element.select("li[aria-label=\"episode\"]").isNotEmpty()) return@map
+ if(postUrl.contains("$mainUrl/expired-download/|$mainUrl/افلام-اون-لاين/".toRegex())) return@map
+ result.add(element.toSearchResponse()!!)
+ }
+ }
+ }
+ }
+ return result.distinct().sortedBy { it.name }
+ }
+
+ override suspend fun load(url: String): LoadResponse {
+ val doc = app.get(url).document
+ val posterUrl = doc.select("body > script:nth-child(3)").html().replace(".*,\"image\":\"|\".*".toRegex(),"").ifEmpty { doc.select("meta[property=\"og:image\"]").attr("content") }
+ val year = doc.select("article ul:nth-child(1) li a").last()?.text()?.toIntOrNull()
+ val title = doc.select("title").text().split(" | ")[0]
+ val isMovie = title.contains("فيلم|حفلات|مسرحية".toRegex())
+ val youtubeTrailer = doc.select("iframe")?.attr("src")
+
+ val synopsis = doc.select("ul#details li:contains(لمحة) p").text()
+
+ val tags = doc.select("article ul").first()?.select("li")?.map { it.text() }
+
+ val recommendations = doc.select("ul#related li").map { element ->
+ MovieSearchResponse(
+ apiName = this@CimaNowProvider.name,
+ url = element.select("a").attr("href"),
+ name = element.select("img:nth-child(2)").attr("alt"),
+ posterUrl = element.select("img:nth-child(2)").attr("src")
+ )
+ }
+
+ return if (isMovie) {
+ newMovieLoadResponse(
+ title,
+ url,
+ TvType.Movie,
+ "$url/watching"
+ ) {
+ this.posterUrl = posterUrl
+ this.year = year
+ this.recommendations = recommendations
+ this.plot = synopsis
+ this.tags = tags
+ addTrailer(youtubeTrailer)
+ }
+ } else {
+ val episodes = doc.select("ul#eps li").map { episode ->
+ Episode(
+ episode.select("a").attr("href")+"/watching",
+ episode.select("a img:nth-child(2)").attr("alt"),
+ doc.select("span[aria-label=\"season-title\"]").html().replace(".*|\n".toRegex(), "").getIntFromText(),
+ episode.select("a em").text().toIntOrNull(),
+ episode.select("a img:nth-child(2)").attr("src")
+ )
+ }
+ newTvSeriesLoadResponse(title, url, TvType.TvSeries, episodes.distinct().sortedBy { it.episode }) {
+ this.posterUrl = posterUrl
+ this.tags = tags
+ this.year = year
+ this.plot = synopsis
+ this.recommendations = recommendations
+ addTrailer(youtubeTrailer)
+ }
+ }
+ }
+
+ override suspend fun loadLinks(
+ data: String,
+ isCasting: Boolean,
+ subtitleCallback: (SubtitleFile) -> Unit,
+ callback: (ExtractorLink) -> Unit
+ ): Boolean {
+ app.get("$data").document.select("ul#download [aria-label=\"quality\"]").forEach {
+ val name = if(it.select("span").text().contains("فائق السرعة")) "Fast Servers" else "Servers"
+ it.select("a").forEach { media ->
+ callback.invoke(
+ ExtractorLink(
+ source = this.name,
+ name = name,
+ url = media.attr("href"),
+ referer = this.mainUrl,
+ quality = media.text().getIntFromText() ?: Qualities.Unknown.value
+ )
+ )
+ }
+ }
+ return true
+ }
+}
diff --git a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/EgyBestProvider.kt b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/EgyBestProvider.kt
index d2e3462c..f12c97ad 100644
--- a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/EgyBestProvider.kt
+++ b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/EgyBestProvider.kt
@@ -4,6 +4,7 @@ import com.fasterxml.jackson.annotation.JsonProperty
import com.lagradost.cloudstream3.*
import com.lagradost.cloudstream3.utils.AppUtils.parseJson
import com.lagradost.cloudstream3.utils.ExtractorLink
+import com.lagradost.cloudstream3.LoadResponse.Companion.addTrailer
import org.jsoup.nodes.Element
class EgyBestProvider : MainAPI() {
@@ -78,7 +79,8 @@ class EgyBestProvider : MainAPI() {
val posterUrl = doc.select("div.movie_img a img")?.attr("src")
val year = doc.select("div.movie_title h1 a")?.text()?.toIntOrNull()
val title = doc.select("div.movie_title h1 span").text()
-
+ val youtubeTrailer = doc.select("div.play")?.attr("url")
+
val synopsis = doc.select("div.mbox").firstOrNull {
it.text().contains("القصة")
}?.text()?.replace("القصة ", "")
@@ -112,6 +114,7 @@ class EgyBestProvider : MainAPI() {
this.plot = synopsis
this.tags = tags
this.actors = actors
+ addTrailer(youtubeTrailer)
}
} else {
val episodes = ArrayList()
@@ -153,6 +156,7 @@ class EgyBestProvider : MainAPI() {
this.year = year
this.plot = synopsis
this.actors = actors
+ addTrailer(youtubeTrailer)
}
}
}
diff --git a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/FilmanProvider.kt b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/FilmanProvider.kt
index 8561568e..e5738de4 100644
--- a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/FilmanProvider.kt
+++ b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/FilmanProvider.kt
@@ -18,9 +18,8 @@ class FilmanProvider : MainAPI() {
)
override suspend fun getMainPage(): HomePageResponse {
- val response = app.get(mainUrl).text
- val document = Jsoup.parse(response)
- val lists = document.select(".item-list,.series-list")
+ val document = app.get(mainUrl).document
+ val lists = document.select("div#item-list")
val categories = ArrayList()
for (l in lists) {
val title = l.parent()!!.select("h3").text()
@@ -53,17 +52,16 @@ class FilmanProvider : MainAPI() {
override suspend fun search(query: String): List {
val url = "$mainUrl/wyszukiwarka?phrase=$query"
- val response = app.get(url).text
- val document = Jsoup.parse(response)
- val lists = document.select("#advanced-search > div")
- val movies = lists[1].select(".item")
- val series = lists[3].select(".item")
+ val document = app.get(url).document
+ val lists = document.select("div#item-list")
+ val movies = lists[0].select(".poster > a")
+ val series = lists[1].select(".poster > a")
if (movies.isEmpty() && series.isEmpty()) return ArrayList()
fun getVideos(type: TvType, items: Elements): List {
return items.map { i ->
val href = i.attr("href")
val img = i.selectFirst("> img")!!.attr("src").replace("/thumb/", "/big/")
- val name = i.selectFirst(".title")!!.text()
+ val name = i.attr("title")
if (type === TvType.TvSeries) {
TvSeriesSearchResponse(
name,
@@ -83,8 +81,7 @@ class FilmanProvider : MainAPI() {
}
override suspend fun load(url: String): LoadResponse {
- val response = app.get(url).text
- val document = Jsoup.parse(response)
+ val document = app.get(url).document
val documentTitle = document.select("title").text().trim()
if (documentTitle.startsWith("Logowanie")) {
diff --git a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/FilmpertuttiProvider.kt b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/FilmpertuttiProvider.kt
index 82cc91e9..15efa32d 100644
--- a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/FilmpertuttiProvider.kt
+++ b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/FilmpertuttiProvider.kt
@@ -14,7 +14,7 @@ import org.jsoup.nodes.Element
class FilmpertuttiProvider : MainAPI() {
override var lang = "it"
- override var mainUrl = "https://www.filmpertutti.love"
+ override var mainUrl = "https://filmpertutti.love"
override var name = "Filmpertutti"
override val hasMainPage = true
override val hasChromecastSupport = true
diff --git a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/LayarKaca21Provider.kt b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/LayarKacaProvider.kt
similarity index 97%
rename from app/src/main/java/com/lagradost/cloudstream3/movieproviders/LayarKaca21Provider.kt
rename to app/src/main/java/com/lagradost/cloudstream3/movieproviders/LayarKacaProvider.kt
index fa3c2c00..adb15e48 100644
--- a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/LayarKaca21Provider.kt
+++ b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/LayarKacaProvider.kt
@@ -10,7 +10,7 @@ import org.jsoup.nodes.Element
import java.util.*
class LayarKacaProvider : MainAPI() {
- override var mainUrl = "https://149.56.24.226"
+ override var mainUrl = "https://lk21.xn--6frz82g"
override var name = "LayarKaca"
override val hasMainPage = true
override var lang = "id"
@@ -214,7 +214,12 @@ class LayarKacaProvider : MainAPI() {
}
sources.apmap {
- loadExtractor(it, data, callback)
+ val link = if(it.startsWith("https://layarkacaxxi.icu")) {
+ it.substringBeforeLast("/")
+ } else {
+ it
+ }
+ loadExtractor(link, data, callback)
}
return true
diff --git a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/StreamingcommunityProvider.kt b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/StreamingcommunityProvider.kt
index 209bca6d..49c6389b 100644
--- a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/StreamingcommunityProvider.kt
+++ b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/StreamingcommunityProvider.kt
@@ -51,7 +51,7 @@ data class Image(
@JsonProperty("proxy_id") val proxyID: Long,
@JsonProperty("url") val url: String,
@JsonProperty("type") val type: String,
- @JsonProperty("sc_url") val scURL: String,
+// @JsonProperty("sc_url") val scURL: String,
// @JsonProperty("proxy") val proxy: Proxy,
// @JsonProperty("server") val server: Proxy
)
@@ -128,7 +128,7 @@ data class TrailerElement(
class StreamingcommunityProvider : MainAPI() {
override var lang = "it"
- override var mainUrl = "https://streamingcommunity.org"
+ override var mainUrl = "https://streamingcommunity.best"
override var name = "Streamingcommunity"
override val hasMainPage = true
override val hasChromecastSupport = true
diff --git a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/TantiFilmProvider.kt b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/TantiFilmProvider.kt
index 84035a14..38d0a104 100644
--- a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/TantiFilmProvider.kt
+++ b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/TantiFilmProvider.kt
@@ -9,7 +9,7 @@ import com.lagradost.cloudstream3.LoadResponse.Companion.addTrailer
class TantifilmProvider : MainAPI() {
override var lang = "it"
- override var mainUrl = "https://www.tantifilm.pics"
+ override var mainUrl = "https://www.tantifilm.nl"
override var name = "Tantifilm"
override val hasMainPage = true
override val hasChromecastSupport = true
diff --git a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/XcineProvider.kt b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/XcineProvider.kt
index 05fd843e..82f5f186 100644
--- a/app/src/main/java/com/lagradost/cloudstream3/movieproviders/XcineProvider.kt
+++ b/app/src/main/java/com/lagradost/cloudstream3/movieproviders/XcineProvider.kt
@@ -231,30 +231,27 @@ class XcineProvider : MainAPI() {
cookies = parsed.cookies + cookies,
).text
- val jsonRegex = Regex("""(vip_|)source.*?(\[.*);""")
- val json = jsonRegex.findAll(response)
+ val urlRegex = Regex("""file['"].*?['"]([^'"]*)""")
+ val link = urlRegex.find(response)?.groupValues!![1]
- val files = json.mapNotNull {
- (it.groupValues.getOrNull(1) == "vip_") to (
- tryParseJson>(it.groupValues.getOrNull(2)) ?: return@mapNotNull null)
- }
+// files.forEach { (isVip, list) ->
+// list.forEach file@{ file ->
+// if (file.file == null) return@file
+ callback.invoke(
+ ExtractorLink(
+ this.name,
+ this.name,
+ link.replace("\\", ""),
+ this.mainUrl,
+// file.label?.getIntFromText() ?:
+ Qualities.Unknown.value,
+ true
+// file.type?.contains("hls", ignoreCase = true) == true,
+ )
+ )
+// }
+// }
- files.forEach { (isVip, list) ->
- list.forEach file@{ file ->
- if (file.file == null) return@file
- callback.invoke(
- ExtractorLink(
- this.name,
- this.name + if (isVip) " VIP" else "",
- file.file.replace("\\", ""),
- this.mainUrl,
- file.label?.getIntFromText() ?: Qualities.Unknown.value,
- file.type?.contains("hls", ignoreCase = true) == true,
- )
- )
- }
- }
-
- return files.sumOf { it.second.size } > 0
+ return true // files.sumOf { it.second.size } > 0
}
}
diff --git a/docs/providers.json b/docs/providers.json
index 30f52595..47e9ef15 100644
--- a/docs/providers.json
+++ b/docs/providers.json
@@ -21,7 +21,7 @@
"language": "it",
"name": "Altadefinizione",
"status": 1,
- "url": "https://altadefinizione.hair"
+ "url": "https://altadefinizione.tienda"
},
"AniflixProvider": {
"language": "en",
@@ -100,10 +100,16 @@
"status": 1,
"url": "https://bflix.ru"
},
+ "CimaNowProvider": {
+ "language": "ar",
+ "name": "CimaNow",
+ "status": 1,
+ "url": "https://cimanow.cc"
+ },
"CineblogProvider": {
"language": "it",
"name": "CineBlog",
- "status": 0,
+ "status": 1,
"url": "https://cb01.rip"
},
"CinecalidadProvider": {
@@ -197,8 +203,8 @@
"FilmpertuttiProvider": {
"language": "it",
"name": "Filmpertutti",
- "status": 0,
- "url": "https://www.filmpertutti.love"
+ "status": 1,
+ "url": "https://filmpertutti.love"
},
"FmoviesToProvider": {
"language": "en",
@@ -239,7 +245,7 @@
"HDrezkaProvider": {
"language": "ru",
"name": "HDrezka",
- "status": 1,
+ "status": 0,
"url": "https://rezka.ag"
},
"IHaveNoTvProvider": {
@@ -472,13 +478,13 @@
"language": "it",
"name": "Streamingcommunity",
"status": 1,
- "url": "https://streamingcommunity.org"
+ "url": "https://streamingcommunity.best"
},
"TantifilmProvider": {
"language": "it",
"name": "Tantifilm",
"status": 1,
- "url": "https://www.tantifilm.pics"
+ "url": "https://www.tantifilm.nl"
},
"TenshiProvider": {
"language": "en",