mirror of
https://github.com/hexated/cloudstream-extensions-hexated.git
synced 2024-08-15 00:03:22 +00:00
All Servers Support
This commit is contained in:
parent
036c0db9c8
commit
6dba40b2f3
2 changed files with 66 additions and 33 deletions
|
@ -1,5 +1,5 @@
|
||||||
// use an integer for version numbers
|
// use an integer for version numbers
|
||||||
version = 2
|
version = 3
|
||||||
|
|
||||||
|
|
||||||
cloudstream {
|
cloudstream {
|
||||||
|
|
|
@ -23,15 +23,14 @@ class ElOstoraTV : MainAPI() {
|
||||||
)
|
)
|
||||||
private val APIurl = "https://z420572.radwan.shop/api/v4_8.php"
|
private val APIurl = "https://z420572.radwan.shop/api/v4_8.php"
|
||||||
|
|
||||||
override val mainPage = generateHomePage()
|
//override val mainPage = generateHomePage()
|
||||||
|
override val mainPage = generateServersHomePage()
|
||||||
private fun generateHomePage() : List<MainPageData> {
|
private fun generateServersHomePage() : List<MainPageData> {
|
||||||
|
|
||||||
val homepage = mutableListOf<MainPageData>()
|
val homepage = mutableListOf<MainPageData>()
|
||||||
val data = mapOf(
|
val data = mapOf(
|
||||||
"main_id" to "1",
|
"main" to "1",
|
||||||
"id" to "",
|
"id" to "",
|
||||||
"sub_id" to "0"
|
|
||||||
)
|
)
|
||||||
val decodedbody = getDecoded(data)
|
val decodedbody = getDecoded(data)
|
||||||
//Log.d("King", "decodedbody:$decodedbody")
|
//Log.d("King", "decodedbody:$decodedbody")
|
||||||
|
@ -39,50 +38,75 @@ class ElOstoraTV : MainAPI() {
|
||||||
parseJson<Categories>(decodedbody).results?.map { element ->
|
parseJson<Categories>(decodedbody).results?.map { element ->
|
||||||
homepage.add(mainPage(name = element.category_name, url = element.cid))
|
homepage.add(mainPage(name = element.category_name, url = element.cid))
|
||||||
} ?: throw ErrorLoadingException("Invalid Json response")
|
} ?: throw ErrorLoadingException("Invalid Json response")
|
||||||
|
//Log.d("King", "homepage:$homepage")
|
||||||
return homepage
|
return homepage
|
||||||
}
|
}
|
||||||
|
|
||||||
override suspend fun getMainPage(page: Int, request: MainPageRequest): HomePageResponse {
|
override suspend fun getMainPage(page: Int, request: MainPageRequest): HomePageResponse {
|
||||||
val items = mutableListOf<HomePageList>()
|
val items = mutableListOf<HomePageList>()
|
||||||
if (page <= 1) {
|
if (page <= 1) {
|
||||||
//Log.d("King", "request:$request")
|
//Log.d("King", "getMainPage:$request")
|
||||||
val data = mapOf(
|
val data = mapOf(
|
||||||
|
"main_id" to request.data,
|
||||||
"id" to "",
|
"id" to "",
|
||||||
"cat_id" to request.data
|
"sub_id" to "0"
|
||||||
)
|
)
|
||||||
val decodedbody = getDecoded(data)
|
val decodedbody = getDecoded(data)
|
||||||
//Log.d("King", "decodedbody:$decodedbody")
|
//Log.d("King", "getMaindecodedbody:$decodedbody")
|
||||||
val list = parseJson<Results>(decodedbody).results?.map { element ->
|
val list = parseJson<Categories>(decodedbody).results?.map { element ->
|
||||||
element.toSearchResponse(request)
|
element.toSearchResponse(request)
|
||||||
} ?: throw ErrorLoadingException("Invalid Json response")
|
} ?: throw ErrorLoadingException("Invalid Json response")
|
||||||
if (list.isNotEmpty()) items.add(HomePageList(request.name, list, true))
|
if (list.isNotEmpty()) items.add(HomePageList(request.name, list, false))
|
||||||
}
|
}
|
||||||
|
//Log.d("King", "items:$items")
|
||||||
return newHomePageResponse(items)
|
return newHomePageResponse(items)
|
||||||
}
|
}
|
||||||
|
private fun Category.toSearchResponse(request: MainPageRequest): SearchResponse {
|
||||||
private fun Channel.toSearchResponse(request: MainPageRequest): SearchResponse {
|
|
||||||
return LiveSearchResponse(
|
return LiveSearchResponse(
|
||||||
name = this.channel_title,
|
name = this.category_name,
|
||||||
url = Data(id = id, channel_title = this.channel_title, channel_thumbnail = this.channel_thumbnail, category = request.name, channel_url = this.channel_url).toJson(),
|
url = Data(id = cid, channel_title = this.category_name, channel_thumbnail = this.image, category = request.name, channel_url = cid).toJson(),
|
||||||
this@ElOstoraTV.name,
|
this@ElOstoraTV.name,
|
||||||
TvType.Live,
|
TvType.Live,
|
||||||
this.channel_thumbnail,
|
this.image,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
override suspend fun load(url: String): LoadResponse {
|
override suspend fun load(url: String): LoadResponse {
|
||||||
//Log.d("King", "Load:$url")
|
Log.d("King", "Load:$url")
|
||||||
val data = parseJson<Data>(url)
|
val data = parseJson<Data>(url)
|
||||||
|
|
||||||
return LiveStreamLoadResponse(
|
val Postdata = mapOf(
|
||||||
name = data.channel_title,
|
"id" to "",
|
||||||
url = Data(id = data.id, channel_title = data.channel_title, channel_thumbnail = data.channel_thumbnail, category = data.category, channel_url = urlfix(data.channel_url)).toJson(),
|
"cat_id" to data.id
|
||||||
dataUrl = Data(id = data.id, channel_title = data.channel_title, channel_thumbnail = data.channel_thumbnail, category = data.category, channel_url = urlfix(data.channel_url)).toJson(),
|
|
||||||
apiName = name,
|
|
||||||
posterUrl = data.channel_thumbnail,
|
|
||||||
type = TvType.Live,
|
|
||||||
)
|
)
|
||||||
|
val decodedbody = getDecoded(Postdata)
|
||||||
|
Log.d("King", "decodedbody:$decodedbody")
|
||||||
|
var channels = parseJson<Results>(decodedbody).results?.map { element ->
|
||||||
|
Episode(
|
||||||
|
name = element.channel_title,
|
||||||
|
posterUrl = element.channel_thumbnail,
|
||||||
|
data = Data(
|
||||||
|
id = element.id,
|
||||||
|
channel_title = element.channel_title,
|
||||||
|
channel_thumbnail = element.channel_thumbnail,
|
||||||
|
category = data.category,
|
||||||
|
channel_url = element.channel_url,
|
||||||
|
).toJson(),
|
||||||
|
)
|
||||||
|
} ?: throw ErrorLoadingException("Invalid Json response")
|
||||||
|
return newTvSeriesLoadResponse(
|
||||||
|
name = data.channel_title,
|
||||||
|
url = Data(
|
||||||
|
id = data.id,
|
||||||
|
channel_title = data.channel_title,
|
||||||
|
channel_thumbnail = data.channel_thumbnail,
|
||||||
|
category = data.category,
|
||||||
|
channel_url = data.channel_url,
|
||||||
|
).toJson(),
|
||||||
|
type = TvType.TvSeries,
|
||||||
|
episodes = channels,
|
||||||
|
) {
|
||||||
|
this.posterUrl = data.channel_thumbnail
|
||||||
|
this.plot = "${data.channel_title} - ${data.category}."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
override suspend fun loadLinks(
|
override suspend fun loadLinks(
|
||||||
data: String,
|
data: String,
|
||||||
|
@ -90,13 +114,13 @@ class ElOstoraTV : MainAPI() {
|
||||||
subtitleCallback: (SubtitleFile) -> Unit,
|
subtitleCallback: (SubtitleFile) -> Unit,
|
||||||
callback: (ExtractorLink) -> Unit
|
callback: (ExtractorLink) -> Unit
|
||||||
): Boolean {
|
): Boolean {
|
||||||
//Log.d("King", "loadLinks:$data")
|
Log.d("King", "loadLinks:$data")
|
||||||
val data = parseJson<Data>(data)
|
val data = parseJson<Data>(data)
|
||||||
callback.invoke(
|
callback.invoke(
|
||||||
ExtractorLink(
|
ExtractorLink(
|
||||||
source = data.channel_title,
|
source = data.channel_title,
|
||||||
name = data.channel_title,
|
name = data.channel_title,
|
||||||
url = data.channel_url,
|
url = fixurl(data.channel_url),
|
||||||
referer = "",
|
referer = "",
|
||||||
quality = Qualities.Unknown.value,
|
quality = Qualities.Unknown.value,
|
||||||
isM3u8 = true,
|
isM3u8 = true,
|
||||||
|
@ -105,8 +129,8 @@ class ElOstoraTV : MainAPI() {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun urlfix(url: String): String {
|
private fun fixurl(url: String): String {
|
||||||
return url.replace("https://raw.githubusercontent.com/ostoratv/m3u8/master/update.m3u8?<F>302<F>","")
|
return url.substring(url.lastIndexOf("http"))
|
||||||
}
|
}
|
||||||
private fun getDecoded(payload: Map<String, String>): String {
|
private fun getDecoded(payload: Map<String, String>): String {
|
||||||
|
|
||||||
|
@ -163,9 +187,18 @@ class ElOstoraTV : MainAPI() {
|
||||||
@JsonProperty("image") val image: String,
|
@JsonProperty("image") val image: String,
|
||||||
@JsonProperty("adp") val adp: String,
|
@JsonProperty("adp") val adp: String,
|
||||||
)
|
)
|
||||||
|
data class Servers(
|
||||||
|
@JsonProperty("data") val results: ArrayList<Category>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
data class Server(
|
||||||
|
@JsonProperty("cid") val cid: String,
|
||||||
|
@JsonProperty("cat") val cat: String,
|
||||||
|
@JsonProperty("category_name") val category_name: String,
|
||||||
|
@JsonProperty("image") val image: String,
|
||||||
|
@JsonProperty("adp") val adp: String,
|
||||||
|
)
|
||||||
data class Data(
|
data class Data(
|
||||||
val id: String? = null,
|
val id: String,
|
||||||
val channel_title: String,
|
val channel_title: String,
|
||||||
val channel_thumbnail: String,
|
val channel_thumbnail: String,
|
||||||
val category: String,
|
val category: String,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue