From b33842569b7d23e89113d9a2ae62d86bdfcbef50 Mon Sep 17 00:00:00 2001 From: Cloudburst <18114966+C10udburst@users.noreply.github.com> Date: Tue, 16 Aug 2022 19:14:43 +0200 Subject: [PATCH] move spanish providers to their own repo --- AnimefenixProvider/build.gradle.kts | 26 -- .../src/main/AndroidManifest.xml | 2 - .../com/lagradost/AnimefenixProvider.kt | 249 -------------- .../com/lagradost/AnimefenixProviderPlugin.kt | 14 - AnimeflvIOProvider/build.gradle.kts | 26 -- .../src/main/AndroidManifest.xml | 2 - .../com/lagradost/AnimeflvIOProvider.kt | 239 ------------- .../com/lagradost/AnimeflvIOProviderPlugin.kt | 14 - AnimeflvnetProvider/build.gradle.kts | 26 -- .../src/main/AndroidManifest.xml | 2 - .../com/lagradost/AnimeflvnetProvider.kt | 182 ---------- .../lagradost/AnimeflvnetProviderPlugin.kt | 14 - CinecalidadProvider/build.gradle.kts | 25 -- .../src/main/AndroidManifest.xml | 2 - .../com/lagradost/CinecalidadProvider.kt | 258 -------------- .../lagradost/CinecalidadProviderPlugin.kt | 14 - CuevanaProvider/build.gradle.kts | 26 -- CuevanaProvider/src/main/AndroidManifest.xml | 2 - .../kotlin/com/lagradost/CuevanaProvider.kt | 324 ------------------ .../com/lagradost/CuevanaProviderPlugin.kt | 14 - DoramasYTProvider/build.gradle.kts | 25 -- .../src/main/AndroidManifest.xml | 2 - .../kotlin/com/lagradost/DoramasYTProvider.kt | 155 --------- .../com/lagradost/DoramasYTProviderPlugin.kt | 14 - .../main/kotlin/com/lagradost/XStreamCdn.kt | 67 ---- ElifilmsProvider/build.gradle.kts | 23 -- ElifilmsProvider/src/main/AndroidManifest.xml | 2 - .../kotlin/com/lagradost/ElifilmsProvider.kt | 94 ----- .../com/lagradost/ElifilmsProviderPlugin.kt | 14 - .../build.gradle.kts | 25 -- .../src/main/AndroidManifest.xml | 2 - .../EntrepeliculasyseriesProvider.kt | 177 ---------- .../EntrepeliculasyseriesProviderPlugin.kt | 14 - EstrenosDoramasProvider/build.gradle.kts | 26 -- .../src/main/AndroidManifest.xml | 2 - .../com/lagradost/EstrenosDoramasProvider.kt | 286 ---------------- .../EstrenosDoramasProviderPlugin.kt | 14 - JKAnimeProvider/build.gradle.kts | 25 -- JKAnimeProvider/src/main/AndroidManifest.xml | 2 - .../kotlin/com/lagradost/JKAnimeProvider.kt | 319 ----------------- .../com/lagradost/JKAnimeProviderPlugin.kt | 14 - MonoschinosProvider/build.gradle.kts | 25 -- .../src/main/AndroidManifest.xml | 2 - .../com/lagradost/MonoschinosProvider.kt | 155 --------- .../lagradost/MonoschinosProviderPlugin.kt | 14 - .../main/kotlin/com/lagradost/XStreamCdn.kt | 67 ---- MundoDonghuaProvider/build.gradle.kts | 25 -- .../src/main/AndroidManifest.xml | 2 - .../com/lagradost/MundoDonghuaProvider.kt | 217 ------------ .../lagradost/MundoDonghuaProviderPlugin.kt | 14 - PeliSmartProvider/build.gradle.kts | 26 -- .../src/main/AndroidManifest.xml | 2 - .../kotlin/com/lagradost/PeliSmartProvider.kt | 160 --------- .../com/lagradost/PeliSmartProviderPlugin.kt | 14 - PelisplusHDProvider/build.gradle.kts | 26 -- .../src/main/AndroidManifest.xml | 2 - .../com/lagradost/PelisplusHDProvider.kt | 173 ---------- .../lagradost/PelisplusHDProviderPlugin.kt | 14 - PelisplusProvider/build.gradle.kts | 26 -- .../src/main/AndroidManifest.xml | 2 - .../kotlin/com/lagradost/PelisplusProvider.kt | 26 -- .../com/lagradost/PelisplusProviderPlugin.kt | 14 - .../lagradost/PelisplusProviderTemplate.kt | 260 -------------- SeriesflixProvider/build.gradle.kts | 25 -- .../src/main/AndroidManifest.xml | 2 - .../com/lagradost/SeriesflixProvider.kt | 226 ------------ .../com/lagradost/SeriesflixProviderPlugin.kt | 14 - 67 files changed, 4296 deletions(-) delete mode 100644 AnimefenixProvider/build.gradle.kts delete mode 100644 AnimefenixProvider/src/main/AndroidManifest.xml delete mode 100644 AnimefenixProvider/src/main/kotlin/com/lagradost/AnimefenixProvider.kt delete mode 100644 AnimefenixProvider/src/main/kotlin/com/lagradost/AnimefenixProviderPlugin.kt delete mode 100644 AnimeflvIOProvider/build.gradle.kts delete mode 100644 AnimeflvIOProvider/src/main/AndroidManifest.xml delete mode 100644 AnimeflvIOProvider/src/main/kotlin/com/lagradost/AnimeflvIOProvider.kt delete mode 100644 AnimeflvIOProvider/src/main/kotlin/com/lagradost/AnimeflvIOProviderPlugin.kt delete mode 100644 AnimeflvnetProvider/build.gradle.kts delete mode 100644 AnimeflvnetProvider/src/main/AndroidManifest.xml delete mode 100644 AnimeflvnetProvider/src/main/kotlin/com/lagradost/AnimeflvnetProvider.kt delete mode 100644 AnimeflvnetProvider/src/main/kotlin/com/lagradost/AnimeflvnetProviderPlugin.kt delete mode 100644 CinecalidadProvider/build.gradle.kts delete mode 100644 CinecalidadProvider/src/main/AndroidManifest.xml delete mode 100644 CinecalidadProvider/src/main/kotlin/com/lagradost/CinecalidadProvider.kt delete mode 100644 CinecalidadProvider/src/main/kotlin/com/lagradost/CinecalidadProviderPlugin.kt delete mode 100644 CuevanaProvider/build.gradle.kts delete mode 100644 CuevanaProvider/src/main/AndroidManifest.xml delete mode 100644 CuevanaProvider/src/main/kotlin/com/lagradost/CuevanaProvider.kt delete mode 100644 CuevanaProvider/src/main/kotlin/com/lagradost/CuevanaProviderPlugin.kt delete mode 100644 DoramasYTProvider/build.gradle.kts delete mode 100644 DoramasYTProvider/src/main/AndroidManifest.xml delete mode 100644 DoramasYTProvider/src/main/kotlin/com/lagradost/DoramasYTProvider.kt delete mode 100644 DoramasYTProvider/src/main/kotlin/com/lagradost/DoramasYTProviderPlugin.kt delete mode 100644 DoramasYTProvider/src/main/kotlin/com/lagradost/XStreamCdn.kt delete mode 100644 ElifilmsProvider/build.gradle.kts delete mode 100644 ElifilmsProvider/src/main/AndroidManifest.xml delete mode 100644 ElifilmsProvider/src/main/kotlin/com/lagradost/ElifilmsProvider.kt delete mode 100644 ElifilmsProvider/src/main/kotlin/com/lagradost/ElifilmsProviderPlugin.kt delete mode 100644 EntrepeliculasyseriesProvider/build.gradle.kts delete mode 100644 EntrepeliculasyseriesProvider/src/main/AndroidManifest.xml delete mode 100644 EntrepeliculasyseriesProvider/src/main/kotlin/com/lagradost/EntrepeliculasyseriesProvider.kt delete mode 100644 EntrepeliculasyseriesProvider/src/main/kotlin/com/lagradost/EntrepeliculasyseriesProviderPlugin.kt delete mode 100644 EstrenosDoramasProvider/build.gradle.kts delete mode 100644 EstrenosDoramasProvider/src/main/AndroidManifest.xml delete mode 100644 EstrenosDoramasProvider/src/main/kotlin/com/lagradost/EstrenosDoramasProvider.kt delete mode 100644 EstrenosDoramasProvider/src/main/kotlin/com/lagradost/EstrenosDoramasProviderPlugin.kt delete mode 100644 JKAnimeProvider/build.gradle.kts delete mode 100644 JKAnimeProvider/src/main/AndroidManifest.xml delete mode 100644 JKAnimeProvider/src/main/kotlin/com/lagradost/JKAnimeProvider.kt delete mode 100644 JKAnimeProvider/src/main/kotlin/com/lagradost/JKAnimeProviderPlugin.kt delete mode 100644 MonoschinosProvider/build.gradle.kts delete mode 100644 MonoschinosProvider/src/main/AndroidManifest.xml delete mode 100644 MonoschinosProvider/src/main/kotlin/com/lagradost/MonoschinosProvider.kt delete mode 100644 MonoschinosProvider/src/main/kotlin/com/lagradost/MonoschinosProviderPlugin.kt delete mode 100644 MonoschinosProvider/src/main/kotlin/com/lagradost/XStreamCdn.kt delete mode 100644 MundoDonghuaProvider/build.gradle.kts delete mode 100644 MundoDonghuaProvider/src/main/AndroidManifest.xml delete mode 100644 MundoDonghuaProvider/src/main/kotlin/com/lagradost/MundoDonghuaProvider.kt delete mode 100644 MundoDonghuaProvider/src/main/kotlin/com/lagradost/MundoDonghuaProviderPlugin.kt delete mode 100644 PeliSmartProvider/build.gradle.kts delete mode 100644 PeliSmartProvider/src/main/AndroidManifest.xml delete mode 100644 PeliSmartProvider/src/main/kotlin/com/lagradost/PeliSmartProvider.kt delete mode 100644 PeliSmartProvider/src/main/kotlin/com/lagradost/PeliSmartProviderPlugin.kt delete mode 100644 PelisplusHDProvider/build.gradle.kts delete mode 100644 PelisplusHDProvider/src/main/AndroidManifest.xml delete mode 100644 PelisplusHDProvider/src/main/kotlin/com/lagradost/PelisplusHDProvider.kt delete mode 100644 PelisplusHDProvider/src/main/kotlin/com/lagradost/PelisplusHDProviderPlugin.kt delete mode 100644 PelisplusProvider/build.gradle.kts delete mode 100644 PelisplusProvider/src/main/AndroidManifest.xml delete mode 100644 PelisplusProvider/src/main/kotlin/com/lagradost/PelisplusProvider.kt delete mode 100644 PelisplusProvider/src/main/kotlin/com/lagradost/PelisplusProviderPlugin.kt delete mode 100644 PelisplusProvider/src/main/kotlin/com/lagradost/PelisplusProviderTemplate.kt delete mode 100644 SeriesflixProvider/build.gradle.kts delete mode 100644 SeriesflixProvider/src/main/AndroidManifest.xml delete mode 100644 SeriesflixProvider/src/main/kotlin/com/lagradost/SeriesflixProvider.kt delete mode 100644 SeriesflixProvider/src/main/kotlin/com/lagradost/SeriesflixProviderPlugin.kt diff --git a/AnimefenixProvider/build.gradle.kts b/AnimefenixProvider/build.gradle.kts deleted file mode 100644 index 0266db8..0000000 --- a/AnimefenixProvider/build.gradle.kts +++ /dev/null @@ -1,26 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "AnimeMovie", - "OVA", - "Anime", - ) - - iconUrl = "https://www.google.com/s2/favicons?domain=animefenix.com&sz=24" -} \ No newline at end of file diff --git a/AnimefenixProvider/src/main/AndroidManifest.xml b/AnimefenixProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/AnimefenixProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/AnimefenixProvider/src/main/kotlin/com/lagradost/AnimefenixProvider.kt b/AnimefenixProvider/src/main/kotlin/com/lagradost/AnimefenixProvider.kt deleted file mode 100644 index 203fa8d..0000000 --- a/AnimefenixProvider/src/main/kotlin/com/lagradost/AnimefenixProvider.kt +++ /dev/null @@ -1,249 +0,0 @@ -package com.lagradost - -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.utils.Qualities -import com.lagradost.cloudstream3.utils.loadExtractor -import org.jsoup.Jsoup -import java.util.* - - -class AnimefenixProvider:MainAPI() { - - override var mainUrl = "https://animefenix.com" - override var name = "Animefenix" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.AnimeMovie, - TvType.OVA, - TvType.Anime, - ) - - fun getDubStatus(title: String): DubStatus { - return if (title.contains("Latino") || title.contains("Castellano")) - DubStatus.Dubbed - else DubStatus.Subbed - } - - override suspend fun getMainPage(page: Int, request : MainPageRequest): HomePageResponse { - val urls = listOf( - Pair("$mainUrl/", "Animes"), - Pair("$mainUrl/animes?type[]=movie&order=default", "Peliculas", ), - Pair("$mainUrl/animes?type[]=ova&order=default", "OVA's", ), - ) - - val items = ArrayList() - - items.add( - HomePageList( - "Últimos episodios", - app.get(mainUrl).document.select(".capitulos-grid div.item").map { - val title = it.selectFirst("div.overtitle")?.text() - val poster = it.selectFirst("a img")?.attr("src") - val epRegex = Regex("(-(\\d+)\$|-(\\d+)\\.(\\d+))") - val url = it.selectFirst("a")?.attr("href")?.replace(epRegex,"") - ?.replace("/ver/","/") - val epNum = it.selectFirst(".is-size-7")?.text()?.replace("Episodio ","")?.toIntOrNull() - newAnimeSearchResponse(title!!, url!!) { - this.posterUrl = poster - addDubStatus(getDubStatus(title), epNum) - } - }) - ) - - urls.apmap { (url, name) -> - val response = app.get(url) - val soup = Jsoup.parse(response.text) - val home = soup.select(".list-series article").map { - val title = it.selectFirst("h3 a")?.text() - val poster = it.selectFirst("figure img")?.attr("src") - AnimeSearchResponse( - title!!, - it.selectFirst("a")?.attr("href") ?: "", - this.name, - TvType.Anime, - poster, - null, - if (title.contains("Latino")) EnumSet.of(DubStatus.Dubbed) else EnumSet.of(DubStatus.Subbed), - ) - } - - items.add(HomePageList(name, home)) - } - - if (items.size <= 0) throw ErrorLoadingException() - return HomePageResponse(items) - } - - override suspend fun search(query: String): List { - return app.get("$mainUrl/animes?q=$query").document.select(".list-series article").map { - val title = it.selectFirst("h3 a")?.text() - val href = it.selectFirst("a")?.attr("href") - val image = it.selectFirst("figure img")?.attr("src") - AnimeSearchResponse( - title!!, - href!!, - this.name, - TvType.Anime, - fixUrl(image ?: ""), - null, - if (title.contains("Latino") || title.contains("Castellano")) EnumSet.of(DubStatus.Dubbed) else EnumSet.of( - DubStatus.Subbed), - ) - } - } - - override suspend fun load(url: String): LoadResponse { - val doc = Jsoup.parse(app.get(url, timeout = 120).text) - val poster = doc.selectFirst(".image > img")?.attr("src") - val title = doc.selectFirst("h1.title.has-text-orange")?.text() - val description = doc.selectFirst("p.has-text-light")?.text() - val genres = doc.select(".genres a").map { it.text() } - val status = when (doc.selectFirst(".is-narrow-desktop a.button")?.text()) { - "Emisión" -> ShowStatus.Ongoing - "Finalizado" -> ShowStatus.Completed - else -> null - } - val episodes = doc.select(".anime-page__episode-list li").map { - val name = it.selectFirst("span")?.text() - val link = it.selectFirst("a")?.attr("href") - Episode(link!!, name) - }.reversed() - val type = if (doc.selectFirst("ul.has-text-light")?.text() - !!.contains("Película") && episodes.size == 1 - ) TvType.AnimeMovie else TvType.Anime - return newAnimeLoadResponse(title!!, url, type) { - japName = null - engName = title - posterUrl = poster - addEpisodes(DubStatus.Subbed, episodes) - plot = description - tags = genres - showStatus = status - } - } - - private fun cleanStreamID(input: String): String = input.replace(Regex("player=.*&code=|&"),"") - - data class Amazon ( - @JsonProperty("file") var file : String? = null, - @JsonProperty("type") var type : String? = null, - @JsonProperty("label") var label : String? = null - ) - - private fun cleanExtractor( - source: String, - name: String, - url: String, - callback: (ExtractorLink) -> Unit - ): Boolean { - callback( - ExtractorLink( - source, - name, - url, - "", - Qualities.Unknown.value, - false - ) - ) - return true - } - - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - val soup = app.get(data).document - val script = soup.selectFirst(".player-container script")?.data() - if (script!!.contains("var tabsArray =")) { - val sourcesRegex = Regex("player=.*&code(.*)&") - val test = sourcesRegex.findAll(script).toList() - test.apmap { - val codestream = it.value - val links = when { - codestream.contains("player=2&") -> "https://embedsito.com/v/"+cleanStreamID(codestream) - codestream.contains("player=3&") -> "https://www.mp4upload.com/embed-"+cleanStreamID(codestream)+".html" - codestream.contains("player=6&") -> "https://www.yourupload.com/embed/"+cleanStreamID(codestream) - codestream.contains("player=12&") -> "http://ok.ru/videoembed/"+cleanStreamID(codestream) - codestream.contains("player=4&") -> "https://sendvid.com/"+cleanStreamID(codestream) - codestream.contains("player=9&") -> "AmaNormal https://www.animefenix.com/stream/amz.php?v="+cleanStreamID(codestream) - codestream.contains("player=11&") -> "AmazonES https://www.animefenix.com/stream/amz.php?v="+cleanStreamID(codestream) - codestream.contains("player=22&") -> "Fireload https://www.animefenix.com/stream/fl.php?v="+cleanStreamID(codestream) - - else -> "" - } - loadExtractor(links, data, subtitleCallback, callback) - - argamap({ - if (links.contains("AmaNormal")) { - val doc = app.get(links.replace("AmaNormal ","")).document - doc.select("script").map { script -> - if (script.data().contains("sources: [{\"file\"")) { - val text = script.data().substringAfter("sources:").substringBefore("]").replace("[","") - val json = parseJson(text) - if (json.file != null) { - cleanExtractor( - "Amazon", - "Amazon ${json.label}", - json.file!!, - callback - ) - } - } - } - } - - if (links.contains("AmazonES")) { - val amazonES = links.replace("AmazonES ", "") - val doc = app.get("$amazonES&ext=es").document - doc.select("script").map { script -> - if (script.data().contains("sources: [{\"file\"")) { - val text = script.data().substringAfter("sources:").substringBefore("]").replace("[","") - val json = parseJson(text) - if (json.file != null) { - cleanExtractor( - "AmazonES", - "AmazonES ${json.label}", - json.file!!, - callback - ) - } - } - } - } - if (links.contains("Fireload")) { - val doc = app.get(links.replace("Fireload ", "")).document - doc.select("script").map { script -> - if (script.data().contains("sources: [{\"file\"")) { - val text = script.data().substringAfter("sources:").substringBefore("]").replace("[","") - val json = parseJson(text) - val testurl = if (json.file?.contains("fireload") == true) { - app.get("https://${json.file}").text - } else null - if (testurl?.contains("error") == true) { - // - } else if (json.file?.contains("fireload") == true) { - cleanExtractor( - "Fireload", - "Fireload ${json.label}", - "https://"+json.file!!, - callback - ) - } - } - } - } - }) - } - } - return true - } -} \ No newline at end of file diff --git a/AnimefenixProvider/src/main/kotlin/com/lagradost/AnimefenixProviderPlugin.kt b/AnimefenixProvider/src/main/kotlin/com/lagradost/AnimefenixProviderPlugin.kt deleted file mode 100644 index 459bd29..0000000 --- a/AnimefenixProvider/src/main/kotlin/com/lagradost/AnimefenixProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class AnimefenixProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(AnimefenixProvider()) - } -} \ No newline at end of file diff --git a/AnimeflvIOProvider/build.gradle.kts b/AnimeflvIOProvider/build.gradle.kts deleted file mode 100644 index 67fe108..0000000 --- a/AnimeflvIOProvider/build.gradle.kts +++ /dev/null @@ -1,26 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "AnimeMovie", - "Anime", - "OVA", - ) - - iconUrl = "https://www.google.com/s2/favicons?domain=animeflv.io&sz=24" -} \ No newline at end of file diff --git a/AnimeflvIOProvider/src/main/AndroidManifest.xml b/AnimeflvIOProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/AnimeflvIOProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/AnimeflvIOProvider/src/main/kotlin/com/lagradost/AnimeflvIOProvider.kt b/AnimeflvIOProvider/src/main/kotlin/com/lagradost/AnimeflvIOProvider.kt deleted file mode 100644 index 5b74053..0000000 --- a/AnimeflvIOProvider/src/main/kotlin/com/lagradost/AnimeflvIOProvider.kt +++ /dev/null @@ -1,239 +0,0 @@ -package com.lagradost - -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.utils.M3u8Helper.Companion.generateM3u8 -import com.lagradost.cloudstream3.utils.Qualities -import com.lagradost.cloudstream3.utils.getQualityFromName -import com.lagradost.cloudstream3.utils.loadExtractor -import java.util.* - -class AnimeflvIOProvider : MainAPI() { - override var mainUrl = "https://animeflv.io" //Also scrapes from animeid.to - override var name = "Animeflv.io" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.AnimeMovie, - TvType.OVA, - TvType.Anime, - ) - - override suspend fun getMainPage(page: Int, request: MainPageRequest): HomePageResponse { - val items = ArrayList() - val urls = listOf( - Pair("$mainUrl/series", "Series actualizadas"), - Pair("$mainUrl/peliculas", "Peliculas actualizadas"), - ) - items.add( - HomePageList( - "Estrenos", - app.get(mainUrl).document.select("div#owl-demo-premiere-movies .pull-left").map { - val title = it.selectFirst("p")?.text() ?: "" - AnimeSearchResponse( - title, - fixUrl(it.selectFirst("a")?.attr("href") ?: ""), - this.name, - TvType.Anime, - it.selectFirst("img")?.attr("src"), - it.selectFirst("span.year").toString().toIntOrNull(), - EnumSet.of(DubStatus.Subbed), - ) - }) - ) - urls.apmap { (url, name) -> - val soup = app.get(url).document - val home = soup.select("div.item-pelicula").map { - val title = it.selectFirst(".item-detail p")?.text() ?: "" - val poster = it.selectFirst("figure img")?.attr("src") - AnimeSearchResponse( - title, - fixUrl(it.selectFirst("a")?.attr("href") ?: ""), - this.name, - TvType.Anime, - poster, - null, - if (title.contains("Latino") || title.contains("Castellano")) EnumSet.of( - DubStatus.Dubbed - ) else EnumSet.of(DubStatus.Subbed), - ) - } - - items.add(HomePageList(name, home)) - } - - if (items.size <= 0) throw ErrorLoadingException() - return HomePageResponse(items) - } - - override suspend fun search(query: String): List { - val headers = mapOf( - "Host" to "animeflv.io", - "User-Agent" to USER_AGENT, - "X-Requested-With" to "XMLHttpRequest", - "DNT" to "1", - "Alt-Used" to "animeflv.io", - "Connection" to "keep-alive", - "Referer" to "https://animeflv.io", - ) - val url = "$mainUrl/search.html?keyword=$query" - val document = app.get( - url, - headers = headers - ).document - return document.select(".item-pelicula.pull-left").map { - val title = it.selectFirst("div.item-detail p")?.text() ?: "" - val href = fixUrl(it.selectFirst("a")?.attr("href") ?: "") - var image = it.selectFirst("figure img")?.attr("src") ?: "" - val isMovie = href.contains("/pelicula/") - if (image.contains("/static/img/picture.png")) { - image = "" - } - if (isMovie) { - MovieSearchResponse( - title, - href, - this.name, - TvType.AnimeMovie, - image, - null - ) - } else { - AnimeSearchResponse( - title, - href, - this.name, - TvType.Anime, - image, - null, - EnumSet.of(DubStatus.Subbed), - ) - } - } - } - - override suspend fun load(url: String): LoadResponse? { - // Gets the url returned from searching. - val soup = app.get(url).document - val title = soup.selectFirst(".info-content h1")?.text() - val description = soup.selectFirst("span.sinopsis")?.text()?.trim() - val poster: String? = soup.selectFirst(".poster img")?.attr("src") - val episodes = soup.select(".item-season-episodes a").map { li -> - val href = fixUrl(li.selectFirst("a")?.attr("href") ?: "") - val name = li.selectFirst("a")?.text() ?: "" - Episode( - href, name, - ) - }.reversed() - - val year = Regex("(\\d*)").find(soup.select(".info-half").text()) - - val tvType = if (url.contains("/pelicula/")) TvType.AnimeMovie else TvType.Anime - val genre = soup.select(".content-type-a a") - .map { it?.text()?.trim().toString().replace(", ", "") } - val duration = Regex("""(\d*)""").find( - soup.select("p.info-half:nth-child(4)").text() - ) - - return when (tvType) { - TvType.Anime -> { - return newAnimeLoadResponse(title ?: "", url, tvType) { - japName = null - engName = title - posterUrl = poster - this.year = null - addEpisodes(DubStatus.Subbed, episodes) - plot = description - tags = genre - - showStatus = null - } - } - TvType.AnimeMovie -> { - MovieLoadResponse( - title ?: "", - url, - this.name, - tvType, - url, - poster, - year.toString().toIntOrNull(), - description, - null, - genre, - duration.toString().toIntOrNull(), - ) - } - else -> null - } - } - - data class MainJson( - @JsonProperty("source") val source: List, - @JsonProperty("source_bk") val sourceBk: String?, - @JsonProperty("track") val track: List?, - @JsonProperty("advertising") val advertising: List?, - @JsonProperty("linkiframe") val linkiframe: String? - ) - - data class Source( - @JsonProperty("file") val file: String, - @JsonProperty("label") val label: String, - @JsonProperty("default") val default: String, - @JsonProperty("type") val type: String - ) - - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - app.get(data).document.select("li.tab-video").apmap { - val url = fixUrl(it.attr("data-video")) - if (url.contains("animeid")) { - val ajaxurl = url.replace("streaming.php", "ajax.php") - val ajaxurltext = app.get(ajaxurl).text - val json = parseJson(ajaxurltext) - json.source.forEach { source -> - if (source.file.contains("m3u8")) { - generateM3u8( - "Animeflv.io", - source.file, - "https://animeid.to", - headers = mapOf("Referer" to "https://animeid.to") - ).apmap { - callback( - ExtractorLink( - "Animeflv.io", - "Animeflv.io", - it.url, - "https://animeid.to", - getQualityFromName(it.quality.toString()), - it.url.contains("m3u8") - ) - ) - } - } else { - callback( - ExtractorLink( - name, - "$name ${source.label}", - source.file, - "https://animeid.to", - Qualities.Unknown.value, - isM3u8 = source.file.contains("m3u8") - ) - ) - } - } - } - loadExtractor(url, data, subtitleCallback, callback) - } - return true - } -} \ No newline at end of file diff --git a/AnimeflvIOProvider/src/main/kotlin/com/lagradost/AnimeflvIOProviderPlugin.kt b/AnimeflvIOProvider/src/main/kotlin/com/lagradost/AnimeflvIOProviderPlugin.kt deleted file mode 100644 index f0fa600..0000000 --- a/AnimeflvIOProvider/src/main/kotlin/com/lagradost/AnimeflvIOProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class AnimeflvIOProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(AnimeflvIOProvider()) - } -} \ No newline at end of file diff --git a/AnimeflvnetProvider/build.gradle.kts b/AnimeflvnetProvider/build.gradle.kts deleted file mode 100644 index 79a6d05..0000000 --- a/AnimeflvnetProvider/build.gradle.kts +++ /dev/null @@ -1,26 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "AnimeMovie", - "Anime", - "OVA", - ) - - iconUrl = "https://www.google.com/s2/favicons?domain=www3.animeflv.net&sz=24" -} \ No newline at end of file diff --git a/AnimeflvnetProvider/src/main/AndroidManifest.xml b/AnimeflvnetProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/AnimeflvnetProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/AnimeflvnetProvider/src/main/kotlin/com/lagradost/AnimeflvnetProvider.kt b/AnimeflvnetProvider/src/main/kotlin/com/lagradost/AnimeflvnetProvider.kt deleted file mode 100644 index c30076f..0000000 --- a/AnimeflvnetProvider/src/main/kotlin/com/lagradost/AnimeflvnetProvider.kt +++ /dev/null @@ -1,182 +0,0 @@ -package com.lagradost - -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.utils.loadExtractor -import java.util.* - -class AnimeflvnetProvider : MainAPI() { - companion object { - fun getType(t: String): TvType { - return if (t.contains("OVA") || t.contains("Especial")) TvType.OVA - else if (t.contains("Película")) TvType.AnimeMovie - else TvType.Anime - } - - fun getDubStatus(title: String): DubStatus { - return if (title.contains("Latino") || title.contains("Castellano")) - DubStatus.Dubbed - else DubStatus.Subbed - } - } - - override var mainUrl = "https://www3.animeflv.net" - override var name = "Animeflv.net" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.AnimeMovie, - TvType.OVA, - TvType.Anime, - ) - - override suspend fun getMainPage(page: Int, request : MainPageRequest): HomePageResponse { - val urls = listOf( - Pair("$mainUrl/browse?type[]=movie&order=updated", "Películas"), - Pair("$mainUrl/browse?status[]=2&order=default", "Animes"), - Pair("$mainUrl/browse?status[]=1&order=rating", "En emision"), - ) - val items = ArrayList() - items.add( - HomePageList( - "Últimos episodios", - app.get(mainUrl).document.select("main.Main ul.ListEpisodios li").mapNotNull { - val title = it.selectFirst("strong.Title")?.text() ?: return@mapNotNull null - val poster = it.selectFirst("span img")?.attr("src") ?: return@mapNotNull null - val epRegex = Regex("(-(\\d+)\$)") - val url = it.selectFirst("a")?.attr("href")?.replace(epRegex, "") - ?.replace("ver/", "anime/") ?: return@mapNotNull null - val epNum = - it.selectFirst("span.Capi")?.text()?.replace("Episodio ", "")?.toIntOrNull() - newAnimeSearchResponse(title, url) { - this.posterUrl = fixUrl(poster) - addDubStatus(getDubStatus(title), epNum) - } - }) - ) - for ((url, name) in urls) { - try { - val doc = app.get(url).document - val home = doc.select("ul.ListAnimes li article").mapNotNull { - val title = it.selectFirst("h3.Title")?.text() ?: return@mapNotNull null - val poster = it.selectFirst("figure img")?.attr("src") ?: return@mapNotNull null - newAnimeSearchResponse( - title, - fixUrl(it.selectFirst("a")?.attr("href") ?: return@mapNotNull null) - ) { - this.posterUrl = fixUrl(poster) - addDubStatus(getDubStatus(title)) - } - } - - items.add(HomePageList(name, home)) - } catch (e: Exception) { - e.printStackTrace() - } - } - if (items.size <= 0) throw ErrorLoadingException() - return HomePageResponse(items) - } - - data class SearchObject( - @JsonProperty("id") val id: String, - @JsonProperty("title") val title: String, - @JsonProperty("type") val type: String, - @JsonProperty("last_id") val lastId: String, - @JsonProperty("slug") val slug: String - ) - - override suspend fun search(query: String): List { - val response = app.post( - "https://www3.animeflv.net/api/animes/search", - data = mapOf(Pair("value", query)) - ).text - val json = parseJson>(response) - return json.map { searchr -> - val title = searchr.title - val href = "$mainUrl/anime/${searchr.slug}" - val image = "$mainUrl/uploads/animes/covers/${searchr.id}.jpg" - AnimeSearchResponse( - title, - href, - this.name, - TvType.Anime, - fixUrl(image), - null, - if (title.contains("Latino") || title.contains("Castellano")) EnumSet.of(DubStatus.Dubbed) else EnumSet.of( - DubStatus.Subbed - ), - ) - } - } - - override suspend fun load(url: String): LoadResponse { - val doc = app.get(url).document - val episodes = ArrayList() - val title = doc.selectFirst("h1.Title")!!.text() - val poster = doc.selectFirst("div.AnimeCover div.Image figure img")?.attr("src")!! - val description = doc.selectFirst("div.Description p")?.text() - val type = doc.selectFirst("span.Type")?.text() ?: "" - val status = when (doc.selectFirst("p.AnmStts span")?.text()) { - "En emision" -> ShowStatus.Ongoing - "Finalizado" -> ShowStatus.Completed - else -> null - } - val genre = doc.select("nav.Nvgnrs a") - .map { it?.text()?.trim().toString() } - - doc.select("script").map { script -> - if (script.data().contains("var episodes = [")) { - val data = script.data().substringAfter("var episodes = [").substringBefore("];") - data.split("],").forEach { - val epNum = it.removePrefix("[").substringBefore(",") - // val epthumbid = it.removePrefix("[").substringAfter(",").substringBefore("]") - val animeid = doc.selectFirst("div.Strs.RateIt")?.attr("data-id") - val epthumb = "https://cdn.animeflv.net/screenshots/$animeid/$epNum/th_3.jpg" - val link = url.replace("/anime/", "/ver/") + "-$epNum" - episodes.add( - Episode( - link, - null, - posterUrl = epthumb, - episode = epNum.toIntOrNull() - ) - ) - } - } - } - return newAnimeLoadResponse(title, url, getType(type)) { - posterUrl = fixUrl(poster) - addEpisodes(DubStatus.Subbed, episodes.reversed()) - showStatus = status - plot = description - tags = genre - } - } - - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - app.get(data).document.select("script").apmap { script -> - if (script.data().contains("var videos = {") || script.data() - .contains("var anime_id =") || script.data().contains("server") - ) { - val videos = script.data().replace("\\/", "/") - fetchUrls(videos).map { - it.replace("https://embedsb.com/e/", "https://watchsb.com/e/") - .replace("https://ok.ru", "http://ok.ru") - }.apmap { - loadExtractor(it, data, subtitleCallback, callback) - } - } - } - return true - } -} diff --git a/AnimeflvnetProvider/src/main/kotlin/com/lagradost/AnimeflvnetProviderPlugin.kt b/AnimeflvnetProvider/src/main/kotlin/com/lagradost/AnimeflvnetProviderPlugin.kt deleted file mode 100644 index 9f45880..0000000 --- a/AnimeflvnetProvider/src/main/kotlin/com/lagradost/AnimeflvnetProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class AnimeflvnetProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(AnimeflvnetProvider()) - } -} \ No newline at end of file diff --git a/CinecalidadProvider/build.gradle.kts b/CinecalidadProvider/build.gradle.kts deleted file mode 100644 index 1f46c5d..0000000 --- a/CinecalidadProvider/build.gradle.kts +++ /dev/null @@ -1,25 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "TvSeries", - "Movie", - ) - - iconUrl = "https://www.google.com/s2/favicons?domain=cinecalidad.lol&sz=24" -} \ No newline at end of file diff --git a/CinecalidadProvider/src/main/AndroidManifest.xml b/CinecalidadProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/CinecalidadProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/CinecalidadProvider/src/main/kotlin/com/lagradost/CinecalidadProvider.kt b/CinecalidadProvider/src/main/kotlin/com/lagradost/CinecalidadProvider.kt deleted file mode 100644 index fbeca40..0000000 --- a/CinecalidadProvider/src/main/kotlin/com/lagradost/CinecalidadProvider.kt +++ /dev/null @@ -1,258 +0,0 @@ -package com.lagradost - -import com.lagradost.cloudstream3.* -// import com.lagradost.cloudstream3.extractors.Cinestart -import com.lagradost.cloudstream3.utils.ExtractorLink -import com.lagradost.cloudstream3.utils.loadExtractor - -class CinecalidadProvider : MainAPI() { - override var mainUrl = "https://cinecalidad.lol" - override var name = "Cinecalidad" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.Movie, - TvType.TvSeries, - ) - override val vpnStatus = VPNStatus.MightBeNeeded //Due to evoload sometimes not loading - - override val mainPage = mainPageOf( - Pair("$mainUrl/ver-serie/page/", "Series"), - Pair("$mainUrl/page/", "Peliculas"), - Pair("$mainUrl/genero-de-la-pelicula/peliculas-en-calidad-4k/page/", "4K UHD"), - ) - - override suspend fun getMainPage( - page: Int, - request : MainPageRequest - ): HomePageResponse { - val url = request.data + page - - val soup = app.get(url).document - val home = soup.select(".item.movies").map { - val title = it.selectFirst("div.in_title")!!.text() - val link = it.selectFirst("a")!!.attr("href") - TvSeriesSearchResponse( - title, - link, - this.name, - if (link.contains("/ver-pelicula/")) TvType.Movie else TvType.TvSeries, - it.selectFirst(".poster.custom img")!!.attr("data-src"), - null, - null, - ) - } - - return newHomePageResponse(request.name, home) - } - - override suspend fun search(query: String): List { - val url = "$mainUrl/?s=${query}" - val document = app.get(url).document - - return document.select("article").map { - val title = it.selectFirst("div.in_title")!!.text() - val href = it.selectFirst("a")!!.attr("href") - val image = it.selectFirst(".poster.custom img")!!.attr("data-src") - val isMovie = href.contains("/ver-pelicula/") - - if (isMovie) { - MovieSearchResponse( - title, - href, - this.name, - TvType.Movie, - image, - null - ) - } else { - TvSeriesSearchResponse( - title, - href, - this.name, - TvType.TvSeries, - image, - null, - null - ) - } - } - } - - - override suspend fun load(url: String): LoadResponse? { - val soup = app.get(url, timeout = 120).document - - val title = soup.selectFirst(".single_left h1")!!.text() - val description = soup.selectFirst("div.single_left table tbody tr td p")?.text()?.trim() - val poster: String? = soup.selectFirst(".alignnone")!!.attr("data-src") - val episodes = soup.select("div.se-c div.se-a ul.episodios li").map { li -> - val href = li.selectFirst("a")!!.attr("href") - val epThumb = li.selectFirst("img.lazy")!!.attr("data-src") - val name = li.selectFirst(".episodiotitle a")!!.text() - val seasonid = - li.selectFirst(".numerando")!!.text().replace(Regex("(S|E)"), "").let { str -> - str.split("-").mapNotNull { subStr -> subStr.toIntOrNull() } - } - val isValid = seasonid.size == 2 - val episode = if (isValid) seasonid.getOrNull(1) else null - val season = if (isValid) seasonid.getOrNull(0) else null - Episode( - href, - name, - season, - episode, - if (epThumb.contains("svg")) null else epThumb - ) - } - return when (val tvType = - if (url.contains("/ver-pelicula/")) TvType.Movie else TvType.TvSeries) { - TvType.TvSeries -> { - TvSeriesLoadResponse( - title, - url, - this.name, - tvType, - episodes, - poster, - null, - description, - ) - } - TvType.Movie -> { - MovieLoadResponse( - title, - url, - this.name, - tvType, - url, - poster, - null, - description, - ) - } - else -> null - } - } - - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - - val datam = app.get(data) - val doc = datam.document - val datatext = datam.text - - doc.select(".dooplay_player_option").apmap { - val url = it.attr("data-option") -// if (url.startsWith("https://cinestart.net")) { -// val extractor = Cinestart() -// extractor.getSafeUrl(url, null, subtitleCallback, callback) -// } else { - loadExtractor(url, mainUrl, subtitleCallback, callback) -// } - if (url.startsWith("https://cinecalidad.lol")) { - val cineurlregex = - Regex("(https:\\/\\/cinecalidad\\.lol\\/play\\/\\?h=[a-zA-Z0-9]{0,8}[a-zA-Z0-9_-]+)") - cineurlregex.findAll(url).map { - it.value.replace("/play/", "/play/r.php") - }.toList().apmap { - app.get( - it, - headers = mapOf( - "Host" to "cinecalidad.lol", - "User-Agent" to USER_AGENT, - "Accept" to "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8", - "Accept-Language" to "en-US,en;q=0.5", - "DNT" to "1", - "Connection" to "keep-alive", - "Referer" to data, - "Upgrade-Insecure-Requests" to "1", - "Sec-Fetch-Dest" to "iframe", - "Sec-Fetch-Mode" to "navigate", - "Sec-Fetch-Site" to "same-origin", - "Sec-Fetch-User" to "?1", - ), - allowRedirects = false - ).okhttpResponse.headers.values("location").apmap { extractedurl -> - if (extractedurl.contains("cinestart")) { - loadExtractor(extractedurl, mainUrl, subtitleCallback, callback) - } - } - } - } - } - if (datatext.contains("en castellano")) app.get("$data?ref=es").document.select(".dooplay_player_option") - .apmap { - val url = it.attr("data-option") -// if (url.startsWith("https://cinestart.net")) { -// val extractor = Cinestart() -// extractor.getSafeUrl(url, null, subtitleCallback, callback) -// } else { - loadExtractor(url, mainUrl, subtitleCallback, callback) -// } - - if (url.startsWith("https://cinecalidad.lol")) { - val cineurlregex = - Regex("(https:\\/\\/cinecalidad\\.lol\\/play\\/\\?h=[a-zA-Z0-9]{0,8}[a-zA-Z0-9_-]+)") - cineurlregex.findAll(url).map { - it.value.replace("/play/", "/play/r.php") - }.toList().apmap { - app.get( - it, - headers = mapOf( - "Host" to "cinecalidad.lol", - "User-Agent" to USER_AGENT, - "Accept" to "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8", - "Accept-Language" to "en-US,en;q=0.5", - "DNT" to "1", - "Connection" to "keep-alive", - "Referer" to data, - "Upgrade-Insecure-Requests" to "1", - "Sec-Fetch-Dest" to "iframe", - "Sec-Fetch-Mode" to "navigate", - "Sec-Fetch-Site" to "same-origin", - "Sec-Fetch-User" to "?1", - ), - allowRedirects = false - ).okhttpResponse.headers.values("location").apmap { extractedurl -> - if (extractedurl.contains("cinestart")) { - loadExtractor(extractedurl, mainUrl, subtitleCallback, callback) - } - } - } - } - } - if (datatext.contains("Subtítulo LAT") || datatext.contains("Forzados LAT")) { - doc.select("#panel_descarga.pane a").apmap { - val link = - if (data.contains("serie") || data.contains("episodio")) "${data}${it.attr("href")}" - else it.attr("href") - val docsub = app.get(link) - val linksub = docsub.document - val validsub = docsub.text - if (validsub.contains("Subtítulo") || validsub.contains("Forzados")) { - val langregex = Regex("(Subtítulo.*\$|Forzados.*\$)") - val langdoc = linksub.selectFirst("div.titulo h3")!!.text() - val reallang = langregex.find(langdoc)?.destructured?.component1() - linksub.select("a.link").apmap { - val sublink = - if (data.contains("serie") || data.contains("episodio")) "${data}${ - it.attr("href") - }" - else it.attr("href") - subtitleCallback( - SubtitleFile(reallang!!, sublink) - ) - } - } - } - } - return true - } -} diff --git a/CinecalidadProvider/src/main/kotlin/com/lagradost/CinecalidadProviderPlugin.kt b/CinecalidadProvider/src/main/kotlin/com/lagradost/CinecalidadProviderPlugin.kt deleted file mode 100644 index cf4a2ca..0000000 --- a/CinecalidadProvider/src/main/kotlin/com/lagradost/CinecalidadProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class CinecalidadProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(CinecalidadProvider()) - } -} \ No newline at end of file diff --git a/CuevanaProvider/build.gradle.kts b/CuevanaProvider/build.gradle.kts deleted file mode 100644 index f8ef81e..0000000 --- a/CuevanaProvider/build.gradle.kts +++ /dev/null @@ -1,26 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "Anime", - "TvSeries", - "Movie", - ) - - iconUrl = "https://www.google.com/s2/favicons?domain=cuevana3.me&sz=24" -} \ No newline at end of file diff --git a/CuevanaProvider/src/main/AndroidManifest.xml b/CuevanaProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/CuevanaProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/CuevanaProvider/src/main/kotlin/com/lagradost/CuevanaProvider.kt b/CuevanaProvider/src/main/kotlin/com/lagradost/CuevanaProvider.kt deleted file mode 100644 index 9aab603..0000000 --- a/CuevanaProvider/src/main/kotlin/com/lagradost/CuevanaProvider.kt +++ /dev/null @@ -1,324 +0,0 @@ -package com.lagradost - -import com.fasterxml.jackson.annotation.JsonProperty -import com.lagradost.cloudstream3.* -import com.lagradost.cloudstream3.mvvm.logError -import com.lagradost.cloudstream3.utils.AppUtils.parseJson -import com.lagradost.cloudstream3.utils.ExtractorLink -import com.lagradost.cloudstream3.utils.loadExtractor - -class CuevanaProvider : MainAPI() { - override var mainUrl = "https://cuevana3.me" - override var name = "Cuevana" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.Movie, - TvType.TvSeries, - ) - - override suspend fun getMainPage(page: Int, request : MainPageRequest): HomePageResponse { - val items = ArrayList() - val urls = listOf( - Pair(mainUrl, "Recientemente actualizadas"), - Pair("$mainUrl/estrenos/", "Estrenos"), - ) - items.add( - HomePageList( - "Series", - app.get("$mainUrl/serie", timeout = 120).document.select("section.home-series li") - .map { - val title = it.selectFirst("h2.Title")!!.text() - val poster = it.selectFirst("img.lazy")!!.attr("data-src") - val url = it.selectFirst("a")!!.attr("href") - TvSeriesSearchResponse( - title, - url, - this.name, - TvType.Anime, - poster, - null, - null, - ) - }) - ) - for ((url, name) in urls) { - try { - val soup = app.get(url).document - val home = soup.select("section li.xxx.TPostMv").map { - val title = it.selectFirst("h2.Title")!!.text() - val link = it.selectFirst("a")!!.attr("href") - TvSeriesSearchResponse( - title, - link, - this.name, - if (link.contains("/pelicula/")) TvType.Movie else TvType.TvSeries, - it.selectFirst("img.lazy")!!.attr("data-src"), - null, - null, - ) - } - - items.add(HomePageList(name, home)) - } catch (e: Exception) { - logError(e) - } - } - - if (items.size <= 0) throw ErrorLoadingException() - return HomePageResponse(items) - } - - override suspend fun search(query: String): List { - val url = "$mainUrl/?s=${query}" - val document = app.get(url).document - - return document.select("li.xxx.TPostMv").map { - val title = it.selectFirst("h2.Title")!!.text() - val href = it.selectFirst("a")!!.attr("href") - val image = it.selectFirst("img.lazy")!!.attr("data-src") - val isSerie = href.contains("/serie/") - - if (isSerie) { - TvSeriesSearchResponse( - title, - href, - this.name, - TvType.TvSeries, - image, - null, - null - ) - } else { - MovieSearchResponse( - title, - href, - this.name, - TvType.Movie, - image, - null - ) - } - } - } - - override suspend fun load(url: String): LoadResponse? { - val soup = app.get(url, timeout = 120).document - val title = soup.selectFirst("h1.Title")!!.text() - val description = soup.selectFirst(".Description p")?.text()?.trim() - val poster: String? = soup.selectFirst(".movtv-info div.Image img")!!.attr("data-src") - val year1 = soup.selectFirst("footer p.meta").toString() - val yearRegex = Regex("(\\d+)") - val yearf = - yearRegex.find(year1)?.destructured?.component1()?.replace(Regex("|"), "") - val year = if (yearf.isNullOrBlank()) null else yearf.toIntOrNull() - val episodes = soup.select(".all-episodes li.TPostMv article").map { li -> - val href = li.select("a").attr("href") - val epThumb = - li.selectFirst("div.Image img")?.attr("data-src") ?: li.selectFirst("img.lazy")!! - .attr("data-srcc") - val seasonid = li.selectFirst("span.Year")!!.text().let { str -> - str.split("x").mapNotNull { subStr -> subStr.toIntOrNull() } - } - val isValid = seasonid.size == 2 - val episode = if (isValid) seasonid.getOrNull(1) else null - val season = if (isValid) seasonid.getOrNull(0) else null - Episode( - href, - null, - season, - episode, - fixUrl(epThumb) - ) - } - val tags = soup.select("ul.InfoList li.AAIco-adjust:contains(Genero) a").map { it.text() } - val tvType = if (episodes.isEmpty()) TvType.Movie else TvType.TvSeries - val recelement = - if (tvType == TvType.TvSeries) "main section div.series_listado.series div.xxx" - else "main section ul.MovieList li" - val recommendations = - soup.select(recelement).mapNotNull { element -> - val recTitle = element.select("h2.Title").text() ?: return@mapNotNull null - val image = element.select("figure img")?.attr("data-src") - val recUrl = fixUrl(element.select("a").attr("href")) - MovieSearchResponse( - recTitle, - recUrl, - this.name, - TvType.Movie, - image, - year = null - ) - } - - return when (tvType) { - TvType.TvSeries -> { - TvSeriesLoadResponse( - title, - url, - this.name, - tvType, - episodes, - poster, - year, - description, - tags = tags, - recommendations = recommendations - ) - } - TvType.Movie -> { - MovieLoadResponse( - title, - url, - this.name, - tvType, - url, - poster, - year, - description, - tags = tags, - recommendations = recommendations - ) - } - else -> null - } - } - - data class Femcuevana( - @JsonProperty("url") val url: String, - ) - - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - app.get(data).document.select("div.TPlayer.embed_div iframe").apmap { - val iframe = fixUrl(it.attr("data-src")) - if (iframe.contains("api.cuevana3.me/fembed/")) { - val femregex = - Regex("(https.\\/\\/api\\.cuevana3\\.me\\/fembed\\/\\?h=[a-zA-Z0-9]{0,8}[a-zA-Z0-9_-]+)") - femregex.findAll(iframe).map { femreg -> - femreg.value - }.toList().apmap { fem -> - val key = fem.replace("https://api.cuevana3.me/fembed/?h=", "") - val url = app.post( - "https://api.cuevana3.me/fembed/api.php", - allowRedirects = false, - headers = mapOf( - "Host" to "api.cuevana3.me", - "User-Agent" to USER_AGENT, - "Accept" to "application/json, text/javascript, */*; q=0.01", - "Accept-Language" to "en-US,en;q=0.5", - "Content-Type" to "application/x-www-form-urlencoded; charset=UTF-8", - "X-Requested-With" to "XMLHttpRequest", - "Origin" to "https://api.cuevana3.me", - "DNT" to "1", - "Connection" to "keep-alive", - "Sec-Fetch-Dest" to "empty", - "Sec-Fetch-Mode" to "cors", - "Sec-Fetch-Site" to "same-origin", - ), - data = mapOf(Pair("h", key)) - ).text - val json = parseJson(url) - val link = json.url - if (link.contains("fembed")) { - loadExtractor(link, data, subtitleCallback, callback) - } - } - } - if (iframe.contains("tomatomatela")) { - val tomatoRegex = - Regex("(\\/\\/apialfa.tomatomatela.com\\/ir\\/player.php\\?h=[a-zA-Z0-9]{0,8}[a-zA-Z0-9_-]+)") - tomatoRegex.findAll(iframe).map { tomreg -> - tomreg.value - }.toList().apmap { tom -> - val tomkey = tom.replace("//apialfa.tomatomatela.com/ir/player.php?h=", "") - app.post( - "https://apialfa.tomatomatela.com/ir/rd.php", allowRedirects = false, - headers = mapOf( - "Host" to "apialfa.tomatomatela.com", - "User-Agent" to USER_AGENT, - "Accept" to "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8", - "Accept-Language" to "en-US,en;q=0.5", - "Content-Type" to "application/x-www-form-urlencoded", - "Origin" to "null", - "DNT" to "1", - "Connection" to "keep-alive", - "Upgrade-Insecure-Requests" to "1", - "Sec-Fetch-Dest" to "iframe", - "Sec-Fetch-Mode" to "navigate", - "Sec-Fetch-Site" to "same-origin", - ), - data = mapOf(Pair("url", tomkey)) - ).okhttpResponse.headers.values("location").apmap { loc -> - if (loc.contains("goto_ddh.php")) { - val gotoregex = - Regex("(\\/\\/api.cuevana3.me\\/ir\\/goto_ddh.php\\?h=[a-zA-Z0-9]{0,8}[a-zA-Z0-9_-]+)") - gotoregex.findAll(loc).map { goreg -> - goreg.value.replace("//api.cuevana3.me/ir/goto_ddh.php?h=", "") - }.toList().apmap { gotolink -> - app.post( - "https://api.cuevana3.me/ir/redirect_ddh.php", - allowRedirects = false, - headers = mapOf( - "Host" to "api.cuevana3.me", - "User-Agent" to USER_AGENT, - "Accept" to "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8", - "Accept-Language" to "en-US,en;q=0.5", - "Content-Type" to "application/x-www-form-urlencoded", - "Origin" to "null", - "DNT" to "1", - "Connection" to "keep-alive", - "Upgrade-Insecure-Requests" to "1", - "Sec-Fetch-Dest" to "iframe", - "Sec-Fetch-Mode" to "navigate", - "Sec-Fetch-Site" to "same-origin", - ), - data = mapOf(Pair("url", gotolink)) - ).okhttpResponse.headers.values("location").apmap { golink -> - loadExtractor(golink, data, subtitleCallback, callback) - } - } - } - if (loc.contains("index.php?h=")) { - val indexRegex = - Regex("(\\/\\/api.cuevana3.me\\/sc\\/index.php\\?h=[a-zA-Z0-9]{0,8}[a-zA-Z0-9_-]+)") - indexRegex.findAll(loc).map { indreg -> - indreg.value.replace("//api.cuevana3.me/sc/index.php?h=", "") - }.toList().apmap { inlink -> - app.post( - "https://api.cuevana3.me/sc/r.php", allowRedirects = false, - headers = mapOf( - "Host" to "api.cuevana3.me", - "User-Agent" to USER_AGENT, - "Accept" to "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8", - "Accept-Language" to "en-US,en;q=0.5", - "Accept-Encoding" to "gzip, deflate, br", - "Content-Type" to "application/x-www-form-urlencoded", - "Origin" to "null", - "DNT" to "1", - "Connection" to "keep-alive", - "Upgrade-Insecure-Requests" to "1", - "Sec-Fetch-Dest" to "iframe", - "Sec-Fetch-Mode" to "navigate", - "Sec-Fetch-Site" to "same-origin", - "Sec-Fetch-User" to "?1", - ), - data = mapOf(Pair("h", inlink)) - ).okhttpResponse.headers.values("location").apmap { link -> - loadExtractor(link, data, subtitleCallback, callback) - } - } - } - } - } - } - } - return true - } -} \ No newline at end of file diff --git a/CuevanaProvider/src/main/kotlin/com/lagradost/CuevanaProviderPlugin.kt b/CuevanaProvider/src/main/kotlin/com/lagradost/CuevanaProviderPlugin.kt deleted file mode 100644 index a126075..0000000 --- a/CuevanaProvider/src/main/kotlin/com/lagradost/CuevanaProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class CuevanaProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(CuevanaProvider()) - } -} \ No newline at end of file diff --git a/DoramasYTProvider/build.gradle.kts b/DoramasYTProvider/build.gradle.kts deleted file mode 100644 index d590c87..0000000 --- a/DoramasYTProvider/build.gradle.kts +++ /dev/null @@ -1,25 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "Anime", - "OVA", - ) - - iconUrl = "https://www.google.com/s2/favicons?domain=doramasyt.com&sz=24" -} \ No newline at end of file diff --git a/DoramasYTProvider/src/main/AndroidManifest.xml b/DoramasYTProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/DoramasYTProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/DoramasYTProvider/src/main/kotlin/com/lagradost/DoramasYTProvider.kt b/DoramasYTProvider/src/main/kotlin/com/lagradost/DoramasYTProvider.kt deleted file mode 100644 index 8f3b5a6..0000000 --- a/DoramasYTProvider/src/main/kotlin/com/lagradost/DoramasYTProvider.kt +++ /dev/null @@ -1,155 +0,0 @@ -package com.lagradost - -import com.lagradost.cloudstream3.* -//import com.lagradost.cloudstream3.extractors.FEmbed -import com.lagradost.cloudstream3.utils.ExtractorLink -import com.lagradost.cloudstream3.utils.loadExtractor -import java.util.* - - -class DoramasYTProvider : MainAPI() { - companion object { - fun getType(t: String): TvType { - return if (t.contains("OVA") || t.contains("Especial")) TvType.OVA - else if (t.contains("Pelicula")) TvType.Movie - else TvType.TvSeries - } - fun getDubStatus(title: String): DubStatus { - return if (title.contains("Latino") || title.contains("Castellano")) - DubStatus.Dubbed - else DubStatus.Subbed - } - } - - override var mainUrl = "https://doramasyt.com" - override var name = "DoramasYT" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.AsianDrama, - ) - - override suspend fun getMainPage(page: Int, request : MainPageRequest): HomePageResponse { - val urls = listOf( - Pair("$mainUrl/emision", "En emisión"), - Pair( - "$mainUrl/doramas?categoria=pelicula&genero=false&fecha=false&letra=false", - "Peliculas" - ), - Pair("$mainUrl/doramas", "Doramas"), - Pair( - "$mainUrl/doramas?categoria=live-action&genero=false&fecha=false&letra=false", - "Live Action" - ), - ) - - val items = ArrayList() - - items.add( - HomePageList( - "Capítulos actualizados", - app.get(mainUrl, timeout = 120).document.select(".col-6").map { - val title = it.selectFirst("p")!!.text() - val poster = it.selectFirst(".chapter img")!!.attr("src") - val epRegex = Regex("episodio-(\\d+)") - val url = it.selectFirst("a")!!.attr("href").replace("ver/", "dorama/") - .replace(epRegex, "sub-espanol") - val epNum = it.selectFirst("h3")!!.text().toIntOrNull() - newAnimeSearchResponse(title,url) { - this.posterUrl = fixUrl(poster) - addDubStatus(getDubStatus(title), epNum) - } - }) - ) - - for (i in urls) { - try { - val home = app.get(i.first, timeout = 120).document.select(".col-6").map { - val title = it.selectFirst(".animedtls p")!!.text() - val poster = it.selectFirst(".anithumb img")!!.attr("src") - newAnimeSearchResponse(title, fixUrl(it.selectFirst("a")!!.attr("href"))) { - this.posterUrl = fixUrl(poster) - addDubStatus(getDubStatus(title)) - } - } - - items.add(HomePageList(i.second, home)) - } catch (e: Exception) { - e.printStackTrace() - } - } - - if (items.size <= 0) throw ErrorLoadingException() - return HomePageResponse(items) - } - - override suspend fun search(query: String): List { - return app.get("$mainUrl/buscar?q=$query", timeout = 120).document.select(".col-6").map { - val title = it.selectFirst(".animedtls p")!!.text() - val href = it.selectFirst("a")!!.attr("href") - val image = it.selectFirst(".animes img")!!.attr("src") - AnimeSearchResponse( - title, - href, - this.name, - TvType.Anime, - image, - null, - if (title.contains("Latino") || title.contains("Castellano")) EnumSet.of( - DubStatus.Dubbed - ) else EnumSet.of(DubStatus.Subbed), - ) - } - } - - override suspend fun load(url: String): LoadResponse { - val doc = app.get(url, timeout = 120).document - val poster = doc.selectFirst("div.flimimg img.img1")!!.attr("src") - val title = doc.selectFirst("h1")!!.text() - val type = doc.selectFirst("h4")!!.text() - val description = doc.selectFirst("p.textComplete")!!.text().replace("Ver menos", "") - val genres = doc.select(".nobel a").map { it.text() } - val status = when (doc.selectFirst(".state h6")?.text()) { - "Estreno" -> ShowStatus.Ongoing - "Finalizado" -> ShowStatus.Completed - else -> null - } - val episodes = doc.select(".heromain .col-item").map { - val name = it.selectFirst(".dtlsflim p")!!.text() - val link = it.selectFirst("a")!!.attr("href") - val epThumb = it.selectFirst(".flimimg img.img1")!!.attr("src") - Episode(link, name, posterUrl = epThumb) - } - return newAnimeLoadResponse(title, url, getType(type)) { - posterUrl = poster - addEpisodes(DubStatus.Subbed, episodes) - showStatus = status - plot = description - tags = genres - } - } - - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - app.get(data).document.select("div.playother p").apmap { - val encodedurl = it.select("p").attr("data-player") - val urlDecoded = base64Decode(encodedurl) - val url = (urlDecoded).replace("https://doramasyt.com/reproductor?url=", "") - if (url.startsWith("https://www.fembed.com")) { - val extractor = FEmbed() - extractor.getUrl(url).forEach { link -> - callback.invoke(link) - } - } else { - loadExtractor(url, mainUrl, subtitleCallback, callback) - } - } - return true - } -} \ No newline at end of file diff --git a/DoramasYTProvider/src/main/kotlin/com/lagradost/DoramasYTProviderPlugin.kt b/DoramasYTProvider/src/main/kotlin/com/lagradost/DoramasYTProviderPlugin.kt deleted file mode 100644 index e5652d9..0000000 --- a/DoramasYTProvider/src/main/kotlin/com/lagradost/DoramasYTProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class DoramasYTProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(DoramasYTProvider()) - } -} \ No newline at end of file diff --git a/DoramasYTProvider/src/main/kotlin/com/lagradost/XStreamCdn.kt b/DoramasYTProvider/src/main/kotlin/com/lagradost/XStreamCdn.kt deleted file mode 100644 index 866aee0..0000000 --- a/DoramasYTProvider/src/main/kotlin/com/lagradost/XStreamCdn.kt +++ /dev/null @@ -1,67 +0,0 @@ -package com.lagradost - -import com.fasterxml.jackson.annotation.JsonProperty -import com.lagradost.cloudstream3.app -import com.lagradost.cloudstream3.utils.AppUtils -import com.lagradost.cloudstream3.utils.ExtractorApi -import com.lagradost.cloudstream3.utils.ExtractorLink -import com.lagradost.cloudstream3.utils.getQualityFromName - -class FEmbed: XStreamCdn() { - override val name: String = "FEmbed" - override val mainUrl: String = "https://www.fembed.com" -} - -open class XStreamCdn : ExtractorApi() { - override val name: String = "XStreamCdn" - override val mainUrl: String = "https://embedsito.com" - override val requiresReferer = false - open var domainUrl: String = "embedsito.com" - - private data class ResponseData( - @JsonProperty("file") val file: String, - @JsonProperty("label") val label: String, - //val type: String // Mp4 - ) - - private data class ResponseJson( - @JsonProperty("success") val success: Boolean, - @JsonProperty("data") val data: List? - ) - - override fun getExtractorUrl(id: String): String { - return "$domainUrl/api/source/$id" - } - - override suspend fun getUrl(url: String, referer: String?): List { - val headers = mapOf( - "Referer" to url, - "User-Agent" to "Mozilla/5.0 (Windows NT 10.0; rv:78.0) Gecko/20100101 Firefox/78.0", - ) - val id = url.trimEnd('/').split("/").last() - val newUrl = "https://${domainUrl}/api/source/${id}" - val extractedLinksList: MutableList = mutableListOf() - with(app.post(newUrl, headers = headers)) { - if (this.code != 200) return listOf() - val text = this.text - if (text.isEmpty()) return listOf() - if (text == """{"success":false,"data":"Video not found or has been removed"}""") return listOf() - AppUtils.parseJson(text)?.let { - if (it.success && it.data != null) { - it.data.forEach { data -> - extractedLinksList.add( - ExtractorLink( - name, - name = name, - data.file, - url, - getQualityFromName(data.label), - ) - ) - } - } - } - } - return extractedLinksList - } -} \ No newline at end of file diff --git a/ElifilmsProvider/build.gradle.kts b/ElifilmsProvider/build.gradle.kts deleted file mode 100644 index 1e957a0..0000000 --- a/ElifilmsProvider/build.gradle.kts +++ /dev/null @@ -1,23 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "Movie", - ) - - } \ No newline at end of file diff --git a/ElifilmsProvider/src/main/AndroidManifest.xml b/ElifilmsProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/ElifilmsProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/ElifilmsProvider/src/main/kotlin/com/lagradost/ElifilmsProvider.kt b/ElifilmsProvider/src/main/kotlin/com/lagradost/ElifilmsProvider.kt deleted file mode 100644 index f2ef65a..0000000 --- a/ElifilmsProvider/src/main/kotlin/com/lagradost/ElifilmsProvider.kt +++ /dev/null @@ -1,94 +0,0 @@ -package com.lagradost - -import com.lagradost.cloudstream3.* -import com.lagradost.cloudstream3.utils.ExtractorLink -import com.lagradost.cloudstream3.utils.loadExtractor - -class ElifilmsProvider : MainAPI() { - override var mainUrl: String = "https://elifilms.net" - override var name: String = "Elifilms" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.Movie, - ) - - override suspend fun getMainPage(page: Int, request : MainPageRequest): HomePageResponse { - val items = ArrayList() - val newest = app.get(mainUrl).document.selectFirst("a.fav_link.premiera")?.attr("href") - val urls = listOf( - Pair(mainUrl, "Películas recientes"), - Pair("$mainUrl/4k-peliculas/", "Películas en 4k"), - Pair(newest, "Últimos estrenos"), - ) - urls.apmap { (url, name) -> - val soup = app.get(url ?: "").document - val home = soup.select("article.shortstory.cf").map { - val title = it.selectFirst(".short_header")?.text() ?: "" - val link = it.selectFirst("div a")?.attr("href") ?: "" - TvSeriesSearchResponse( - title, - link, - this.name, - TvType.Movie, - it.selectFirst("a.ah-imagge img")?.attr("data-src"), - null, - null, - ) - } - items.add(HomePageList(name, home)) - } - if (items.size <= 0) throw ErrorLoadingException() - return HomePageResponse(items) - } - - override suspend fun search(query: String): List { - val url = "$mainUrl/?s=$query" - val doc = app.get(url).document - return doc.select("article.cf").map { - val href = it.selectFirst("div.short_content a")?.attr("href") ?: "" - val poster = it.selectFirst("a.ah-imagge img")?.attr("data-src") - val name = it.selectFirst(".short_header")?.text() ?: "" - (MovieSearchResponse(name, href, this.name, TvType.Movie, poster, null)) - } - } - - override suspend fun load(url: String): LoadResponse { - val document = app.get(url, timeout = 120).document - val title = document.selectFirst(".post_title h1")?.text() ?: "" - val rating = document.select("span.imdb.rki").toString().toIntOrNull() - val poster = document.selectFirst(".poster img")?.attr("src") - val desc = document.selectFirst("div.notext .actors p")?.text() - val tags = document.select("td.notext a") - .map { it?.text()?.trim().toString() } - return MovieLoadResponse( - title, - url, - this.name, - TvType.Movie, - url, - poster, - null, - desc, - rating, - tags - ) - } - - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - app.get(data).document.select("li.change-server a").apmap { - val encodedurl = it.attr("data-id") - val urlDecoded = base64Decode(encodedurl) - val url = fixUrl(urlDecoded) - loadExtractor(url, data, subtitleCallback, callback) - } - return true - } -} diff --git a/ElifilmsProvider/src/main/kotlin/com/lagradost/ElifilmsProviderPlugin.kt b/ElifilmsProvider/src/main/kotlin/com/lagradost/ElifilmsProviderPlugin.kt deleted file mode 100644 index c719279..0000000 --- a/ElifilmsProvider/src/main/kotlin/com/lagradost/ElifilmsProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class ElifilmsProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(ElifilmsProvider()) - } -} \ No newline at end of file diff --git a/EntrepeliculasyseriesProvider/build.gradle.kts b/EntrepeliculasyseriesProvider/build.gradle.kts deleted file mode 100644 index ea3351a..0000000 --- a/EntrepeliculasyseriesProvider/build.gradle.kts +++ /dev/null @@ -1,25 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "TvSeries", - "Movie", - ) - - iconUrl = "https://www.google.com/s2/favicons?domain=entrepeliculasyseries.nu&sz=24" -} \ No newline at end of file diff --git a/EntrepeliculasyseriesProvider/src/main/AndroidManifest.xml b/EntrepeliculasyseriesProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/EntrepeliculasyseriesProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/EntrepeliculasyseriesProvider/src/main/kotlin/com/lagradost/EntrepeliculasyseriesProvider.kt b/EntrepeliculasyseriesProvider/src/main/kotlin/com/lagradost/EntrepeliculasyseriesProvider.kt deleted file mode 100644 index 7832cb9..0000000 --- a/EntrepeliculasyseriesProvider/src/main/kotlin/com/lagradost/EntrepeliculasyseriesProvider.kt +++ /dev/null @@ -1,177 +0,0 @@ -package com.lagradost - -import com.lagradost.cloudstream3.* -import com.lagradost.cloudstream3.utils.ExtractorLink -import com.lagradost.cloudstream3.utils.loadExtractor - -class EntrepeliculasyseriesProvider : MainAPI() { - override var mainUrl = "https://entrepeliculasyseries.nu" - override var name = "EntrePeliculasySeries" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.Movie, - TvType.TvSeries, - ) - override val vpnStatus = VPNStatus.MightBeNeeded //Due to evoload sometimes not loading - - override val mainPage = mainPageOf( - Pair("$mainUrl/series/page/", "Series"), - Pair("$mainUrl/peliculas/page/", "Peliculas"), - Pair("$mainUrl/anime/page/", "Animes"), - ) - - override suspend fun getMainPage( - page: Int, - request : MainPageRequest - ): HomePageResponse { - val url = request.data + page - - val soup = app.get(url).document - val home = soup.select("ul.list-movie li").map { - val title = it.selectFirst("a.link-title h2")!!.text() - val link = it.selectFirst("a")!!.attr("href") - TvSeriesSearchResponse( - title, - link, - this.name, - if (link.contains("/pelicula/")) TvType.Movie else TvType.TvSeries, - it.selectFirst("a.poster img")!!.attr("src"), - null, - null, - ) - } - - return newHomePageResponse(request.name, home) - } - - override suspend fun search(query: String): List { - val url = "$mainUrl/?s=${query}" - val document = app.get(url).document - - return document.select("li.xxx.TPostMv").map { - val title = it.selectFirst("h2.Title")!!.text() - val href = it.selectFirst("a")!!.attr("href") - val image = it.selectFirst("img.lazy")!!.attr("data-src") - val isMovie = href.contains("/pelicula/") - - if (isMovie) { - MovieSearchResponse( - title, - href, - this.name, - TvType.Movie, - image, - null - ) - } else { - TvSeriesSearchResponse( - title, - href, - this.name, - TvType.TvSeries, - image, - null, - null - ) - } - }.toList() - } - - - override suspend fun load(url: String): LoadResponse? { - val soup = app.get(url, timeout = 120).document - - val title = soup.selectFirst("h1.title-post")!!.text() - val description = soup.selectFirst("p.text-content:nth-child(3)")?.text()?.trim() - val poster: String? = soup.selectFirst("article.TPost img.lazy")!!.attr("data-src") - val episodes = soup.select(".TPostMv article").map { li -> - val href = (li.select("a") ?: li.select(".C a") ?: li.select("article a")).attr("href") - val epThumb = li.selectFirst("div.Image img")!!.attr("data-src") - val seasonid = li.selectFirst("span.Year")!!.text().let { str -> - str.split("x").mapNotNull { subStr -> subStr.toIntOrNull() } - } - val isValid = seasonid.size == 2 - val episode = if (isValid) seasonid.getOrNull(1) else null - val season = if (isValid) seasonid.getOrNull(0) else null - Episode( - href, - null, - season, - episode, - fixUrl(epThumb) - ) - } - return when (val tvType = - if (url.contains("/pelicula/")) TvType.Movie else TvType.TvSeries) { - TvType.TvSeries -> { - TvSeriesLoadResponse( - title, - url, - this.name, - tvType, - episodes, - poster, - null, - description, - ) - } - TvType.Movie -> { - MovieLoadResponse( - title, - url, - this.name, - tvType, - url, - poster, - null, - description, - ) - } - else -> null - } - } - - - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - app.get(data).document.select(".video ul.dropdown-menu li").apmap { - val servers = it.attr("data-link") - val doc = app.get(servers).document - doc.select("input").apmap { - val postkey = it.attr("value") - app.post( - "https://entrepeliculasyseries.nu/r.php", - headers = mapOf( - "Host" to "entrepeliculasyseries.nu", - "User-Agent" to USER_AGENT, - "Accept" to "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8", - "Accept-Language" to "en-US,en;q=0.5", - "Content-Type" to "application/x-www-form-urlencoded", - "Origin" to "https://entrepeliculasyseries.nu", - "DNT" to "1", - "Connection" to "keep-alive", - "Referer" to servers, - "Upgrade-Insecure-Requests" to "1", - "Sec-Fetch-Dest" to "document", - "Sec-Fetch-Mode" to "navigate", - "Sec-Fetch-Site" to "same-origin", - "Sec-Fetch-User" to "?1", - ), - //params = mapOf(Pair("h", postkey)), - data = mapOf(Pair("h", postkey)), - allowRedirects = false - ).okhttpResponse.headers.values("location").apmap { - loadExtractor(it, data, subtitleCallback, callback) - } - } - } - return true - } -} \ No newline at end of file diff --git a/EntrepeliculasyseriesProvider/src/main/kotlin/com/lagradost/EntrepeliculasyseriesProviderPlugin.kt b/EntrepeliculasyseriesProvider/src/main/kotlin/com/lagradost/EntrepeliculasyseriesProviderPlugin.kt deleted file mode 100644 index b165d5b..0000000 --- a/EntrepeliculasyseriesProvider/src/main/kotlin/com/lagradost/EntrepeliculasyseriesProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class EntrepeliculasyseriesProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(EntrepeliculasyseriesProvider()) - } -} \ No newline at end of file diff --git a/EstrenosDoramasProvider/build.gradle.kts b/EstrenosDoramasProvider/build.gradle.kts deleted file mode 100644 index a190f2d..0000000 --- a/EstrenosDoramasProvider/build.gradle.kts +++ /dev/null @@ -1,26 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "AsianDrama", - "Movie", - "OVA", - ) - - iconUrl = "https://www.google.com/s2/favicons?domain=www23.estrenosdoramas.net&sz=24" -} \ No newline at end of file diff --git a/EstrenosDoramasProvider/src/main/AndroidManifest.xml b/EstrenosDoramasProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/EstrenosDoramasProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/EstrenosDoramasProvider/src/main/kotlin/com/lagradost/EstrenosDoramasProvider.kt b/EstrenosDoramasProvider/src/main/kotlin/com/lagradost/EstrenosDoramasProvider.kt deleted file mode 100644 index 5b14c53..0000000 --- a/EstrenosDoramasProvider/src/main/kotlin/com/lagradost/EstrenosDoramasProvider.kt +++ /dev/null @@ -1,286 +0,0 @@ -package com.lagradost - -import com.fasterxml.jackson.annotation.JsonProperty -import com.lagradost.cloudstream3.* -import com.lagradost.cloudstream3.network.WebViewResolver -import com.lagradost.cloudstream3.utils.* -import com.lagradost.cloudstream3.utils.AppUtils.parseJson -import java.util.* -import kotlin.collections.ArrayList - - -class EstrenosDoramasProvider : MainAPI() { - companion object { - fun getType(t: String): TvType { - return if (t.contains("OVA") || t.contains("Especial")) TvType.OVA - else if (t.contains("Pelicula")) TvType.Movie - else TvType.TvSeries - } - } - - override var mainUrl = "https://www23.estrenosdoramas.net" - override var name = "EstrenosDoramas" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.AsianDrama, - ) - - override suspend fun getMainPage(page: Int, request : MainPageRequest): HomePageResponse { - val urls = listOf( - Pair(mainUrl, "Últimas series"), - Pair("$mainUrl/category/peliculas", "Películas"), - ) - - val items = ArrayList() - - urls.apmap { (url, name) -> - val home = app.get(url, timeout = 120).document.select("div.clearfix").map { - val title = cleanTitle(it.selectFirst("h3 a")?.text()!!) - val poster = it.selectFirst("img.cate_thumb")?.attr("src") - AnimeSearchResponse( - title, - it.selectFirst("a")?.attr("href")!!, - this.name, - TvType.AsianDrama, - poster, - null, - if (title.contains("Latino") || title.contains("Castellano")) EnumSet.of( - DubStatus.Dubbed - ) else EnumSet.of(DubStatus.Subbed), - ) - } - items.add(HomePageList(name, home)) - } - - if (items.size <= 0) throw ErrorLoadingException() - return HomePageResponse(items) - } - - override suspend fun search(query: String): List { - val searchob = ArrayList() - val search = - app.get("$mainUrl/?s=$query", timeout = 120).document.select("div.clearfix").map { - val title = cleanTitle(it.selectFirst("h3 a")?.text()!!) - val href = it.selectFirst("a")?.attr("href") - val image = it.selectFirst("img.cate_thumb")?.attr("src") - val lists = - AnimeSearchResponse( - title, - href!!, - this.name, - TvType.AsianDrama, - image, - null, - if (title.contains("Latino") || title.contains("Castellano")) EnumSet.of( - DubStatus.Dubbed - ) else EnumSet.of(DubStatus.Subbed), - ) - if (href.contains("capitulo")) { - //nothing - } - else { - searchob.add(lists) - } - } - return searchob - } - - override suspend fun load(url: String): LoadResponse? { - val doc = app.get(url, timeout = 120).document - val poster = doc.selectFirst("head meta[property]")?.attr("content") - val title = doc.selectFirst("h1.titulo")?.text() - val description = try { - doc.selectFirst("div.post div.highlight div.font")?.text() - } catch (e:Exception){ - null - } - val finaldesc = description?.substringAfter("Sinopsis")?.replace(": ", "")?.trim() - val epi = ArrayList() - val episodes = doc.select("div.post .lcp_catlist a").map { - val name = it.selectFirst("a")?.text() - val link = it.selectFirst("a")?.attr("href") - val test = Episode(link!!, name) - if (!link.equals(url)) { - epi.add(test) - } - }.reversed() - return when (val type = if (episodes.isEmpty()) TvType.Movie else TvType.AsianDrama) { - TvType.AsianDrama -> { - return newAnimeLoadResponse(title!!, url, type) { - japName = null - engName = title.replace(Regex("[Pp]elicula |[Pp]elicula"),"") - posterUrl = poster - addEpisodes(DubStatus.Subbed, epi.reversed()) - plot = finaldesc - } - } - TvType.Movie -> { - MovieLoadResponse( - cleanTitle(title!!), - url, - this.name, - TvType.Movie, - url, - poster, - null, - finaldesc, - null, - null, - ) - } - else -> null - } - - } - - - - data class ReproDoramas ( - @JsonProperty("link") val link: String, - @JsonProperty("time") val time: Int - ) - - private fun cleanTitle(title: String): String = title.replace(Regex("[Pp]elicula |[Pp]elicula"),"") - - private fun cleanExtractor( - source: String, - name: String, - url: String, - referer: String, - m3u8: Boolean, - callback: (ExtractorLink) -> Unit - ): Boolean { - callback( - ExtractorLink( - source, - name, - url, - referer, - Qualities.Unknown.value, - m3u8 - ) - ) - return true - } - - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - val headers = mapOf("Host" to "repro3.estrenosdoramas.us", - "User-Agent" to USER_AGENT, - "Accept" to "*/*", - "Accept-Language" to "en-US,en;q=0.5", - "Content-Type" to "application/x-www-form-urlencoded; charset=UTF-8", - "X-Requested-With" to "XMLHttpRequest", - "Origin" to "https://repro3.estrenosdoramas.us", - "DNT" to "1", - "Connection" to "keep-alive", - "Sec-Fetch-Dest" to "empty", - "Sec-Fetch-Mode" to "cors", - "Sec-Fetch-Site" to "same-origin", - "Cache-Control" to "max-age=0",) - - val document = app.get(data).document - document.select("div.tab_container iframe").apmap { container -> - val directlink = fixUrl(container.attr("src")) - loadExtractor(directlink, data, subtitleCallback, callback) - - if (directlink.contains("/repro/amz/")) { - val amzregex = Regex("https:\\/\\/repro3\\.estrenosdoramas\\.us\\/repro\\/amz\\/examples\\/.*\\.php\\?key=.*\$") - amzregex.findAll(directlink).map { - it.value.replace(Regex("https:\\/\\/repro3\\.estrenosdoramas\\.us\\/repro\\/amz\\/examples\\/.*\\.php\\?key="),"") - }.toList().apmap { key -> - val response = app.post("https://repro3.estrenosdoramas.us/repro/amz/examples/player/api/indexDCA.php", - headers = headers, - data = mapOf( - Pair("key",key), - Pair("token","MDAwMDAwMDAwMA=="), - ), - allowRedirects = false - ).text - val reprojson = parseJson(response) - val decodeurl = base64Decode(reprojson.link) - if (decodeurl.contains("m3u8")) - - cleanExtractor( - name, - name, - decodeurl, - "https://repro3.estrenosdoramas.us", - decodeurl.contains(".m3u8"), - callback - ) - } - } - - - if (directlink.contains("reproducir14")) { - val regex = Regex("(https:\\/\\/repro.\\.estrenosdoramas\\.us\\/repro\\/reproducir14\\.php\\?key=[a-zA-Z0-9]{0,8}[a-zA-Z0-9_-]+)") - regex.findAll(directlink).map { - it.value - }.toList().apmap { - val doc = app.get(it).text - val videoid = doc.substringAfter("vid=\"").substringBefore("\" n") - val token = doc.substringAfter("name=\"").substringBefore("\" s") - val acctkn = doc.substringAfter("{ acc: \"").substringBefore("\", id:") - val link = app.post("https://repro3.estrenosdoramas.us/repro/proto4.php", - headers = headers, - data = mapOf( - Pair("acc",acctkn), - Pair("id",videoid), - Pair("tk",token)), - allowRedirects = false - ).text - val extracteklink = link.substringAfter("\"urlremoto\":\"").substringBefore("\"}") - .replace("\\/", "/").replace("//ok.ru/","http://ok.ru/") - loadExtractor(extracteklink, data, subtitleCallback, callback) - } - } - - if (directlink.contains("reproducir120")) { - val regex = Regex("(https:\\/\\/repro3.estrenosdoramas.us\\/repro\\/reproducir120\\.php\\?\\nkey=[a-zA-Z0-9]{0,8}[a-zA-Z0-9_-]+)") - regex.findAll(directlink).map { - it.value - }.toList().apmap { - val doc = app.get(it).text - val videoid = doc.substringAfter("var videoid = '").substringBefore("';") - val token = doc.substringAfter("var tokens = '").substringBefore("';") - val acctkn = doc.substringAfter("{ acc: \"").substringBefore("\", id:") - val link = app.post("https://repro3.estrenosdoramas.us/repro/api3.php", - headers = headers, - data = mapOf( - Pair("acc",acctkn), - Pair("id",videoid), - Pair("tk",token)), - allowRedirects = false - ).text - val extractedlink = link.substringAfter("\"{file:'").substringBefore("',label:") - .replace("\\/", "/") - val quality = link.substringAfter(",label:'").substringBefore("',type:") - val type = link.substringAfter("type: '").substringBefore("'}\"") - if (extractedlink.isNotBlank()) - if (quality.contains("File not found", ignoreCase = true)) { - //Nothing - } else { - cleanExtractor( - "Movil", - "Movil $quality", - extractedlink, - "", - !type.contains("mp4"), - callback - ) - } - } - } - } - - return true - } -} diff --git a/EstrenosDoramasProvider/src/main/kotlin/com/lagradost/EstrenosDoramasProviderPlugin.kt b/EstrenosDoramasProvider/src/main/kotlin/com/lagradost/EstrenosDoramasProviderPlugin.kt deleted file mode 100644 index 521bebd..0000000 --- a/EstrenosDoramasProvider/src/main/kotlin/com/lagradost/EstrenosDoramasProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class EstrenosDoramasProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(EstrenosDoramasProvider()) - } -} \ No newline at end of file diff --git a/JKAnimeProvider/build.gradle.kts b/JKAnimeProvider/build.gradle.kts deleted file mode 100644 index 87e7d07..0000000 --- a/JKAnimeProvider/build.gradle.kts +++ /dev/null @@ -1,25 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "Anime", - "OVA", - ) - - iconUrl = "https://www.google.com/s2/favicons?domain=jkanime.net&sz=24" -} \ No newline at end of file diff --git a/JKAnimeProvider/src/main/AndroidManifest.xml b/JKAnimeProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/JKAnimeProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/JKAnimeProvider/src/main/kotlin/com/lagradost/JKAnimeProvider.kt b/JKAnimeProvider/src/main/kotlin/com/lagradost/JKAnimeProvider.kt deleted file mode 100644 index a3174ab..0000000 --- a/JKAnimeProvider/src/main/kotlin/com/lagradost/JKAnimeProvider.kt +++ /dev/null @@ -1,319 +0,0 @@ -package com.lagradost - - -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.utils.M3u8Helper.Companion.generateM3u8 -import com.lagradost.cloudstream3.utils.getQualityFromName -import com.lagradost.cloudstream3.utils.loadExtractor -import java.util.* - - -class JKAnimeProvider : MainAPI() { - companion object { - fun getType(t: String): TvType { - return if (t.contains("OVA") || t.contains("Especial")) TvType.OVA - else if (t.contains("Pelicula")) TvType.AnimeMovie - else TvType.Anime - } - } - - override var mainUrl = "https://jkanime.net" - override var name = "JKAnime" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.AnimeMovie, - TvType.OVA, - TvType.Anime, - ) - - override suspend fun getMainPage(page: Int, request : MainPageRequest): HomePageResponse { - val urls = listOf( - Pair( - "$mainUrl/directorio/?filtro=fecha&tipo=TV&estado=1&fecha=none&temporada=none&orden=desc", - "En emisión" - ), - Pair( - "$mainUrl/directorio/?filtro=fecha&tipo=none&estado=none&fecha=none&temporada=none&orden=none", - "Animes" - ), - Pair( - "$mainUrl/directorio/?filtro=fecha&tipo=Movie&estado=none&fecha=none&temporada=none&orden=none", - "Películas" - ), - ) - - val items = ArrayList() - - items.add( - HomePageList( - "Últimos episodios", - app.get(mainUrl).document.select(".listadoanime-home a.bloqq").map { - val title = it.selectFirst("h5")?.text() - val dubstat = if (title!!.contains("Latino") || title.contains("Castellano")) - DubStatus.Dubbed else DubStatus.Subbed - val poster = - it.selectFirst(".anime__sidebar__comment__item__pic img")?.attr("src") ?: "" - val epRegex = Regex("/(\\d+)/|/especial/|/ova/") - val url = it.attr("href").replace(epRegex, "") - val epNum = - it.selectFirst("h6")?.text()?.replace("Episodio ", "")?.toIntOrNull() - newAnimeSearchResponse(title, url) { - this.posterUrl = poster - addDubStatus(dubstat, epNum) - } - }) - ) - urls.apmap { (url, name) -> - val soup = app.get(url).document - val home = soup.select(".g-0").map { - val title = it.selectFirst("h5 a")?.text() - val poster = it.selectFirst("img")?.attr("src") ?: "" - AnimeSearchResponse( - title!!, - fixUrl(it.selectFirst("a")?.attr("href") ?: ""), - this.name, - TvType.Anime, - fixUrl(poster), - null, - if (title.contains("Latino") || title.contains("Castellano")) EnumSet.of( - DubStatus.Dubbed - ) else EnumSet.of(DubStatus.Subbed), - ) - } - items.add(HomePageList(name, home)) - } - - if (items.size <= 0) throw ErrorLoadingException() - return HomePageResponse(items) - } - - data class MainSearch( - @JsonProperty("animes") val animes: List, - @JsonProperty("anime_types") val animeTypes: AnimeTypes - ) - - data class Animes( - @JsonProperty("id") val id: String, - @JsonProperty("slug") val slug: String, - @JsonProperty("title") val title: String, - @JsonProperty("image") val image: String, - @JsonProperty("synopsis") val synopsis: String, - @JsonProperty("type") val type: String, - @JsonProperty("status") val status: String, - @JsonProperty("thumbnail") val thumbnail: String - ) - - data class AnimeTypes( - @JsonProperty("TV") val TV: String, - @JsonProperty("OVA") val OVA: String, - @JsonProperty("Movie") val Movie: String, - @JsonProperty("Special") val Special: String, - @JsonProperty("ONA") val ONA: String, - @JsonProperty("Music") val Music: String - ) - - override suspend fun search(query: String): List { - val main = app.get("$mainUrl/ajax/ajax_search/?q=$query").text - val json = parseJson(main) - return json.animes.map { - val title = it.title - val href = "$mainUrl/${it.slug}" - val image = "https://cdn.jkanime.net/assets/images/animes/image/${it.slug}.jpg" - AnimeSearchResponse( - title, - href, - this.name, - TvType.Anime, - image, - null, - if (title.contains("Latino") || title.contains("Castellano")) EnumSet.of( - DubStatus.Dubbed - ) else EnumSet.of(DubStatus.Subbed), - ) - } - } - - override suspend fun load(url: String): LoadResponse { - val doc = app.get(url, timeout = 120).document - val poster = doc.selectFirst(".set-bg")?.attr("data-setbg") - val title = doc.selectFirst(".anime__details__title > h3")?.text() - val type = doc.selectFirst(".anime__details__text")?.text() - val description = doc.selectFirst(".anime__details__text > p")?.text() - val genres = doc.select("div.col-lg-6:nth-child(1) > ul:nth-child(1) > li:nth-child(2) > a") - .map { it.text() } - val status = when (doc.selectFirst("span.enemision")?.text()) { - "En emisión" -> ShowStatus.Ongoing - "Concluido" -> ShowStatus.Completed - else -> null - } - val animeID = doc.selectFirst("div.ml-2")?.attr("data-anime")?.toInt() - val animeeps = "$mainUrl/ajax/last_episode/$animeID/" - val jsoneps = app.get(animeeps).text - val lastepnum = - jsoneps.substringAfter("{\"number\":\"").substringBefore("\",\"title\"").toInt() - val episodes = (1..lastepnum).map { - val link = "${url.removeSuffix("/")}/$it" - Episode(link) - } - - return newAnimeLoadResponse(title!!, url, getType(type!!)) { - posterUrl = poster - addEpisodes(DubStatus.Subbed, episodes) - showStatus = status - plot = description - tags = genres - } - } - - data class Nozomi( - @JsonProperty("file") val file: String? - ) - - private fun streamClean( - name: String, - url: String, - referer: String, - quality: String?, - callback: (ExtractorLink) -> Unit, - m3u8: Boolean - ): Boolean { - callback( - ExtractorLink( - name, - name, - url, - referer, - getQualityFromName(quality), - m3u8 - ) - ) - return true - } - - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - app.get(data).document.select("script").apmap { script -> - if (script.data().contains("var video = []")) { - val videos = script.data().replace("\\/", "/") - fetchUrls(videos).map { - it.replace("$mainUrl/jkfembed.php?u=", "https://embedsito.com/v/") - .replace("$mainUrl/jkokru.php?u=", "http://ok.ru/videoembed/") - .replace("$mainUrl/jkvmixdrop.php?u=", "https://mixdrop.co/e/") - .replace("$mainUrl/jk.php?u=", "$mainUrl/") - }.apmap { link -> - loadExtractor(link, data, subtitleCallback, callback) - if (link.contains("um2.php")) { - val doc = app.get(link, referer = data).document - val gsplaykey = doc.select("form input[value]").attr("value") - app.post( - "$mainUrl/gsplay/redirect_post.php", - headers = mapOf( - "Host" to "jkanime.net", - "User-Agent" to USER_AGENT, - "Accept" to "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8", - "Accept-Language" to "en-US,en;q=0.5", - "Referer" to link, - "Content-Type" to "application/x-www-form-urlencoded", - "Origin" to "https://jkanime.net", - "DNT" to "1", - "Connection" to "keep-alive", - "Upgrade-Insecure-Requests" to "1", - "Sec-Fetch-Dest" to "iframe", - "Sec-Fetch-Mode" to "navigate", - "Sec-Fetch-Site" to "same-origin", - "TE" to "trailers", - "Pragma" to "no-cache", - "Cache-Control" to "no-cache", - ), - data = mapOf(Pair("data", gsplaykey)), - allowRedirects = false - ).okhttpResponse.headers.values("location").apmap { loc -> - val postkey = loc.replace("/gsplay/player.html#", "") - val nozomitext = app.post( - "$mainUrl/gsplay/api.php", - headers = mapOf( - "Host" to "jkanime.net", - "User-Agent" to USER_AGENT, - "Accept" to "application/json, text/javascript, */*; q=0.01", - "Accept-Language" to "en-US,en;q=0.5", - "Content-Type" to "application/x-www-form-urlencoded; charset=UTF-8", - "X-Requested-With" to "XMLHttpRequest", - "Origin" to "https://jkanime.net", - "DNT" to "1", - "Connection" to "keep-alive", - "Sec-Fetch-Dest" to "empty", - "Sec-Fetch-Mode" to "cors", - "Sec-Fetch-Site" to "same-origin", - ), - data = mapOf(Pair("v", postkey)), - allowRedirects = false - ).text - val json = parseJson(nozomitext) - val nozomiurl = listOf(json.file) - if (nozomiurl.isEmpty()) null else - nozomiurl.forEach { url -> - val nozominame = "Nozomi" - streamClean( - nozominame, - url!!, - "", - null, - callback, - url.contains(".m3u8") - ) - } - } - } - if (link.contains("um.php")) { - val desutext = app.get(link, referer = data).text - val desuRegex = Regex("((https:|http:)//.*\\.m3u8)") - val file = desuRegex.find(desutext)?.value - val namedesu = "Desu" - generateM3u8( - namedesu, - file!!, - mainUrl, - ).forEach { desurl -> - streamClean( - namedesu, - desurl.url, - mainUrl, - desurl.quality.toString(), - callback, - true - ) - } - } - if (link.contains("jkmedia")) { - app.get( - link, - referer = data, - allowRedirects = false - ).okhttpResponse.headers.values("location").apmap { xtremeurl -> - val namex = "Xtreme S" - streamClean( - namex, - xtremeurl, - "", - null, - callback, - xtremeurl.contains(".m3u8") - ) - } - } - } - } - } - return true - } -} \ No newline at end of file diff --git a/JKAnimeProvider/src/main/kotlin/com/lagradost/JKAnimeProviderPlugin.kt b/JKAnimeProvider/src/main/kotlin/com/lagradost/JKAnimeProviderPlugin.kt deleted file mode 100644 index 330bc29..0000000 --- a/JKAnimeProvider/src/main/kotlin/com/lagradost/JKAnimeProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class JKAnimeProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(JKAnimeProvider()) - } -} \ No newline at end of file diff --git a/MonoschinosProvider/build.gradle.kts b/MonoschinosProvider/build.gradle.kts deleted file mode 100644 index dde6619..0000000 --- a/MonoschinosProvider/build.gradle.kts +++ /dev/null @@ -1,25 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "Anime", - "OVA", - ) - - iconUrl = "https://www.google.com/s2/favicons?domain=monoschinos2.com&sz=24" -} \ No newline at end of file diff --git a/MonoschinosProvider/src/main/AndroidManifest.xml b/MonoschinosProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/MonoschinosProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/MonoschinosProvider/src/main/kotlin/com/lagradost/MonoschinosProvider.kt b/MonoschinosProvider/src/main/kotlin/com/lagradost/MonoschinosProvider.kt deleted file mode 100644 index ba6f7ab..0000000 --- a/MonoschinosProvider/src/main/kotlin/com/lagradost/MonoschinosProvider.kt +++ /dev/null @@ -1,155 +0,0 @@ -package com.lagradost - -import com.lagradost.cloudstream3.* -import com.lagradost.cloudstream3.utils.ExtractorLink -import com.lagradost.cloudstream3.utils.loadExtractor -import java.util.* - - -class MonoschinosProvider : MainAPI() { - companion object { - fun getType(t: String): TvType { - return if (t.contains("OVA") || t.contains("Especial")) TvType.OVA - else if (t.contains("Pelicula")) TvType.AnimeMovie - else TvType.Anime - } - - fun getDubStatus(title: String): DubStatus { - return if (title.contains("Latino") || title.contains("Castellano")) - DubStatus.Dubbed - else DubStatus.Subbed - } - } - - override var mainUrl = "https://monoschinos2.com" - override var name = "Monoschinos" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.AnimeMovie, - TvType.OVA, - TvType.Anime, - ) - - override suspend fun getMainPage(page: Int, request : MainPageRequest): HomePageResponse { - val urls = listOf( - Pair("$mainUrl/emision", "En emisión"), - Pair( - "$mainUrl/animes?categoria=pelicula&genero=false&fecha=false&letra=false", - "Peliculas" - ), - Pair("$mainUrl/animes", "Animes"), - ) - - val items = ArrayList() - - items.add( - HomePageList( - "Capítulos actualizados", - app.get(mainUrl, timeout = 120).document.select(".col-6").map { - val title = it.selectFirst("p.animetitles")?.text() ?: it.selectFirst(".animetitles")?.text() ?: "" - val poster = it.selectFirst(".animeimghv")!!.attr("data-src") - val epRegex = Regex("episodio-(\\d+)") - val url = it.selectFirst("a")?.attr("href")!!.replace("ver/", "anime/") - .replace(epRegex, "sub-espanol") - val epNum = (it.selectFirst(".positioning h5")?.text() ?: it.selectFirst("div.positioning p")?.text())?.toIntOrNull() - newAnimeSearchResponse(title, url) { - this.posterUrl = fixUrl(poster) - addDubStatus(getDubStatus(title), epNum) - } - }) - ) - - for (i in urls) { - try { - val home = app.get(i.first, timeout = 120).document.select(".col-6").map { - val title = it.selectFirst(".seristitles")!!.text() - val poster = it.selectFirst("img.animemainimg")!!.attr("src") - newAnimeSearchResponse(title, fixUrl(it.selectFirst("a")!!.attr("href"))) { - this.posterUrl = fixUrl(poster) - addDubStatus(getDubStatus(title)) - } - } - - items.add(HomePageList(i.second, home)) - } catch (e: Exception) { - e.printStackTrace() - } - } - - if (items.size <= 0) throw ErrorLoadingException() - return HomePageResponse(items) - } - - override suspend fun search(query: String): ArrayList { - val search = - app.get("$mainUrl/buscar?q=$query", timeout = 120).document.select(".col-6").map { - val title = it.selectFirst(".seristitles")!!.text() - val href = fixUrl(it.selectFirst("a")!!.attr("href")) - val image = it.selectFirst("img.animemainimg")!!.attr("src") - AnimeSearchResponse( - title, - href, - this.name, - TvType.Anime, - fixUrl(image), - null, - if (title.contains("Latino") || title.contains("Castellano")) EnumSet.of( - DubStatus.Dubbed - ) else EnumSet.of(DubStatus.Subbed), - ) - } - return ArrayList(search) - } - - override suspend fun load(url: String): LoadResponse { - val doc = app.get(url, timeout = 120).document - val poster = doc.selectFirst(".chapterpic img")!!.attr("src") - val title = doc.selectFirst(".chapterdetails h1")!!.text() - val type = doc.selectFirst("div.chapterdetls2")!!.text() - val description = doc.selectFirst("p.textComplete")!!.text().replace("Ver menos", "") - val genres = doc.select(".breadcrumb-item a").map { it.text() } - val status = when (doc.selectFirst("button.btn1")?.text()) { - "Estreno" -> ShowStatus.Ongoing - "Finalizado" -> ShowStatus.Completed - else -> null - } - val episodes = doc.select("div.col-item").map { - val name = it.selectFirst("p.animetitles")!!.text() - val link = it.selectFirst("a")!!.attr("href") - val epThumb = it.selectFirst(".animeimghv")!!.attr("data-src") - Episode(link, name, posterUrl = epThumb) - } - return newAnimeLoadResponse(title, url, getType(type)) { - posterUrl = poster - addEpisodes(DubStatus.Subbed, episodes) - showStatus = status - plot = description - tags = genres - } - } - - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - app.get(data).document.select("div.playother p").forEach { - val encodedurl = it.select("p").attr("data-player") - val urlDecoded = base64Decode(encodedurl) - val url = (urlDecoded).replace("https://monoschinos2.com/reproductor?url=", "") - if (url.startsWith("https://www.fembed.com")) { - val extractor = FEmbed() - extractor.getUrl(url).forEach { link -> - callback.invoke(link) - } - } else { - loadExtractor(url, mainUrl, subtitleCallback, callback) - } - } - return true - } -} \ No newline at end of file diff --git a/MonoschinosProvider/src/main/kotlin/com/lagradost/MonoschinosProviderPlugin.kt b/MonoschinosProvider/src/main/kotlin/com/lagradost/MonoschinosProviderPlugin.kt deleted file mode 100644 index f3b0b35..0000000 --- a/MonoschinosProvider/src/main/kotlin/com/lagradost/MonoschinosProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class MonoschinosProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(MonoschinosProvider()) - } -} \ No newline at end of file diff --git a/MonoschinosProvider/src/main/kotlin/com/lagradost/XStreamCdn.kt b/MonoschinosProvider/src/main/kotlin/com/lagradost/XStreamCdn.kt deleted file mode 100644 index 866aee0..0000000 --- a/MonoschinosProvider/src/main/kotlin/com/lagradost/XStreamCdn.kt +++ /dev/null @@ -1,67 +0,0 @@ -package com.lagradost - -import com.fasterxml.jackson.annotation.JsonProperty -import com.lagradost.cloudstream3.app -import com.lagradost.cloudstream3.utils.AppUtils -import com.lagradost.cloudstream3.utils.ExtractorApi -import com.lagradost.cloudstream3.utils.ExtractorLink -import com.lagradost.cloudstream3.utils.getQualityFromName - -class FEmbed: XStreamCdn() { - override val name: String = "FEmbed" - override val mainUrl: String = "https://www.fembed.com" -} - -open class XStreamCdn : ExtractorApi() { - override val name: String = "XStreamCdn" - override val mainUrl: String = "https://embedsito.com" - override val requiresReferer = false - open var domainUrl: String = "embedsito.com" - - private data class ResponseData( - @JsonProperty("file") val file: String, - @JsonProperty("label") val label: String, - //val type: String // Mp4 - ) - - private data class ResponseJson( - @JsonProperty("success") val success: Boolean, - @JsonProperty("data") val data: List? - ) - - override fun getExtractorUrl(id: String): String { - return "$domainUrl/api/source/$id" - } - - override suspend fun getUrl(url: String, referer: String?): List { - val headers = mapOf( - "Referer" to url, - "User-Agent" to "Mozilla/5.0 (Windows NT 10.0; rv:78.0) Gecko/20100101 Firefox/78.0", - ) - val id = url.trimEnd('/').split("/").last() - val newUrl = "https://${domainUrl}/api/source/${id}" - val extractedLinksList: MutableList = mutableListOf() - with(app.post(newUrl, headers = headers)) { - if (this.code != 200) return listOf() - val text = this.text - if (text.isEmpty()) return listOf() - if (text == """{"success":false,"data":"Video not found or has been removed"}""") return listOf() - AppUtils.parseJson(text)?.let { - if (it.success && it.data != null) { - it.data.forEach { data -> - extractedLinksList.add( - ExtractorLink( - name, - name = name, - data.file, - url, - getQualityFromName(data.label), - ) - ) - } - } - } - } - return extractedLinksList - } -} \ No newline at end of file diff --git a/MundoDonghuaProvider/build.gradle.kts b/MundoDonghuaProvider/build.gradle.kts deleted file mode 100644 index cc6f854..0000000 --- a/MundoDonghuaProvider/build.gradle.kts +++ /dev/null @@ -1,25 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "AnimeMovie", - "Anime", - ) - - iconUrl = "https://www.google.com/s2/favicons?domain=www.mundodonghua.com&sz=24" -} \ No newline at end of file diff --git a/MundoDonghuaProvider/src/main/AndroidManifest.xml b/MundoDonghuaProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/MundoDonghuaProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/MundoDonghuaProvider/src/main/kotlin/com/lagradost/MundoDonghuaProvider.kt b/MundoDonghuaProvider/src/main/kotlin/com/lagradost/MundoDonghuaProvider.kt deleted file mode 100644 index 8381b2f..0000000 --- a/MundoDonghuaProvider/src/main/kotlin/com/lagradost/MundoDonghuaProvider.kt +++ /dev/null @@ -1,217 +0,0 @@ -package com.lagradost - -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.utils.M3u8Helper.Companion.generateM3u8 -import com.lagradost.cloudstream3.utils.getAndUnpack -import com.lagradost.cloudstream3.utils.getQualityFromName -import com.lagradost.cloudstream3.utils.loadExtractor -import java.util.* - - -class MundoDonghuaProvider : MainAPI() { - - override var mainUrl = "https://www.mundodonghua.com" - override var name = "MundoDonghua" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.Anime, - ) - - override suspend fun getMainPage(page: Int, request : MainPageRequest): HomePageResponse { - val urls = listOf( - Pair("$mainUrl/lista-donghuas", "Donghuas"), - ) - - val items = ArrayList() - items.add( - HomePageList( - "Últimos episodios", - app.get(mainUrl, timeout = 120).document.select("div.row .col-xs-4").map { - val title = it.selectFirst("h5")?.text() ?: "" - val poster = it.selectFirst(".fit-1 img")?.attr("src") - val epRegex = Regex("(\\/(\\d+)\$)") - val url = it.selectFirst("a")?.attr("href")?.replace(epRegex,"")?.replace("/ver/","/donghua/") - val epnumRegex = Regex("((\\d+)$)") - val epNum = epnumRegex.find(title)?.value?.toIntOrNull() - val dubstat = if (title.contains("Latino") || title.contains("Castellano")) DubStatus.Dubbed else DubStatus.Subbed - newAnimeSearchResponse(title.replace(Regex("Episodio|(\\d+)"),"").trim(), fixUrl(url ?: "")) { - this.posterUrl = fixUrl(poster ?: "") - addDubStatus(dubstat, epNum) - } - }) - ) - - urls.apmap { (url, name) -> - val home = app.get(url, timeout = 120).document.select(".col-xs-4").map { - val title = it.selectFirst(".fs-14")?.text() ?: "" - val poster = it.selectFirst(".fit-1 img")?.attr("src") ?: "" - AnimeSearchResponse( - title, - fixUrl(it.selectFirst("a")?.attr("href") ?: ""), - this.name, - TvType.Anime, - fixUrl(poster), - null, - if (title.contains("Latino") || title.contains("Castellano")) EnumSet.of( - DubStatus.Dubbed - ) else EnumSet.of(DubStatus.Subbed), - ) - } - - items.add(HomePageList(name, home)) - } - - if (items.size <= 0) throw ErrorLoadingException() - return HomePageResponse(items) - } - - override suspend fun search(query: String): List { - return app.get("$mainUrl/busquedas/$query", timeout = 120).document.select(".col-xs-4").map { - val title = it.selectFirst(".fs-14")?.text() ?: "" - val href = fixUrl(it.selectFirst("a")?.attr("href") ?: "") - val image = it.selectFirst(".fit-1 img")?.attr("src") - AnimeSearchResponse( - title, - href, - this.name, - TvType.Anime, - fixUrl(image ?: ""), - null, - if (title.contains("Latino") || title.contains("Castellano")) EnumSet.of( - DubStatus.Dubbed - ) else EnumSet.of(DubStatus.Subbed), - ) - } - } - - override suspend fun load(url: String): LoadResponse { - val doc = app.get(url, timeout = 120).document - val poster = doc.selectFirst("head meta[property=og:image]")?.attr("content") ?: "" - val title = doc.selectFirst(".ls-title-serie")?.text() ?: "" - val description = doc.selectFirst("p.text-justify.fc-dark")?.text() ?: "" - val genres = doc.select("span.label.label-primary.f-bold").map { it.text() } - val status = when (doc.selectFirst("div.col-md-6.col-xs-6.align-center.bg-white.pt-10.pr-15.pb-0.pl-15 p span.badge.bg-default")?.text()) { - "En Emisión" -> ShowStatus.Ongoing - "Finalizada" -> ShowStatus.Completed - else -> null - } - val episodes = doc.select("ul.donghua-list a").map { - val name = it.selectFirst(".fs-16")?.text() - val link = it.attr("href") - Episode(fixUrl(link), name) - }.reversed() - val typeinfo = doc.select("div.row div.col-md-6.pl-15 p.fc-dark").text() - val tvType = if (typeinfo.contains(Regex("Tipo.*Pel.cula"))) TvType.AnimeMovie else TvType.Anime - return newAnimeLoadResponse(title, url, tvType) { - posterUrl = poster - addEpisodes(DubStatus.Subbed, episodes) - showStatus = status - plot = description - tags = genres - } - } - data class Protea ( - @JsonProperty("source") val source: List, - @JsonProperty("poster") val poster: String? - ) - - data class Source ( - @JsonProperty("file") val file: String, - @JsonProperty("label") val label: String?, - @JsonProperty("type") val type: String?, - @JsonProperty("default") val default: String? - ) - - private fun cleanStream( - name: String, - url: String, - qualityString: String?, - callback: (ExtractorLink) -> Unit, - isM3U8: Boolean - ): Boolean { - callback( - ExtractorLink( - name, - name, - url, - "", - getQualityFromName(qualityString), - isM3U8 - ) - ) - return true - } - - - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - app.get(data).document.select("script").apmap { script -> - if (script.data().contains("eval(function(p,a,c,k,e")) { - val packedRegex = Regex("eval\\(function\\(p,a,c,k,e,.*\\)\\)") - packedRegex.findAll(script.data()).map { - it.value - }.toList().apmap { - val unpack = getAndUnpack(it).replace("diasfem","embedsito") - fetchUrls(unpack).apmap { url -> - loadExtractor(url, data, subtitleCallback, callback) - } - if (unpack.contains("protea_tab")) { - val protearegex = Regex("(protea_tab.*slug.*,type)") - val slug = protearegex.findAll(unpack).map { - it.value.replace(Regex("(protea_tab.*slug\":\")"),"").replace("\"},type","") - }.first() - val requestlink = "$mainUrl/api_donghua.php?slug=$slug" - val response = app.get(requestlink, headers = - mapOf("Host" to "www.mundodonghua.com", - "User-Agent" to USER_AGENT, - "Accept" to "*/*", - "Accept-Language" to "en-US,en;q=0.5", - "Referer" to data, - "X-Requested-With" to "XMLHttpRequest", - "DNT" to "1", - "Connection" to "keep-alive", - "Sec-Fetch-Dest" to "empty", - "Sec-Fetch-Mode" to "no-cors", - "Sec-Fetch-Site" to "same-origin", - "TE" to "trailers", - "Pragma" to "no-cache", - "Cache-Control" to "no-cache",) - ).text.removePrefix("[").removeSuffix("]") - val json = parseJson(response) - json.source.forEach { source -> - val protename = "Protea" - cleanStream(protename, fixUrl(source.file), source.label, callback, false) - } - } - if (unpack.contains("asura_player")) { - val asuraRegex = Regex("(asura_player.*type)") - asuraRegex.findAll(unpack).map { - it.value - }.toList().apmap { protea -> - val asuraname = "Asura" - val file = protea.substringAfter("{file:\"").substringBefore("\"") - generateM3u8( - asuraname, - file, - "" - ).forEach { - cleanStream(asuraname, it.url, it.quality.toString(), callback, true) - } - } - } - } - } - } - return true - } -} \ No newline at end of file diff --git a/MundoDonghuaProvider/src/main/kotlin/com/lagradost/MundoDonghuaProviderPlugin.kt b/MundoDonghuaProvider/src/main/kotlin/com/lagradost/MundoDonghuaProviderPlugin.kt deleted file mode 100644 index 7b2574f..0000000 --- a/MundoDonghuaProvider/src/main/kotlin/com/lagradost/MundoDonghuaProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class MundoDonghuaProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(MundoDonghuaProvider()) - } -} \ No newline at end of file diff --git a/PeliSmartProvider/build.gradle.kts b/PeliSmartProvider/build.gradle.kts deleted file mode 100644 index 10de895..0000000 --- a/PeliSmartProvider/build.gradle.kts +++ /dev/null @@ -1,26 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "TvSeries", - "Movie", - ) - - - iconUrl = "https://www.google.com/s2/favicons?domain=pelismart.com&sz=24" -} \ No newline at end of file diff --git a/PeliSmartProvider/src/main/AndroidManifest.xml b/PeliSmartProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/PeliSmartProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/PeliSmartProvider/src/main/kotlin/com/lagradost/PeliSmartProvider.kt b/PeliSmartProvider/src/main/kotlin/com/lagradost/PeliSmartProvider.kt deleted file mode 100644 index 2e6b489..0000000 --- a/PeliSmartProvider/src/main/kotlin/com/lagradost/PeliSmartProvider.kt +++ /dev/null @@ -1,160 +0,0 @@ -package com.lagradost - -import com.lagradost.cloudstream3.* -import com.lagradost.cloudstream3.utils.ExtractorLink -import com.lagradost.cloudstream3.utils.loadExtractor - -class PeliSmartProvider: MainAPI() { - override var mainUrl = "https://pelismart.com" - override var name = "PeliSmart" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.Movie, - TvType.TvSeries, - ) - override val vpnStatus = VPNStatus.MightBeNeeded //Due to evoload sometimes not loading - - override suspend fun getMainPage(page: Int, request : MainPageRequest): HomePageResponse { - val items = ArrayList() - val urls = listOf( - Pair("$mainUrl/peliculas/", "Peliculas"), - Pair("$mainUrl/series/", "Series"), - Pair("$mainUrl/documentales/", "Documentales"), - ) - - // has no inf loading - urls.apmap { (url, name) -> - try { - val soup = app.get(url).document - val home = soup.select(".description-off").map { - val title = it.selectFirst("h3.entry-title a")!!.text() - val link = it.selectFirst("a")!!.attr("href") - TvSeriesSearchResponse( - title, - link, - this.name, - if (link.contains("pelicula")) TvType.Movie else TvType.TvSeries, - it.selectFirst("div img")!!.attr("src"), - null, - null, - ) - } - - items.add(HomePageList(name, home)) - } catch (e: Exception) { - e.printStackTrace() - } - } - - if (items.size <= 0) throw ErrorLoadingException() - return HomePageResponse(items) - } - - override suspend fun search(query: String): List { - val url = "$mainUrl?s=${query}&post_type=post" - val document = app.get(url).document - - return document.select(".description-off").map { - val title = it.selectFirst("h3.entry-title a")!!.text() - val href = it.selectFirst("a")!!.attr("href") - val image = it.selectFirst("div img")!!.attr("src") - val isMovie = href.contains("pelicula") - - if (isMovie) { - MovieSearchResponse( - title, - href, - this.name, - TvType.Movie, - image, - null - ) - } else { - TvSeriesSearchResponse( - title, - href, - this.name, - TvType.TvSeries, - image, - null, - null - ) - } - } - } - - - override suspend fun load(url: String): LoadResponse? { - val soup = app.get(url, timeout = 120).document - val title = soup.selectFirst(".wpb_wrapper h1")!!.text() - val description = soup.selectFirst("div.wpb_wrapper p")?.text()?.trim() - val poster: String? = soup.selectFirst(".vc_single_image-img")!!.attr("src") - val episodes = soup.select("div.vc_tta-panel-body div a").map { li -> - val href = li.selectFirst("a")!!.attr("href") - val preregex = Regex("(\\d+)\\. ") - val name = li.selectFirst("a")!!.text().replace(preregex,"") - val regextest = Regex("(temporada-(\\d+)-capitulo-(\\d+)|temporada-(\\d+)-episodio-(\\d+))") - val test = regextest.find(href)?.destructured?.component1()?.replace(Regex("(temporada-|-)"),"") - val seasonid = test.let { str -> - str?.split("episodio","capitulo")?.mapNotNull { subStr -> subStr.toIntOrNull() } - } - val isValid = seasonid?.size == 2 - val episode = if (isValid) seasonid?.getOrNull(1) else null - val season = if (isValid) seasonid?.getOrNull(0) else null - Episode( - href, - name, - season, - episode, - ) - } - return when (val tvType = if (episodes.isEmpty()) TvType.Movie else TvType.TvSeries) { - TvType.TvSeries -> { - TvSeriesLoadResponse( - title, - url, - this.name, - tvType, - episodes, - poster, - null, - description, - ) - } - TvType.Movie -> { - MovieLoadResponse( - title, - url, - this.name, - tvType, - url, - poster, - null, - description, - ) - } - else -> null - } - } - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - val soup = app.get(data).text - fetchUrls(soup).apmap { - val urlc = it.replace("https://pelismart.com/p/1.php?v=","https://evoload.io/e/") - .replace("https://pelismart.com/p/2.php?v=","https://streamtape.com/e/") - .replace("https://pelismart.com/p/4.php?v=","https://dood.to/e/") - .replace("https://pelismarthd.com/p/1.php?v=","https://evoload.io/e/") - .replace("https://pelismarthd.com/p/2.php?v=","https://streamtape.com/e/") - .replace("https://pelismarthd.com/p/4.php?v=","https://dood.to/e/") - loadExtractor(urlc, data, subtitleCallback, callback) - } - return true - } -} \ No newline at end of file diff --git a/PeliSmartProvider/src/main/kotlin/com/lagradost/PeliSmartProviderPlugin.kt b/PeliSmartProvider/src/main/kotlin/com/lagradost/PeliSmartProviderPlugin.kt deleted file mode 100644 index 8ef863c..0000000 --- a/PeliSmartProvider/src/main/kotlin/com/lagradost/PeliSmartProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class PeliSmartProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(PeliSmartProvider()) - } -} \ No newline at end of file diff --git a/PelisplusHDProvider/build.gradle.kts b/PelisplusHDProvider/build.gradle.kts deleted file mode 100644 index 5a7ea96..0000000 --- a/PelisplusHDProvider/build.gradle.kts +++ /dev/null @@ -1,26 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "TvSeries", - "Movie", - ) - - - iconUrl = "https://www.google.com/s2/favicons?domain=pelisplushd.net&sz=24" -} \ No newline at end of file diff --git a/PelisplusHDProvider/src/main/AndroidManifest.xml b/PelisplusHDProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/PelisplusHDProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/PelisplusHDProvider/src/main/kotlin/com/lagradost/PelisplusHDProvider.kt b/PelisplusHDProvider/src/main/kotlin/com/lagradost/PelisplusHDProvider.kt deleted file mode 100644 index cf13381..0000000 --- a/PelisplusHDProvider/src/main/kotlin/com/lagradost/PelisplusHDProvider.kt +++ /dev/null @@ -1,173 +0,0 @@ -package com.lagradost - -import com.lagradost.cloudstream3.* -import com.lagradost.cloudstream3.utils.ExtractorLink -import com.lagradost.cloudstream3.utils.loadExtractor -import org.jsoup.nodes.Element - -class PelisplusHDProvider:MainAPI() { - override var mainUrl = "https://pelisplushd.net" - override var name = "PelisplusHD" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.Movie, - TvType.TvSeries, - ) - override suspend fun getMainPage(page: Int, request : MainPageRequest): HomePageResponse { - val items = ArrayList() - val document = app.get(mainUrl).document - val map = mapOf( - "Películas" to "#default-tab-1", - "Series" to "#default-tab-2", - "Anime" to "#default-tab-3", - "Doramas" to "#default-tab-4", - ) - map.forEach { - items.add(HomePageList( - it.key, - document.select(it.value).select("a.Posters-link").map { element -> - element.toSearchResult() - } - )) - } - return HomePageResponse(items) - } - private fun Element.toSearchResult(): SearchResponse { - val title = this.select(".listing-content p").text() - val href = this.select("a").attr("href") - val posterUrl = this.select(".Posters-img").attr("src") - val isMovie = href.contains("/pelicula/") - return if (isMovie) { - MovieSearchResponse( - title, - href, - name, - TvType.Movie, - posterUrl, - null - ) - } else { - TvSeriesSearchResponse( - title, - href, - name, - TvType.Movie, - posterUrl, - null, - null - ) - } - } - - override suspend fun search(query: String): List { - val url = "https://pelisplushd.net/search?s=${query}" - val document = app.get(url).document - - return document.select("a.Posters-link").map { - val title = it.selectFirst(".listing-content p")!!.text() - val href = it.selectFirst("a")!!.attr("href") - val image = it.selectFirst(".Posters-img")!!.attr("src") - val isMovie = href.contains("/pelicula/") - - if (isMovie) { - MovieSearchResponse( - title, - href, - this.name, - TvType.Movie, - image, - null - ) - } else { - TvSeriesSearchResponse( - title, - href, - this.name, - TvType.TvSeries, - image, - null, - null - ) - } - } - } - - override suspend fun load(url: String): LoadResponse? { - val soup = app.get(url, timeout = 120).document - - val title = soup.selectFirst(".m-b-5")!!.text() - val description = soup.selectFirst("div.text-large")?.text()?.trim() - val poster: String? = soup.selectFirst(".img-fluid")!!.attr("src") - val episodes = soup.select("div.tab-pane .btn").map { li -> - val href = li.selectFirst("a")!!.attr("href") - val name = li.selectFirst(".btn-primary.btn-block")!!.text() - val seasonid = href.replace("/capitulo/","-") - .replace(Regex("$mainUrl/.*/.*/temporada/"),"").let { str -> - str.split("-").mapNotNull { subStr -> subStr.toIntOrNull() } - } - val isValid = seasonid.size == 2 - val episode = if (isValid) seasonid.getOrNull(1) else null - val season = if (isValid) seasonid.getOrNull(0) else null - Episode( - href, - name, - season, - episode, - ) - } - - val year = soup.selectFirst(".p-r-15 .text-semibold")!!.text().toIntOrNull() - val tvType = if (url.contains("/pelicula/")) TvType.Movie else TvType.TvSeries - val tags = soup.select(".p-h-15.text-center a span.font-size-18.text-info.text-semibold") - .map { it?.text()?.trim().toString().replace(", ","") } - - return when (tvType) { - TvType.TvSeries -> { - TvSeriesLoadResponse( - title, - url, - this.name, - tvType, - episodes, - poster, - year, - description, - null, - null, - tags, - ) - } - TvType.Movie -> { - MovieLoadResponse( - title, - url, - this.name, - tvType, - url, - poster, - year, - description, - null, - tags, - ) - } - else -> null - } - } - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - app.get(data).document.select("div.player > script").map { script -> - fetchUrls(script.data().replace("https://pelisplushd.net/fembed.php?url=","https://www.fembed.com/v/")).apmap { - loadExtractor(it, data, subtitleCallback, callback) - } - } - return true - } -} diff --git a/PelisplusHDProvider/src/main/kotlin/com/lagradost/PelisplusHDProviderPlugin.kt b/PelisplusHDProvider/src/main/kotlin/com/lagradost/PelisplusHDProviderPlugin.kt deleted file mode 100644 index ead1a6a..0000000 --- a/PelisplusHDProvider/src/main/kotlin/com/lagradost/PelisplusHDProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class PelisplusHDProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(PelisplusHDProvider()) - } -} \ No newline at end of file diff --git a/PelisplusProvider/build.gradle.kts b/PelisplusProvider/build.gradle.kts deleted file mode 100644 index 94afecc..0000000 --- a/PelisplusProvider/build.gradle.kts +++ /dev/null @@ -1,26 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "TvSeries", - "Movie", - ) - - - iconUrl = "https://www.google.com/s2/favicons?domain=pelisplus.icu&sz=24" -} \ No newline at end of file diff --git a/PelisplusProvider/src/main/AndroidManifest.xml b/PelisplusProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/PelisplusProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/PelisplusProvider/src/main/kotlin/com/lagradost/PelisplusProvider.kt b/PelisplusProvider/src/main/kotlin/com/lagradost/PelisplusProvider.kt deleted file mode 100644 index 9e8617b..0000000 --- a/PelisplusProvider/src/main/kotlin/com/lagradost/PelisplusProvider.kt +++ /dev/null @@ -1,26 +0,0 @@ -package com.lagradost - -import com.lagradost.cloudstream3.TvType - -/** Needs to inherit from MainAPI() to - * make the app know what functions to call - */ -class PelisplusProvider : PelisplusProviderTemplate() { - // mainUrl is good to have as a holder for the url to make future changes easier. - override var mainUrl = "https://pelisplus.icu" - - // name is for how the provider will be named which is visible in the UI, no real rules for this. - override var name = "Pelisplus" - - override val homePageUrlList = listOf( - mainUrl, - "$mainUrl/movies", - "$mainUrl/series", - "$mainUrl/new-season", - "$mainUrl/popular" - ) - - // This is just extra metadata about what type of movies the provider has. - // Needed for search functionality. - override val supportedTypes = setOf(TvType.TvSeries, TvType.Movie) -} diff --git a/PelisplusProvider/src/main/kotlin/com/lagradost/PelisplusProviderPlugin.kt b/PelisplusProvider/src/main/kotlin/com/lagradost/PelisplusProviderPlugin.kt deleted file mode 100644 index e33bd42..0000000 --- a/PelisplusProvider/src/main/kotlin/com/lagradost/PelisplusProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class PelisplusProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(PelisplusProvider()) - } -} \ No newline at end of file diff --git a/PelisplusProvider/src/main/kotlin/com/lagradost/PelisplusProviderTemplate.kt b/PelisplusProvider/src/main/kotlin/com/lagradost/PelisplusProviderTemplate.kt deleted file mode 100644 index 2fab513..0000000 --- a/PelisplusProvider/src/main/kotlin/com/lagradost/PelisplusProviderTemplate.kt +++ /dev/null @@ -1,260 +0,0 @@ -package com.lagradost - -import com.lagradost.cloudstream3.* -import com.lagradost.cloudstream3.utils.ExtractorLink -import com.lagradost.cloudstream3.utils.M3u8Helper -import com.lagradost.cloudstream3.utils.loadExtractor -import org.jsoup.Jsoup - - -/** Needs to inherit from MainAPI() to - * make the app know what functions to call - */ - -open class PelisplusProviderTemplate : MainAPI() { - override var lang = "es" - open val homePageUrlList = listOf() - -// // mainUrl is good to have as a holder for the url to make future changes easier. -// override val mainUrl: String -// get() = "https://vidembed.cc" -// -// // name is for how the provider will be named which is visible in the UI, no real rules for this. -// override val name: String -// get() = "VidEmbed" - - // hasQuickSearch defines if quickSearch() should be called, this is only when typing the searchbar - // gives results on the site instead of bringing you to another page. - // if hasQuickSearch is true and quickSearch() hasn't been overridden you will get errors. - // VidEmbed actually has quick search on their site, but the function wasn't implemented. - override val hasQuickSearch = false - - // If getMainPage() is functional, used to display the homepage in app, an optional, but highly encouraged endevour. - override val hasMainPage = true - - // Searching returns a SearchResponse, which can be one of the following: AnimeSearchResponse, MovieSearchResponse, TorrentSearchResponse, TvSeriesSearchResponse - // Each of the classes requires some different data, but always has some critical things like name, poster and url. - - override suspend fun search(query: String): ArrayList { - // Simply looking at devtools network is enough to spot a request like: - // https://vidembed.cc/search.html?keyword=neverland where neverland is the query, can be written as below. - val link = "$mainUrl/search.html?keyword=$query" - val html = app.get(link).text - val soup = Jsoup.parse(html) - - return ArrayList(soup.select(".listing.items > .video-block").map { li -> - // Selects the href in - val href = fixUrl(li.selectFirst("a")!!.attr("href")) - val poster = fixUrl(li.selectFirst("img")!!.attr("src")) - - // .text() selects all the text in the element, be careful about doing this while too high up in the html hierarchy - val title = cleanName(li.selectFirst(".name")!!.text()) - // Use get(0) and toIntOrNull() to prevent any possible crashes, [0] or toInt() will error the search on unexpected values. - val year = li.selectFirst(".date")?.text()?.split("-")?.get(0)?.toIntOrNull() - - TvSeriesSearchResponse( - // .trim() removes unwanted spaces in the start and end. - if (!title.contains("Episode")) title else title.split("Episode")[0].trim(), - href, - this.name, - TvType.TvSeries, - poster, year, - // You can't get the episodes from the search bar. - null - ) - }) - } - - - // Load, like the name suggests loads the info page, where all the episodes and data usually is. - // Like search you should return either of: AnimeLoadResponse, MovieLoadResponse, TorrentLoadResponse, TvSeriesLoadResponse. - override suspend fun load(url: String): LoadResponse? { - // Gets the url returned from searching. - val html = app.get(url).text - val soup = Jsoup.parse(html) - - val title = cleanName(soup.selectFirst("h1,h2,h3")!!.text()) - val description = soup.selectFirst(".post-entry")?.text()?.trim() - val poster = soup.selectFirst("head meta[property=og:image]")!!.attr("content") - - var year : Int? = null - val episodes = soup.select(".listing.items.lists > .video-block").map { li -> - val href = fixUrl(li.selectFirst("a")!!.attr("href")) - val regexseason = Regex("(-[Tt]emporada-(\\d+)-[Cc]apitulo-(\\d+))") - val aaa = regexseason.find(href)?.destructured?.component1()?.replace(Regex("(-[Tt]emporada-|[Cc]apitulo-)"),"") - val seasonid = aaa.let { str -> - str?.split("-")?.mapNotNull { subStr -> subStr.toIntOrNull() } - } - val isValid = seasonid?.size == 2 - val episode = if (isValid) seasonid?.getOrNull(1) else null - val season = if (isValid) seasonid?.getOrNull(0) else null - val epThumb = fixUrl(li.selectFirst("img")!!.attr("src")) - val epDate = li.selectFirst(".meta > .date")!!.text() - - if(year == null) { - year = epDate?.split("-")?.get(0)?.toIntOrNull() - } - - newEpisode(li.selectFirst("a")!!.attr("href")) { - this.season = season - this.episode = episode - this.posterUrl = epThumb - addDate(epDate) - } - }.reversed() - - // Make sure to get the type right to display the correct UI. - val tvType = if (episodes.size == 1 && episodes[0].name == title) TvType.Movie else TvType.TvSeries - - return when (tvType) { - TvType.TvSeries -> { - TvSeriesLoadResponse( - title, - url, - this.name, - tvType, - episodes, - fixUrl(poster), - year, - description, - null, - null, - null - ) - } - TvType.Movie -> { - MovieLoadResponse( - title, - url, - this.name, - tvType, - episodes[0].data, - fixUrl(poster), - year, - description, - null, - null - ) - } - else -> null - } - } - - // This loads the homepage, which is basically a collection of search results with labels. - // Optional function, but make sure to enable hasMainPage if you program this. - override suspend fun getMainPage(page: Int, request : MainPageRequest): HomePageResponse { - val urls = homePageUrlList - val homePageList = ArrayList() - // .pmap {} is used to fetch the different pages in parallel - urls.apmap { url -> - val response = app.get(url, timeout = 20).text - val document = Jsoup.parse(response) - document.select("div.main-inner")?.forEach { inner -> - // Always trim your text unless you want the risk of spaces at the start or end. - val title = cleanName(inner.select(".widget-title").text()) - val elements = inner.select(".video-block").map { - val link = fixUrl(it.select("a").attr("href")) - val image = it.select(".picture > img").attr("src").replace("//img", "https://img") - val name = cleanName(it.select("div.name").text()) - val isSeries = (name.contains("Temporada") || name.contains("Capítulo")) - - if (isSeries) { - TvSeriesSearchResponse( - name, - link, - this.name, - TvType.TvSeries, - image, - null, - null, - ) - } else { - MovieSearchResponse( - name, - link, - this.name, - TvType.Movie, - image, - null, - null, - ) - } - } - - homePageList.add( - HomePageList( - title, elements - ) - ) - - } - - } - return HomePageResponse(homePageList) - } - - - private fun cleanName(input: String): String = input.replace(Regex("([Tt]emporada (\\d+)|[Cc]apítulo (\\d+))|[Tt]emporada|[Cc]apítulo"),"").trim() - - - private suspend fun getPelisStream( - link: String, - callback: (ExtractorLink) -> Unit) : Boolean { - val soup = app.get(link).text - val m3u8regex = Regex("((https:|http:)\\/\\/.*m3u8.*expiry=(\\d+))") - val m3u8 = m3u8regex.find(soup)?.value ?: return false - - M3u8Helper.generateM3u8( - name, - m3u8, - mainUrl, - headers = mapOf("Referer" to mainUrl) - ).forEach (callback) - - return true - } - - // loadLinks gets the raw .mp4 or .m3u8 urls from the data parameter in the episodes class generated in load() - // See Episode(...) in this provider. - // The data are usually links, but can be any other string to help aid loading the links. - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - // These callbacks are functions you should call when you get a link to a subtitle file or media file. - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - val doc = app.get(data).document - val info = doc.select("div.tabs-video li").text() - if (info.contains("Latino")) { - doc.select(".server-item-1 li").apmap { - val serverid = fixUrl(it.attr("data-video")).replace("streaming.php","play") - loadExtractor(serverid, data, subtitleCallback, callback) - if (serverid.contains("pelisplus.icu")) { - getPelisStream(serverid, callback) - } - } - } - - if (info.contains("Subtitulado")) { - doc.select(".server-item-0 li").apmap { - val serverid = fixUrl(it.attr("data-video")).replace("streaming.php","play") - loadExtractor(serverid, data, subtitleCallback, callback) - if (serverid.contains("pelisplus.icu")) { - getPelisStream(serverid, callback) - } - } - } - - if (info.contains("Castellano")) { - doc.select(".server-item-2 li").apmap { - val serverid = fixUrl(it.attr("data-video")).replace("streaming.php","play") - loadExtractor(serverid, data, subtitleCallback, callback) - if (serverid.contains("pelisplus.icu")) { - getPelisStream(serverid, callback) - } - } - } - return true - } -} diff --git a/SeriesflixProvider/build.gradle.kts b/SeriesflixProvider/build.gradle.kts deleted file mode 100644 index 5a9960d..0000000 --- a/SeriesflixProvider/build.gradle.kts +++ /dev/null @@ -1,25 +0,0 @@ -// use an integer for version numbers -version = 1 - - -cloudstream { - // All of these properties are optional, you can safely remove them - - // description = "Lorem Ipsum" - // authors = listOf("Cloudburst") - - /** - * Status int as the following: - * 0: Down - * 1: Ok - * 2: Slow - * 3: Beta only - * */ - status = 1 // will be 3 if unspecified - tvTypes = listOf( - "TvSeries", - "Movie", - ) - - iconUrl = "https://www.google.com/s2/favicons?domain=seriesflix.video&sz=24" -} \ No newline at end of file diff --git a/SeriesflixProvider/src/main/AndroidManifest.xml b/SeriesflixProvider/src/main/AndroidManifest.xml deleted file mode 100644 index 29aec9d..0000000 --- a/SeriesflixProvider/src/main/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/SeriesflixProvider/src/main/kotlin/com/lagradost/SeriesflixProvider.kt b/SeriesflixProvider/src/main/kotlin/com/lagradost/SeriesflixProvider.kt deleted file mode 100644 index 1d8930c..0000000 --- a/SeriesflixProvider/src/main/kotlin/com/lagradost/SeriesflixProvider.kt +++ /dev/null @@ -1,226 +0,0 @@ -package com.lagradost - -import com.lagradost.cloudstream3.* -import com.lagradost.cloudstream3.LoadResponse.Companion.addDuration -import com.lagradost.cloudstream3.mvvm.logError -import com.lagradost.cloudstream3.utils.ExtractorLink -import com.lagradost.cloudstream3.utils.loadExtractor - -class SeriesflixProvider : MainAPI() { - override var mainUrl = "https://seriesflix.video" - override var name = "Seriesflix" - override var lang = "es" - override val hasMainPage = true - override val hasChromecastSupport = true - override val hasDownloadSupport = true - override val supportedTypes = setOf( - TvType.Movie, - TvType.TvSeries, - ) - - override suspend fun getMainPage(page: Int, request : MainPageRequest): HomePageResponse { - val items = ArrayList() - val urls = listOf( - Pair("$mainUrl/ver-series-online/", "Series"), - Pair("$mainUrl/genero/accion/", "Acción"), - Pair("$mainUrl/genero/ciencia-ficcion/", "Ciencia ficción"), - ) - for (i in urls) { - try { - val soup = app.get(i.first).document - val home = soup.select("article.TPost.B").map { - val title = it.selectFirst("h2.title")!!.text() - val link = it.selectFirst("a")!!.attr("href") - TvSeriesSearchResponse( - title, - link, - this.name, - TvType.Movie, - it.selectFirst("figure img")!!.attr("src"), - null, - null, - ) - } - - items.add(HomePageList(i.second, home)) - } catch (e: Exception) { - logError(e) - } - } - if (items.size <= 0) throw ErrorLoadingException() - return HomePageResponse(items) - } - - override suspend fun search(query: String): List { - val url = "$mainUrl/?s=$query" - val doc = app.get(url).document - return doc.select("article.TPost.B").map { - val href = it.selectFirst("a")!!.attr("href") - val poster = it.selectFirst("figure img")!!.attr("src") - val name = it.selectFirst("h2.title")!!.text() - val isMovie = href.contains("/movies/") - if (isMovie) { - MovieSearchResponse( - name, - href, - this.name, - TvType.Movie, - poster, - null - ) - } else { - TvSeriesSearchResponse( - name, - href, - this.name, - TvType.TvSeries, - poster, - null, - null - ) - } - }.toList() - } - - - override suspend fun load(url: String): LoadResponse { - val type = if (url.contains("/movies/")) TvType.Movie else TvType.TvSeries - - val document = app.get(url).document - - val title = document.selectFirst("h1.Title")!!.text() - val descRegex = Regex("(Recuerda.*Seriesflix.)") - val descipt = document.selectFirst("div.Description > p")!!.text().replace(descRegex, "") - val rating = - document.selectFirst("div.Vote > div.post-ratings > span")?.text()?.toRatingInt() - val year = document.selectFirst("span.Date")?.text() - // ?: does not work - val duration = try { - document.selectFirst("span.Time")!!.text() - } catch (e: Exception) { - null - } - val postercss = document.selectFirst("head").toString() - val posterRegex = - Regex("(\"og:image\" content=\"https://seriesflix.video/wp-content/uploads/(\\d+)/(\\d+)/?.*.jpg)") - val poster = try { - posterRegex.findAll(postercss).map { - it.value.replace("\"og:image\" content=\"", "") - }.toList().first() - } catch (e: Exception) { - document.select(".TPostBg").attr("src") - } - - if (type == TvType.TvSeries) { - val list = ArrayList>() - - document.select("main > section.SeasonBx > div > div.Title > a").forEach { element -> - val season = element.selectFirst("> span")?.text()?.toIntOrNull() - val href = element.attr("href") - if (season != null && season > 0 && !href.isNullOrBlank()) { - list.add(Pair(season, fixUrl(href))) - } - } - if (list.isEmpty()) throw ErrorLoadingException("No Seasons Found") - - val episodeList = ArrayList() - - for (season in list) { - val seasonDocument = app.get(season.second).document - val episodes = seasonDocument.select("table > tbody > tr") - if (episodes.isNotEmpty()) { - episodes.forEach { episode -> - val epNum = episode.selectFirst("> td > span.Num")?.text()?.toIntOrNull() - val epthumb = episode.selectFirst("img")?.attr("src") - val aName = episode.selectFirst("> td.MvTbTtl > a") - val name = aName!!.text() - val href = aName!!.attr("href") - val date = episode.selectFirst("> td.MvTbTtl > span")?.text() - episodeList.add( - newEpisode(href) { - this.name = name - this.season = season.first - this.episode = epNum - this.posterUrl = fixUrlNull(epthumb) - addDate(date) - } - ) - } - } - } - return TvSeriesLoadResponse( - title, - url, - this.name, - type, - episodeList, - fixUrlNull(poster), - year?.toIntOrNull(), - descipt, - null, - rating - ) - } else { - return newMovieLoadResponse( - title, - url, - type, - url - ) { - posterUrl = fixUrlNull(poster) - this.year = year?.toIntOrNull() - this.plot = descipt - this.rating = rating - addDuration(duration) - } - } - } - - override suspend fun loadLinks( - data: String, - isCasting: Boolean, - subtitleCallback: (SubtitleFile) -> Unit, - callback: (ExtractorLink) -> Unit - ): Boolean { - app.get(data).document.select("ul.ListOptions li").forEach { - val movieID = it.attr("data-id") - val serverID = it.attr("data-key") - val type = if (data.contains("movies")) 1 else 2 - val url = - "$mainUrl/?trembed=$serverID&trid=$movieID&trtype=$type" //This is to get the POST key value - val doc1 = app.get(url).document - doc1.select("div.Video iframe").apmap { - val iframe = it.attr("src") - val postkey = - iframe.replace("https://sc.seriesflix.video/index.php?h=", "") // this obtains - // djNIdHNCR2lKTGpnc3YwK3pyRCs3L2xkQmljSUZ4ai9ibTcza0JRODNMcmFIZ0hPejdlYW0yanJIL2prQ1JCZA POST KEY - app.post( - "https://sc.seriesflix.video/r.php", - headers = mapOf( - "Host" to "sc.seriesflix.video", - "User-Agent" to USER_AGENT, - "Accept" to "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8", - "Accept-Language" to "en-US,en;q=0.5", - "Content-Type" to "application/x-www-form-urlencoded", - "Origin" to "null", - "DNT" to "1", - "Alt-Used" to "sc.seriesflix.video", - "Connection" to "keep-alive", - "Upgrade-Insecure-Requests" to "1", - "Sec-Fetch-Dest" to "iframe", - "Sec-Fetch-Mode" to "navigate", - "Sec-Fetch-Site" to "same-origin", - "Sec-Fetch-User" to "?1", - ), - params = mapOf(Pair("h", postkey)), - data = mapOf(Pair("h", postkey)), - allowRedirects = false - ).okhttpResponse.headers.values("location").apmap { link -> - val url1 = link.replace("#bu", "") - loadExtractor(url1, data, subtitleCallback, callback) - } - } - } - return true - } -} diff --git a/SeriesflixProvider/src/main/kotlin/com/lagradost/SeriesflixProviderPlugin.kt b/SeriesflixProvider/src/main/kotlin/com/lagradost/SeriesflixProviderPlugin.kt deleted file mode 100644 index ee822ae..0000000 --- a/SeriesflixProvider/src/main/kotlin/com/lagradost/SeriesflixProviderPlugin.kt +++ /dev/null @@ -1,14 +0,0 @@ - -package com.lagradost - -import com.lagradost.cloudstream3.plugins.CloudstreamPlugin -import com.lagradost.cloudstream3.plugins.Plugin -import android.content.Context - -@CloudstreamPlugin -class SeriesflixProviderPlugin: Plugin() { - override fun load(context: Context) { - // All providers should be added in this manner. Please don't edit the providers list directly. - registerMainAPI(SeriesflixProvider()) - } -} \ No newline at end of file