This commit is contained in:
hexated 2023-05-05 17:25:35 +07:00
parent 52f7ea9d59
commit 696550cdf9
2 changed files with 43 additions and 26 deletions

View file

@ -48,10 +48,7 @@ jobs:
SORATED: ${{ secrets.SORATED }} SORATED: ${{ secrets.SORATED }}
run: | run: |
cd $GITHUB_WORKSPACE/src cd $GITHUB_WORKSPACE/src
echo SORA_API=$SORA_API > local.properties echo $'SORA_API=$SORA_API\nSORAHE=$SORAHE\nSORAXA=$SORAXA\nSORATED=$SORATED' > local.properties
echo SORAHE=$SORAHE > local.properties
echo SORAXA=$SORAXA > local.properties
echo SORATED=$SORATED > local.properties
- name: Build Plugins - name: Build Plugins
run: | run: |

View file

@ -649,7 +649,7 @@ object SoraExtractor : SoraStream() {
) )
} }
if(season == null) return if (season == null) return
json.definitionList?.map { video -> json.definitionList?.map { video ->
val media = app.get( val media = app.get(
"${BuildConfig.SORA_API}/movieDrama/getPlayInfo?category=${type}&contentId=${id}&episodeId=${json.id}&definition=${video.code}", "${BuildConfig.SORA_API}/movieDrama/getPlayInfo?category=${type}&contentId=${id}&episodeId=${json.id}&definition=${video.code}",
@ -660,8 +660,10 @@ object SoraExtractor : SoraStream() {
ExtractorLink( ExtractorLink(
this.name, this.name,
this.name, this.name,
if(media?.mediaUrl?.startsWith(BuildConfig.SORAXA) == true) upgradeSoraUrl(media.mediaUrl) else media?.mediaUrl ?: return@map null, if (media?.mediaUrl?.startsWith(BuildConfig.SORAXA) == true) upgradeSoraUrl(
if(media.mediaUrl.startsWith(BuildConfig.SORAHE)) base64DecodeAPI("Lw==b20=LmM=b2s=a2w=bG8=Ly8=czo=dHA=aHQ=") else "", media.mediaUrl
) else media?.mediaUrl ?: return@map null,
if (media.mediaUrl.startsWith(BuildConfig.SORAHE)) base64DecodeAPI("Lw==b20=LmM=b2s=a2w=bG8=Ly8=czo=dHA=aHQ=") else "",
getSoraQuality(media.currentDefinition ?: ""), getSoraQuality(media.currentDefinition ?: ""),
true, true,
) )
@ -874,7 +876,7 @@ object SoraExtractor : SoraStream() {
callback: (ExtractorLink) -> Unit callback: (ExtractorLink) -> Unit
) { ) {
val (aniId, malId) = app.get( val (aniId, malId) = app.get(
if(season == null) "$tmdb2anilist/movie/?id=$id" else "$tmdb2anilist/tv/?id=$id&s=$season" if (season == null) "$tmdb2anilist/movie/?id=$id" else "$tmdb2anilist/tv/?id=$id&s=$season"
).parsedSafe<Tmdb2Anilist>().let { it?.anilist_id to it?.mal_id } ).parsedSafe<Tmdb2Anilist>().let { it?.anilist_id to it?.mal_id }
argamap( argamap(
@ -900,8 +902,14 @@ object SoraExtractor : SoraStream() {
episode: Int? = null, episode: Int? = null,
callback: (ExtractorLink) -> Unit callback: (ExtractorLink) -> Unit
) { ) {
val aniDetail = app.get("$consumetAnilistAPI/info/$aniId").parsedSafe<ConsumetDetails>() ?: return val aniDetail =
val edges = app.get(allanimeQueries("""{"search":{"query":"$title","allowAdult":false,"allowUnknown":false},"limit":26,"page":1,"translationType":"sub","countryOrigin":"ALL"}""", allanimeSearchQuery)) app.get("$consumetAnilistAPI/info/$aniId").parsedSafe<ConsumetDetails>() ?: return
val edges = app.get(
allanimeQueries(
"""{"search":{"query":"$title","allowAdult":false,"allowUnknown":false},"limit":26,"page":1,"translationType":"sub","countryOrigin":"ALL"}""",
allanimeSearchQuery
)
)
.parsedSafe<AllanimeResponses>()?.data?.shows?.edges .parsedSafe<AllanimeResponses>()?.data?.shows?.edges
val id = edges?.let { edge -> val id = edges?.let { edge ->
if (edges.size == 1) { if (edges.size == 1) {
@ -924,7 +932,10 @@ object SoraExtractor : SoraStream() {
) || it.name.equals( ) || it.name.equals(
jpTitle, jpTitle,
true true
) || it.englishName.equals(aniDetail.title?.english, true) || it.englishName.equals(title, true) ) || it.englishName.equals(
aniDetail.title?.english,
true
) || it.englishName.equals(title, true)
} }
} }
}?._id ?: return }?._id ?: return
@ -933,7 +944,12 @@ object SoraExtractor : SoraStream() {
"sub", "sub",
"dub" "dub"
).apmap { tl -> ).apmap { tl ->
val server = app.get(allanimeQueries("""{"showId":"$id","translationType":"$tl","episodeString":"$episode"}""", allanimeServerQuery)) val server = app.get(
allanimeQueries(
"""{"showId":"$id","translationType":"$tl","episodeString":"$episode"}""",
allanimeServerQuery
)
)
.parsedSafe<AllanimeResponses>()?.data?.episode?.sourceUrls?.find { it.sourceName == "Ac" } .parsedSafe<AllanimeResponses>()?.data?.episode?.sourceUrls?.find { it.sourceName == "Ac" }
val serverUrl = fixUrl( val serverUrl = fixUrl(
server?.sourceUrl?.replace("/clock", "/clock.json") ?: return@apmap, server?.sourceUrl?.replace("/clock", "/clock.json") ?: return@apmap,
@ -2676,19 +2692,23 @@ object SoraExtractor : SoraStream() {
) )
} }
val subtitles = json?.subtitles as ArrayList<HashMap<String, String>> argamap(
{
subtitles.map { sub -> invokeMonster(
subtitleCallback.invoke( res.url.substringAfterLast("/"), episodeId, season, callback
SubtitleFile(
sub["language"] ?: return@map, fixUrl(sub["url"] ?: return@map, watchOnlineAPI)
) )
) },
} {
val subtitles = json?.subtitles as ArrayList<HashMap<String, String>>
invokeMonster( subtitles.map { sub ->
res.url.substringAfterLast("/"), episodeId, season, callback subtitleCallback.invoke(
) SubtitleFile(
sub["language"] ?: return@map,
fixUrl(sub["url"] ?: return@map, watchOnlineAPI)
)
)
}
})
} }
@ -2698,7 +2718,7 @@ object SoraExtractor : SoraStream() {
season: Int? = null, season: Int? = null,
callback: (ExtractorLink) -> Unit, callback: (ExtractorLink) -> Unit,
) { ) {
val monsterMainUrl = "https://ditairridgeleg.monster" val monsterMainUrl = "https://freedoze.monster"
val playSlug = if (season == null) { val playSlug = if (season == null) {
"movies/play/$urlSlug" "movies/play/$urlSlug"
} else { } else {
@ -2842,7 +2862,7 @@ object SoraExtractor : SoraStream() {
val res = app.get(url) val res = app.get(url)
val media = if(season == null) { val media = if (season == null) {
res.document.select("table.rwd-table tr").map { res.document.select("table.rwd-table tr").map {
Triple( Triple(
it.select("td[data-th=File Name]").text(), it.select("td[data-th=File Name]").text(),