[Sora] filter ecchi & erotic movie from tmdb

This commit is contained in:
hexated 2023-01-01 01:06:35 +07:00
parent bd82ba5d51
commit 6c7dc430a4
3 changed files with 55 additions and 39 deletions

View file

@ -1,5 +1,5 @@
// use an integer for version numbers // use an integer for version numbers
version = 66 version = 67
cloudstream { cloudstream {

View file

@ -1,6 +1,5 @@
package com.hexated package com.hexated
import android.util.Log
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
import com.lagradost.cloudstream3.* import com.lagradost.cloudstream3.*
import com.lagradost.cloudstream3.utils.* import com.lagradost.cloudstream3.utils.*
@ -12,7 +11,6 @@ import com.lagradost.cloudstream3.extractors.XStreamCdn
import com.lagradost.cloudstream3.network.CloudflareKiller import com.lagradost.cloudstream3.network.CloudflareKiller
import com.lagradost.nicehttp.RequestBodyTypes import com.lagradost.nicehttp.RequestBodyTypes
import kotlinx.coroutines.delay import kotlinx.coroutines.delay
import okhttp3.HttpUrl.Companion.toHttpUrl
import okhttp3.MediaType.Companion.toMediaTypeOrNull import okhttp3.MediaType.Companion.toMediaTypeOrNull
import okhttp3.RequestBody.Companion.toRequestBody import okhttp3.RequestBody.Companion.toRequestBody
@ -342,6 +340,7 @@ object SoraExtractor : SoraStream() {
title: String? = null, title: String? = null,
season: Int? = null, season: Int? = null,
episode: Int? = null, episode: Int? = null,
subtitleCallback: (SubtitleFile) -> Unit,
callback: (ExtractorLink) -> Unit callback: (ExtractorLink) -> Unit
) { ) {
val fixTitle = title.fixTitle() val fixTitle = title.fixTitle()
@ -367,9 +366,10 @@ object SoraExtractor : SoraStream() {
delay(1000) delay(1000)
val iframe = app.get(iframeUrl, referer = "$hdMovieBoxAPI/").document.selectFirst("iframe") val iframe = app.get(iframeUrl, referer = "$hdMovieBoxAPI/").document.selectFirst("iframe")
?.attr("src") ?.attr("src")
val base = getBaseUrl(iframe ?: return)
val script = app.get( val script = app.get(
iframe ?: return, referer = "$hdMovieBoxAPI/" iframe, referer = "$hdMovieBoxAPI/"
).document.selectFirst("script:containsData(var vhash =)")?.data() ).document.selectFirst("script:containsData(var vhash =)")?.data()
?.substringAfter("vhash, {")?.substringBefore("}, false") ?.substringAfter("vhash, {")?.substringBefore("}, false")
@ -392,6 +392,15 @@ object SoraExtractor : SoraStream() {
isM3u8 = true, isM3u8 = true,
) )
) )
source?.tracks?.map { sub ->
subtitleCallback.invoke(
SubtitleFile(
sub.label ?: "",
fixUrl(sub.file ?: return@map null, base),
)
)
}
} }
} }
@ -853,26 +862,45 @@ object SoraExtractor : SoraStream() {
) { ) {
val fixTitle = title.fixTitle() val fixTitle = title.fixTitle()
val url = if (season == null) { val url = if (season == null) {
"$xMovieAPI/movies/$fixTitle/watch" val tempUrl = "$xMovieAPI/movies/$fixTitle/watch"
val newUrl = app.get(tempUrl).url
if(newUrl == "$xMovieAPI/") "$xMovieAPI/movies/$fixTitle-$year/watch" else tempUrl
} else { } else {
"$xMovieAPI/series/$fixTitle-season-$season-episode-$episode/watch" "$xMovieAPI/series/$fixTitle-season-$season-episode-$episode/watch"
} }
val doc = app.get(url).text val doc = app.get(url).document
val link = val script = doc.selectFirst("script:containsData(const player =)")?.data() ?: return
Regex("[\"|']file[\"|']:\\s?[\"|'](http.*?.mp4)[\"|'],").find(doc)?.groupValues?.getOrNull( val link = Regex("[\"|']file[\"|']:\\s?[\"|'](http.*?.(mp4|m3u8))[\"|'],").find(script)?.groupValues?.getOrNull(
1 1
) ) ?: return
callback.invoke( if(link.contains(".m3u8")) {
ExtractorLink( M3u8Helper.generateM3u8(
"Xmovie", "Xmovie",
"Xmovie", link,
link ?: return,
"", "",
Qualities.Unknown.value, ).forEach(callback)
} else {
callback.invoke(
ExtractorLink(
"Xmovie",
"Xmovie",
link,
"",
Qualities.P720.value,
)
) )
) }
Regex(""""file":\s+?"(\S+\.(vtt|srt))""").find(script)?.groupValues?.getOrNull(1)?.let { sub ->
subtitleCallback.invoke(
SubtitleFile(
"English",
sub,
)
)
}
} }
@ -1139,7 +1167,6 @@ object SoraExtractor : SoraStream() {
season: Int? = null, season: Int? = null,
lastSeason: Int? = null, lastSeason: Int? = null,
episode: Int? = null, episode: Int? = null,
subtitleCallback: (SubtitleFile) -> Unit,
callback: (ExtractorLink) -> Unit callback: (ExtractorLink) -> Unit
) { ) {
val url = if (season == null) { val url = if (season == null) {
@ -1265,7 +1292,6 @@ object SoraExtractor : SoraStream() {
year: Int? = null, year: Int? = null,
season: Int? = null, season: Int? = null,
episode: Int? = null, episode: Int? = null,
subtitleCallback: (SubtitleFile) -> Unit,
callback: (ExtractorLink) -> Unit callback: (ExtractorLink) -> Unit
) { ) {
val fixTitle = title.fixTitle() val fixTitle = title.fixTitle()
@ -1314,7 +1340,6 @@ object SoraExtractor : SoraStream() {
title: String? = null, title: String? = null,
season: Int? = null, season: Int? = null,
episode: Int? = null, episode: Int? = null,
subtitleCallback: (SubtitleFile) -> Unit,
callback: (ExtractorLink) -> Unit callback: (ExtractorLink) -> Unit
) { ) {
val fixTitle = title.fixTitle() val fixTitle = title.fixTitle()
@ -1339,7 +1364,6 @@ object SoraExtractor : SoraStream() {
"4k", true "4k", true
)) && (it.type.contains("gdtot") || it.type.contains("oiya")) )) && (it.type.contains("gdtot") || it.type.contains("oiya"))
} }
Log.i("hexated", "$iframe")
iframe.apmap { (link, quality, size, type) -> iframe.apmap { (link, quality, size, type) ->
val qualities = getFDoviesQuality(quality) val qualities = getFDoviesQuality(quality)
val fdLink = bypassFdAds(link) val fdLink = bypassFdAds(link)
@ -1461,7 +1485,6 @@ object SoraExtractor : SoraStream() {
title: String? = null, title: String? = null,
season: Int? = null, season: Int? = null,
episode: Int? = null, episode: Int? = null,
subtitleCallback: (SubtitleFile) -> Unit,
callback: (ExtractorLink) -> Unit callback: (ExtractorLink) -> Unit
) { ) {
val fixTitle = title.fixTitle() val fixTitle = title.fixTitle()
@ -1543,7 +1566,6 @@ object SoraExtractor : SoraStream() {
suspend fun invokeMoviesbay( suspend fun invokeMoviesbay(
title: String? = null, title: String? = null,
year: Int? = null, year: Int? = null,
subtitleCallback: (SubtitleFile) -> Unit,
callback: (ExtractorLink) -> Unit callback: (ExtractorLink) -> Unit
) { ) {
val url = val url =
@ -1587,7 +1609,6 @@ object SoraExtractor : SoraStream() {
year: Int? = null, year: Int? = null,
season: Int? = null, season: Int? = null,
episode: Int? = null, episode: Int? = null,
subtitleCallback: (SubtitleFile) -> Unit,
callback: (ExtractorLink) -> Unit callback: (ExtractorLink) -> Unit
) { ) {
val fixTitle = title?.fixTitle()?.replace("-", " ") val fixTitle = title?.fixTitle()?.replace("-", " ")
@ -1675,10 +1696,16 @@ data class MoviesbayValues(
@JsonProperty("values") val values: List<List<String>>? = arrayListOf(), @JsonProperty("values") val values: List<List<String>>? = arrayListOf(),
) )
data class HdMovieBoxTracks(
@JsonProperty("label") val label: String? = null,
@JsonProperty("file") val file: String? = null,
)
data class HdMovieBoxSource( data class HdMovieBoxSource(
@JsonProperty("videoUrl") val videoUrl: String? = null, @JsonProperty("videoUrl") val videoUrl: String? = null,
@JsonProperty("videoServer") val videoServer: String? = null, @JsonProperty("videoServer") val videoServer: String? = null,
@JsonProperty("videoDisk") val videoDisk: Any? = null, @JsonProperty("videoDisk") val videoDisk: Any? = null,
@JsonProperty("tracks") val tracks: ArrayList<HdMovieBoxTracks>? = arrayListOf(),
) )
data class HdMovieBoxIframe( data class HdMovieBoxIframe(
@ -1794,12 +1821,6 @@ data class KisskhResults(
@JsonProperty("title") val title: String?, @JsonProperty("title") val title: String?,
) )
data class AnimixData(
@JsonProperty("title") val title: String? = null,
@JsonProperty("title_english") val title_english: String? = null,
@JsonProperty("title_japanese") val title_japanese: String? = null,
)
data class EpisodesFwatayako( data class EpisodesFwatayako(
@JsonProperty("id") val id: String? = null, @JsonProperty("id") val id: String? = null,
@JsonProperty("file") val file: String? = null, @JsonProperty("file") val file: String? = null,

View file

@ -113,8 +113,8 @@ open class SoraStream : TmdbProvider() {
override val mainPage = mainPageOf( override val mainPage = mainPageOf(
"$tmdbAPI/trending/all/day?api_key=$apiKey&region=&page=" to "Trending", "$tmdbAPI/trending/all/day?api_key=$apiKey&region=&page=" to "Trending",
"$tmdbAPI/movie/popular?api_key=$apiKey&region=&page=" to "Popular Movies", "$tmdbAPI/movie/popular?api_key=$apiKey&region=&without_keywords=190370&page=" to "Popular Movies",
"$tmdbAPI/tv/popular?api_key=$apiKey&region=&page=" to "Popular TV Shows", "$tmdbAPI/tv/popular?api_key=$apiKey&region=&without_keywords=190370&page=" to "Popular TV Shows",
"$tmdbAPI/tv/airing_today?api_key=$apiKey&region=&page=" to "Airing Today TV Shows", "$tmdbAPI/tv/airing_today?api_key=$apiKey&region=&page=" to "Airing Today TV Shows",
// "$tmdbAPI/tv/on_the_air?api_key=$apiKey&region=&page=" to "On The Air TV Shows", // "$tmdbAPI/tv/on_the_air?api_key=$apiKey&region=&page=" to "On The Air TV Shows",
"$tmdbAPI/discover/tv?api_key=$apiKey&with_networks=213&page=" to "Netflix", "$tmdbAPI/discover/tv?api_key=$apiKey&with_networks=213&page=" to "Netflix",
@ -129,8 +129,8 @@ open class SoraStream : TmdbProvider() {
"$tmdbAPI/discover/tv?api_key=$apiKey&with_original_language=ko&page=" to "Korean Shows", "$tmdbAPI/discover/tv?api_key=$apiKey&with_original_language=ko&page=" to "Korean Shows",
"$tmdbAPI/tv/airing_today?api_key=$apiKey&with_keywords=210024|222243&sort_by=primary_release_date.desc&page=" to "Airing Today Anime", "$tmdbAPI/tv/airing_today?api_key=$apiKey&with_keywords=210024|222243&sort_by=primary_release_date.desc&page=" to "Airing Today Anime",
"$tmdbAPI/tv/on_the_air?api_key=$apiKey&with_keywords=210024|222243&sort_by=primary_release_date.desc&page=" to "Ongoing Anime", "$tmdbAPI/tv/on_the_air?api_key=$apiKey&with_keywords=210024|222243&sort_by=primary_release_date.desc&page=" to "Ongoing Anime",
"$tmdbAPI/discover/tv?api_key=$apiKey&with_keywords=210024|222243&page=" to "Anime", "$tmdbAPI/discover/tv?api_key=$apiKey&with_keywords=210024|222243&without_keywords=195669&page=" to "Anime",
"$tmdbAPI/discover/movie?api_key=$apiKey&with_keywords=210024|222243&page=" to "Anime Movies", "$tmdbAPI/discover/movie?api_key=$apiKey&with_keywords=210024|222243&without_keywords=195669&page=" to "Anime Movies",
) )
private fun getImageUrl(link: String?): String? { private fun getImageUrl(link: String?): String? {
@ -361,7 +361,7 @@ open class SoraStream : TmdbProvider() {
) )
}, },
{ {
if (!res.isAnime) invokeHDMovieBox(res.title, res.season, res.episode, callback) if (!res.isAnime) invokeHDMovieBox(res.title, res.season, res.episode, subtitleCallback, callback)
}, },
{ {
invokeSeries9(res.title, res.season, res.episode, subtitleCallback, callback) invokeSeries9(res.title, res.season, res.episode, subtitleCallback, callback)
@ -435,7 +435,6 @@ open class SoraStream : TmdbProvider() {
res.season, res.season,
res.lastSeason, res.lastSeason,
res.episode, res.episode,
subtitleCallback,
callback callback
) )
}, },
@ -448,7 +447,6 @@ open class SoraStream : TmdbProvider() {
res.year, res.year,
res.season, res.season,
res.episode, res.episode,
subtitleCallback,
callback callback
) )
}, },
@ -457,7 +455,6 @@ open class SoraStream : TmdbProvider() {
res.title, res.title,
res.season, res.season,
res.episode, res.episode,
subtitleCallback,
callback callback
) )
}, },
@ -472,13 +469,12 @@ open class SoraStream : TmdbProvider() {
) )
}, },
{ {
invokeTvMovies(res.title, res.season, res.episode, subtitleCallback, callback) invokeTvMovies(res.title, res.season, res.episode, callback)
}, },
{ {
if (res.season == null) invokeMoviesbay( if (res.season == null) invokeMoviesbay(
res.title, res.title,
res.year, res.year,
subtitleCallback,
callback callback
) )
}, },
@ -488,7 +484,6 @@ open class SoraStream : TmdbProvider() {
res.year, res.year,
res.season, res.season,
res.episode, res.episode,
subtitleCallback,
callback callback
) )
}, },