mirror of
https://github.com/hexated/cloudstream-extensions-hexated.git
synced 2024-08-15 00:03:22 +00:00
sora: bump
This commit is contained in:
parent
7b6b138dcc
commit
2f2358d6c1
5 changed files with 14 additions and 149 deletions
|
@ -1,7 +1,7 @@
|
||||||
import org.jetbrains.kotlin.konan.properties.Properties
|
import org.jetbrains.kotlin.konan.properties.Properties
|
||||||
|
|
||||||
// use an integer for version numbers
|
// use an integer for version numbers
|
||||||
version = 164
|
version = 165
|
||||||
|
|
||||||
android {
|
android {
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
|
|
|
@ -234,92 +234,6 @@ object SoraExtractor : SoraStream() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
suspend fun invokeHDMovieBox(
|
|
||||||
title: String? = null,
|
|
||||||
season: Int? = null,
|
|
||||||
episode: Int? = null,
|
|
||||||
subtitleCallback: (SubtitleFile) -> Unit,
|
|
||||||
callback: (ExtractorLink) -> Unit
|
|
||||||
) {
|
|
||||||
val fixTitle = title.createSlug()
|
|
||||||
val url = "$hdMovieBoxAPI/watch/$fixTitle"
|
|
||||||
val doc = app.get(url).document
|
|
||||||
val id = if (season == null) {
|
|
||||||
doc.selectFirst("div.player div#not-loaded")?.attr("data-whatwehave")
|
|
||||||
} else {
|
|
||||||
doc.select("div.season-list-column div[data-season=$season] div.list div.item")[episode?.minus(
|
|
||||||
1
|
|
||||||
) ?: 0].selectFirst("div.ui.checkbox")?.attr("data-episode")
|
|
||||||
} ?: return
|
|
||||||
|
|
||||||
val iframeUrl = app.post(
|
|
||||||
"$hdMovieBoxAPI/ajax/service", data = mapOf(
|
|
||||||
"e_id" to id,
|
|
||||||
"v_lang" to "en",
|
|
||||||
"type" to "get_whatwehave",
|
|
||||||
), headers = mapOf("X-Requested-With" to "XMLHttpRequest")
|
|
||||||
).parsedSafe<HdMovieBoxIframe>()?.apiIframe ?: return
|
|
||||||
|
|
||||||
delay(1000)
|
|
||||||
val iframe = app.get(iframeUrl, referer = url).document.selectFirst("iframe")
|
|
||||||
?.attr("src").let { httpsify(it ?: return) }
|
|
||||||
|
|
||||||
if (iframe.startsWith("https://vidmoly.to")) {
|
|
||||||
loadExtractor(iframe, "$hdMovieBoxAPI/", subtitleCallback) { video ->
|
|
||||||
callback.invoke(
|
|
||||||
ExtractorLink(
|
|
||||||
video.name,
|
|
||||||
video.name,
|
|
||||||
video.url,
|
|
||||||
video.referer,
|
|
||||||
Qualities.P1080.value,
|
|
||||||
video.type,
|
|
||||||
video.headers,
|
|
||||||
video.extractorData
|
|
||||||
)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
val base = getBaseUrl(iframe)
|
|
||||||
val script = app.get(
|
|
||||||
httpsify(iframe), referer = "$hdMovieBoxAPI/"
|
|
||||||
).document.selectFirst("script:containsData(var vhash =)")?.data()
|
|
||||||
?.substringAfter("vhash, {")?.substringBefore("}, false")
|
|
||||||
|
|
||||||
tryParseJson<HdMovieBoxSource>("{$script}").let { source ->
|
|
||||||
val disk = if (source?.videoDisk == null) {
|
|
||||||
""
|
|
||||||
} else {
|
|
||||||
base64Encode(source.videoDisk.toString().toByteArray())
|
|
||||||
}
|
|
||||||
val link = getBaseUrl(iframe) + source?.videoUrl?.replace(
|
|
||||||
"\\", ""
|
|
||||||
) + "?s=${source?.videoServer}&d=$disk"
|
|
||||||
callback.invoke(
|
|
||||||
ExtractorLink(
|
|
||||||
"HDMovieBox",
|
|
||||||
"HDMovieBox",
|
|
||||||
link,
|
|
||||||
iframe,
|
|
||||||
Qualities.P1080.value,
|
|
||||||
isM3u8 = true,
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
source?.tracks?.map { sub ->
|
|
||||||
subtitleCallback.invoke(
|
|
||||||
SubtitleFile(
|
|
||||||
sub.label ?: "",
|
|
||||||
fixUrl(sub.file ?: return@map null, base),
|
|
||||||
)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
suspend fun invokeDreamfilm(
|
suspend fun invokeDreamfilm(
|
||||||
title: String? = null,
|
title: String? = null,
|
||||||
season: Int? = null,
|
season: Int? = null,
|
||||||
|
@ -1517,14 +1431,15 @@ object SoraExtractor : SoraStream() {
|
||||||
subtitleCallback: (SubtitleFile) -> Unit,
|
subtitleCallback: (SubtitleFile) -> Unit,
|
||||||
callback: (ExtractorLink) -> Unit
|
callback: (ExtractorLink) -> Unit
|
||||||
) {
|
) {
|
||||||
|
val (seasonSlug, episodeSlug) = getEpisodeSlug(season, episode)
|
||||||
val req = app.get("$m4uhdAPI/search/${title.createSlug()}.html")
|
val req = app.get("$m4uhdAPI/search/${title.createSlug()}.html")
|
||||||
val referer = getBaseUrl(req.url)
|
val referer = getBaseUrl(req.url)
|
||||||
val res = req.document
|
val res = req.document
|
||||||
val scriptData = res.select("div.row div.item").map {
|
val scriptData = res.select("div.row div.item").map { ele ->
|
||||||
Triple(
|
Triple(
|
||||||
it.selectFirst("img.imagecover")?.attr("title"),
|
ele.select("div.tiptitle p").text(),
|
||||||
it.selectFirst("div.jtip-top div:last-child")?.text(),
|
ele.select("div.jtip-top div:last-child").text().filter { it.isDigit() },
|
||||||
it.selectFirst("a")?.attr("href")
|
ele.selectFirst("a")?.attr("href")
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1532,11 +1447,9 @@ object SoraExtractor : SoraStream() {
|
||||||
scriptData.firstOrNull()
|
scriptData.firstOrNull()
|
||||||
} else {
|
} else {
|
||||||
scriptData.find {
|
scriptData.find {
|
||||||
it.first?.contains(
|
it.first.contains(
|
||||||
"Watch Free ${title?.replace(":", "")}", true
|
"$title", true
|
||||||
) == true && (it.first?.contains("$year") == true || it.second?.contains(
|
) && it.second == "$year"
|
||||||
"$year"
|
|
||||||
) == true)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1556,7 +1469,7 @@ object SoraExtractor : SoraStream() {
|
||||||
doc.select("div.le-server span").map { it.attr("data") }
|
doc.select("div.le-server span").map { it.attr("data") }
|
||||||
} else {
|
} else {
|
||||||
val episodeData =
|
val episodeData =
|
||||||
doc.selectFirst("div.col-lg-9.col-xl-9 p:matches((?i)S0?$season-E0?$episode$)")
|
doc.selectFirst("div.col-lg-9.col-xl-9 p:matches((?i)S$seasonSlug-E$episodeSlug)")
|
||||||
?: return
|
?: return
|
||||||
val idepisode = episodeData.select("button").attr("idepisode") ?: return
|
val idepisode = episodeData.select("button").attr("idepisode") ?: return
|
||||||
val requestEmbed = app.post(
|
val requestEmbed = app.post(
|
||||||
|
|
|
@ -47,22 +47,6 @@ 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(
|
|
||||||
@JsonProperty("videoUrl") val videoUrl: String? = null,
|
|
||||||
@JsonProperty("videoServer") val videoServer: String? = null,
|
|
||||||
@JsonProperty("videoDisk") val videoDisk: Any? = null,
|
|
||||||
@JsonProperty("tracks") val tracks: ArrayList<HdMovieBoxTracks>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class HdMovieBoxIframe(
|
|
||||||
@JsonProperty("api_iframe") val apiIframe: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class ResponseHash(
|
data class ResponseHash(
|
||||||
@JsonProperty("embed_url") val embed_url: String,
|
@JsonProperty("embed_url") val embed_url: String,
|
||||||
@JsonProperty("key") val key: String? = null,
|
@JsonProperty("key") val key: String? = null,
|
||||||
|
|
|
@ -8,7 +8,6 @@ import com.hexated.SoraExtractor.invokeBollyMaza
|
||||||
import com.hexated.SoraExtractor.invokeCryMovies
|
import com.hexated.SoraExtractor.invokeCryMovies
|
||||||
import com.hexated.SoraExtractor.invokeDbgo
|
import com.hexated.SoraExtractor.invokeDbgo
|
||||||
import com.hexated.SoraExtractor.invokeFilmxy
|
import com.hexated.SoraExtractor.invokeFilmxy
|
||||||
import com.hexated.SoraExtractor.invokeHDMovieBox
|
|
||||||
import com.hexated.SoraExtractor.invokeIdlix
|
import com.hexated.SoraExtractor.invokeIdlix
|
||||||
import com.hexated.SoraExtractor.invokeKimcartoon
|
import com.hexated.SoraExtractor.invokeKimcartoon
|
||||||
import com.hexated.SoraExtractor.invokeMovieHab
|
import com.hexated.SoraExtractor.invokeMovieHab
|
||||||
|
@ -91,7 +90,6 @@ open class SoraStream : TmdbProvider() {
|
||||||
const val vidSrcAPI = "https://v2.vidsrc.me"
|
const val vidSrcAPI = "https://v2.vidsrc.me"
|
||||||
const val dbgoAPI = "https://dbgo.fun"
|
const val dbgoAPI = "https://dbgo.fun"
|
||||||
const val movieHabAPI = "https://moviehab.com"
|
const val movieHabAPI = "https://moviehab.com"
|
||||||
const val hdMovieBoxAPI = "https://hdmoviebox.net"
|
|
||||||
const val dreamfilmAPI = "https://dreamfilmsw.net"
|
const val dreamfilmAPI = "https://dreamfilmsw.net"
|
||||||
const val series9API = "https://series9.cx"
|
const val series9API = "https://series9.cx"
|
||||||
const val idlixAPI = "https://tv.idlixplus.net"
|
const val idlixAPI = "https://tv.idlixplus.net"
|
||||||
|
@ -106,7 +104,7 @@ open class SoraStream : TmdbProvider() {
|
||||||
const val fwatayakoAPI = "https://5100.svetacdn.in"
|
const val fwatayakoAPI = "https://5100.svetacdn.in"
|
||||||
const val gMoviesAPI = "https://gdrivemovies.xyz"
|
const val gMoviesAPI = "https://gdrivemovies.xyz"
|
||||||
const val fdMoviesAPI = "https://freedrivemovie.lol"
|
const val fdMoviesAPI = "https://freedrivemovie.lol"
|
||||||
const val m4uhdAPI = "https://m4uhd.tv"
|
const val m4uhdAPI = "https://ww2.m4ufree.com"
|
||||||
const val tvMoviesAPI = "https://www.tvseriesnmovies.com"
|
const val tvMoviesAPI = "https://www.tvseriesnmovies.com"
|
||||||
const val moviezAddAPI = "https://ww2.moviezaddiction.click"
|
const val moviezAddAPI = "https://ww2.moviezaddiction.click"
|
||||||
const val bollyMazaAPI = "https://m.bollymaza.click"
|
const val bollyMazaAPI = "https://m.bollymaza.click"
|
||||||
|
@ -127,7 +125,7 @@ open class SoraStream : TmdbProvider() {
|
||||||
const val pobmoviesAPI = "https://pobmovies.cam"
|
const val pobmoviesAPI = "https://pobmovies.cam"
|
||||||
const val fourCartoonAPI = "https://4cartoon.net"
|
const val fourCartoonAPI = "https://4cartoon.net"
|
||||||
const val multimoviesAPI = "https://multi-movies.xyz"
|
const val multimoviesAPI = "https://multi-movies.xyz"
|
||||||
const val netmoviesAPI = "https://netmovies.to"
|
const val netmoviesAPI = "https://web.netmovies.to"
|
||||||
const val momentAPI = "https://moment-explanation-i-244.site"
|
const val momentAPI = "https://moment-explanation-i-244.site"
|
||||||
const val doomoviesAPI = "https://doomovies.net"
|
const val doomoviesAPI = "https://doomovies.net"
|
||||||
const val primewireAPI = "https://real-primewire.club"
|
const val primewireAPI = "https://real-primewire.club"
|
||||||
|
@ -419,15 +417,6 @@ open class SoraStream : TmdbProvider() {
|
||||||
callback
|
callback
|
||||||
)
|
)
|
||||||
},
|
},
|
||||||
{
|
|
||||||
if (!res.isAnime) invokeHDMovieBox(
|
|
||||||
res.title,
|
|
||||||
res.season,
|
|
||||||
res.episode,
|
|
||||||
subtitleCallback,
|
|
||||||
callback
|
|
||||||
)
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
if (!res.isAnime) invokeDreamfilm(
|
if (!res.isAnime) invokeDreamfilm(
|
||||||
res.title,
|
res.title,
|
||||||
|
@ -541,7 +530,7 @@ open class SoraStream : TmdbProvider() {
|
||||||
{
|
{
|
||||||
if(!res.isAnime) invokeM4uhd(
|
if(!res.isAnime) invokeM4uhd(
|
||||||
res.title,
|
res.title,
|
||||||
res.year,
|
res.airedYear ?: res.year,
|
||||||
res.season,
|
res.season,
|
||||||
res.episode,
|
res.episode,
|
||||||
subtitleCallback,
|
subtitleCallback,
|
||||||
|
|
|
@ -11,7 +11,6 @@ import com.hexated.SoraExtractor.invokeFilmxy
|
||||||
import com.hexated.SoraExtractor.invokeFlixon
|
import com.hexated.SoraExtractor.invokeFlixon
|
||||||
import com.hexated.SoraExtractor.invokeFwatayako
|
import com.hexated.SoraExtractor.invokeFwatayako
|
||||||
import com.hexated.SoraExtractor.invokeGoku
|
import com.hexated.SoraExtractor.invokeGoku
|
||||||
import com.hexated.SoraExtractor.invokeHDMovieBox
|
|
||||||
import com.hexated.SoraExtractor.invokeIdlix
|
import com.hexated.SoraExtractor.invokeIdlix
|
||||||
import com.hexated.SoraExtractor.invokeKimcartoon
|
import com.hexated.SoraExtractor.invokeKimcartoon
|
||||||
import com.hexated.SoraExtractor.invokeKisskh
|
import com.hexated.SoraExtractor.invokeKisskh
|
||||||
|
@ -33,7 +32,6 @@ import com.hexated.SoraExtractor.invokeMoment
|
||||||
import com.hexated.SoraExtractor.invokeMultimovies
|
import com.hexated.SoraExtractor.invokeMultimovies
|
||||||
import com.hexated.SoraExtractor.invokeNetmovies
|
import com.hexated.SoraExtractor.invokeNetmovies
|
||||||
import com.hexated.SoraExtractor.invokePrimewire
|
import com.hexated.SoraExtractor.invokePrimewire
|
||||||
import com.hexated.SoraExtractor.invokeSusflix
|
|
||||||
import com.hexated.SoraExtractor.invokeVidSrc
|
import com.hexated.SoraExtractor.invokeVidSrc
|
||||||
import com.hexated.SoraExtractor.invokeVidsrcto
|
import com.hexated.SoraExtractor.invokeVidsrcto
|
||||||
import com.hexated.SoraExtractor.invokeWatchOnline
|
import com.hexated.SoraExtractor.invokeWatchOnline
|
||||||
|
@ -127,25 +125,6 @@ class SoraStreamLite : SoraStream() {
|
||||||
callback
|
callback
|
||||||
)
|
)
|
||||||
},
|
},
|
||||||
// {
|
|
||||||
// if (res.season != null && res.isAnime) invokeCrunchyroll(
|
|
||||||
// res.title,
|
|
||||||
// res.epsTitle,
|
|
||||||
// res.season,
|
|
||||||
// res.episode,
|
|
||||||
// subtitleCallback,
|
|
||||||
// callback
|
|
||||||
// )
|
|
||||||
// },
|
|
||||||
{
|
|
||||||
if (!res.isAnime) invokeHDMovieBox(
|
|
||||||
res.title,
|
|
||||||
res.season,
|
|
||||||
res.episode,
|
|
||||||
subtitleCallback,
|
|
||||||
callback
|
|
||||||
)
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
if (!res.isAnime) invokeDreamfilm(
|
if (!res.isAnime) invokeDreamfilm(
|
||||||
res.title,
|
res.title,
|
||||||
|
@ -259,7 +238,7 @@ class SoraStreamLite : SoraStream() {
|
||||||
{
|
{
|
||||||
if(!res.isAnime) invokeM4uhd(
|
if(!res.isAnime) invokeM4uhd(
|
||||||
res.title,
|
res.title,
|
||||||
res.year,
|
res.airedYear ?: res.year,
|
||||||
res.season,
|
res.season,
|
||||||
res.episode,
|
res.episode,
|
||||||
subtitleCallback,
|
subtitleCallback,
|
||||||
|
|
Loading…
Reference in a new issue