mirror of
https://github.com/recloudstream/cloudstream-extensions.git
synced 2024-08-15 03:03:54 +00:00
parent
97a17c0729
commit
b1a9851fc0
2 changed files with 48 additions and 20 deletions
|
@ -1,5 +1,5 @@
|
||||||
// use an integer for version numbers
|
// use an integer for version numbers
|
||||||
version = 8
|
version = 9
|
||||||
|
|
||||||
|
|
||||||
cloudstream {
|
cloudstream {
|
||||||
|
|
|
@ -201,7 +201,7 @@ class AllAnimeProvider : MainAPI() {
|
||||||
val link =
|
val link =
|
||||||
"""$mainUrl/allanimeapi?variables={"search":{"allowAdult":false,"allowUnknown":false,"query":"$query"},"limit":26,"page":1,"translationType":"sub","countryOrigin":"ALL"}&extensions={"persistedQuery":{"version":1,"sha256Hash":"c4305f3918591071dfecd081da12243725364f6b7dd92072df09d915e390b1b7"}}"""
|
"""$mainUrl/allanimeapi?variables={"search":{"allowAdult":false,"allowUnknown":false,"query":"$query"},"limit":26,"page":1,"translationType":"sub","countryOrigin":"ALL"}&extensions={"persistedQuery":{"version":1,"sha256Hash":"c4305f3918591071dfecd081da12243725364f6b7dd92072df09d915e390b1b7"}}"""
|
||||||
val res = app.get(link).text.takeUnless { it.contains("PERSISTED_QUERY_NOT_FOUND") }
|
val res = app.get(link).text.takeUnless { it.contains("PERSISTED_QUERY_NOT_FOUND") }
|
||||||
// Retries
|
// Retries
|
||||||
?: app.get(link).text.takeUnless { it.contains("PERSISTED_QUERY_NOT_FOUND") }
|
?: app.get(link).text.takeUnless { it.contains("PERSISTED_QUERY_NOT_FOUND") }
|
||||||
?: return emptyList()
|
?: return emptyList()
|
||||||
|
|
||||||
|
@ -360,11 +360,23 @@ class AllAnimeProvider : MainAPI() {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private data class Stream(
|
||||||
|
@JsonProperty("format") val format: String? = null,
|
||||||
|
@JsonProperty("audio_lang") val audio_lang: String? = null,
|
||||||
|
@JsonProperty("hardsub_lang") val hardsub_lang: String? = null,
|
||||||
|
@JsonProperty("url") val url: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
private data class PortData(
|
||||||
|
@JsonProperty("streams") val streams: ArrayList<Stream>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
private data class Links(
|
private data class Links(
|
||||||
@JsonProperty("link") val link: String,
|
@JsonProperty("link") val link: String,
|
||||||
@JsonProperty("hls") val hls: Boolean?,
|
@JsonProperty("hls") val hls: Boolean?,
|
||||||
@JsonProperty("resolutionStr") val resolutionStr: String,
|
@JsonProperty("resolutionStr") val resolutionStr: String,
|
||||||
@JsonProperty("src") val src: String?
|
@JsonProperty("src") val src: String?,
|
||||||
|
@JsonProperty("portData") val portData: PortData? = null,
|
||||||
)
|
)
|
||||||
|
|
||||||
private data class AllAnimeVideoApiResponse(
|
private data class AllAnimeVideoApiResponse(
|
||||||
|
@ -394,6 +406,16 @@ class AllAnimeProvider : MainAPI() {
|
||||||
val episode: Int
|
val episode: Int
|
||||||
)
|
)
|
||||||
|
|
||||||
|
private suspend fun PortData.extractAcSources(callback: (ExtractorLink) -> Unit) {
|
||||||
|
this.streams?.filter { it.format == "adaptive_hls" && it.hardsub_lang == "en-US" }?.map { source ->
|
||||||
|
M3u8Helper.generateM3u8(
|
||||||
|
"Crunchyroll",
|
||||||
|
source.url ?: return@map,
|
||||||
|
"https://static.crunchyroll.com/",
|
||||||
|
).forEach(callback)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
override suspend fun loadLinks(
|
override suspend fun loadLinks(
|
||||||
data: String,
|
data: String,
|
||||||
isCasting: Boolean,
|
isCasting: Boolean,
|
||||||
|
@ -436,27 +458,33 @@ class AllAnimeProvider : MainAPI() {
|
||||||
val links = app.get(fixedLink).parsedSafe<AllAnimeVideoApiResponse>()?.links
|
val links = app.get(fixedLink).parsedSafe<AllAnimeVideoApiResponse>()?.links
|
||||||
?: emptyList()
|
?: emptyList()
|
||||||
links.forEach { server ->
|
links.forEach { server ->
|
||||||
if (server.hls != null && server.hls) {
|
when {
|
||||||
getM3u8Qualities(
|
source.sourceName == "Ac" -> {
|
||||||
server.link,
|
server.portData?.extractAcSources(callback)
|
||||||
"$apiEndPoint/player?uri=" + (if (URI(server.link).host.isNotEmpty()) server.link else apiEndPoint + URI(
|
}
|
||||||
server.link
|
server.hls != null && server.hls -> {
|
||||||
).path),
|
getM3u8Qualities(
|
||||||
server.resolutionStr
|
|
||||||
).forEach(callback)
|
|
||||||
} else {
|
|
||||||
callback(
|
|
||||||
ExtractorLink(
|
|
||||||
"AllAnime - " + URI(server.link).host,
|
|
||||||
server.resolutionStr,
|
|
||||||
server.link,
|
server.link,
|
||||||
"$apiEndPoint/player?uri=" + (if (URI(server.link).host.isNotEmpty()) server.link else apiEndPoint + URI(
|
"$apiEndPoint/player?uri=" + (if (URI(server.link).host.isNotEmpty()) server.link else apiEndPoint + URI(
|
||||||
server.link
|
server.link
|
||||||
).path),
|
).path),
|
||||||
Qualities.P1080.value,
|
server.resolutionStr
|
||||||
false
|
).forEach(callback)
|
||||||
|
}
|
||||||
|
else -> {
|
||||||
|
callback(
|
||||||
|
ExtractorLink(
|
||||||
|
"AllAnime - " + URI(server.link).host,
|
||||||
|
server.resolutionStr,
|
||||||
|
server.link,
|
||||||
|
"$apiEndPoint/player?uri=" + (if (URI(server.link).host.isNotEmpty()) server.link else apiEndPoint + URI(
|
||||||
|
server.link
|
||||||
|
).path),
|
||||||
|
Qualities.P1080.value,
|
||||||
|
false
|
||||||
|
)
|
||||||
)
|
)
|
||||||
)
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue