fix(pt/pifansubs): Fix latest updates & video extractors (#2733)

This commit is contained in:
Claudemirovsky 2024-01-13 06:43:46 -03:00 committed by GitHub
parent daa397256c
commit afb33b7e01
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 55 additions and 70 deletions

View File

@ -1,4 +1,4 @@
dependencies {
implementation(project(':lib-gdriveplayer-extractor'))
implementation(project(':lib-streamhidevid-extractor'))
}

View File

@ -1,10 +1,8 @@
package eu.kanade.tachiyomi.animeextension.pt.pifansubs
import android.net.Uri
import eu.kanade.tachiyomi.animeextension.pt.pifansubs.extractors.AdoroDoramasExtractor
import eu.kanade.tachiyomi.animeextension.pt.pifansubs.extractors.JMVStreamExtractor
import eu.kanade.tachiyomi.animeextension.pt.pifansubs.extractors.BlembedExtractor
import eu.kanade.tachiyomi.animesource.model.Video
import eu.kanade.tachiyomi.lib.gdriveplayerextractor.GdrivePlayerExtractor
import eu.kanade.tachiyomi.lib.streamhidevidextractor.StreamHideVidExtractor
import eu.kanade.tachiyomi.multisrc.dooplay.DooPlay
import eu.kanade.tachiyomi.network.GET
import eu.kanade.tachiyomi.util.asJsoup
@ -43,18 +41,13 @@ class PiFansubs : DooPlay(
}
}
private val streamHideVidExtractor by lazy { StreamHideVidExtractor(client) }
private val blembedExtractor by lazy { BlembedExtractor(client, headers) }
private fun getPlayerVideos(url: String): List<Video> {
return when {
"player.jmvstream" in url ->
JMVStreamExtractor(client).videosFromUrl(url)
"gdriveplayer." in url ->
GdrivePlayerExtractor(client).videosFromUrl(url, "GdrivePlayer", headers)
"https://adorodoramas.com" in url ->
AdoroDoramasExtractor(client).videosFromUrl(url)
"/jwplayer/?source" in url -> {
val videoUrl = Uri.parse(url).getQueryParameter("source")!!
listOf(Video(videoUrl, "JWPlayer", videoUrl, headers))
}
"https://vidhide" in url -> streamHideVidExtractor.videosFromUrl(url)
"https://blembed" in url -> blembedExtractor.videosFromUrl(url)
else -> emptyList<Video>()
}
}
@ -67,5 +60,5 @@ class PiFansubs : DooPlay(
}
// =============================== Latest ===============================
override fun latestUpdatesRequest(page: Int) = GET("$baseUrl/episodes/page/$page", headers)
override fun latestUpdatesRequest(page: Int) = GET("$baseUrl/episodios/page/$page", headers)
}

View File

@ -1,22 +0,0 @@
package eu.kanade.tachiyomi.animeextension.pt.pifansubs.extractors
import eu.kanade.tachiyomi.animesource.model.Video
import eu.kanade.tachiyomi.network.GET
import okhttp3.OkHttpClient
class AdoroDoramasExtractor(private val client: OkHttpClient) {
private val playerName = "AdoroDoramas"
fun videosFromUrl(url: String): List<Video> {
val body = client.newCall(GET(url)).execute()
.use { it.body.string() }
.substringAfter("sources: [")
.substringBefore("],")
return body.split("}").filter { it.isNotBlank() }.map {
val quality = it.substringAfter("size: ").substringBefore(" ") + "p"
val videoUrl = it.substringAfter("src: '").substringBefore("'")
Video(url, "$playerName - $quality", videoUrl)
}
}
}

View File

@ -0,0 +1,45 @@
package eu.kanade.tachiyomi.animeextension.pt.pifansubs.extractors
import eu.kanade.tachiyomi.animesource.model.Video
import eu.kanade.tachiyomi.network.GET
import eu.kanade.tachiyomi.util.asJsoup
import kotlinx.serialization.Serializable
import kotlinx.serialization.json.Json
import kotlinx.serialization.json.decodeFromStream
import okhttp3.Headers
import okhttp3.OkHttpClient
import okhttp3.Response
import uy.kohesive.injekt.injectLazy
class BlembedExtractor(private val client: OkHttpClient, private val headers: Headers) {
private val json: Json by injectLazy()
fun videosFromUrl(url: String): List<Video> {
val doc = client.newCall(GET(url, headers)).execute()
.use { it.asJsoup() }
val script = doc.selectFirst("script:containsData(player =)")
?.data()
?: return emptyList()
val token = script.substringAfter("kaken = \"").substringBefore('"')
val timestamp = System.currentTimeMillis().toString()
val reqUrl = "https://blembed.com/api/?$token&_=$timestamp"
val reqHeaders = headers.newBuilder().add("X-Requested-With", "XMLHttpRequest").build()
val res = client.newCall(GET(reqUrl, reqHeaders)).execute()
.parseAs<ResponseData>()
return res.sources.map { Video(it.file, "Blembed - ${it.label}", it.file, headers) }
}
private inline fun <reified T> Response.parseAs(): T = use {
json.decodeFromStream(it.body.byteStream())
}
}
@Serializable
data class ResponseData(val sources: List<VideoDto>) {
@Serializable
data class VideoDto(val file: String, val label: String)
}

View File

@ -1,31 +0,0 @@
package eu.kanade.tachiyomi.animeextension.pt.pifansubs.extractors
import eu.kanade.tachiyomi.animesource.model.Video
import eu.kanade.tachiyomi.network.GET
import okhttp3.OkHttpClient
class JMVStreamExtractor(private val client: OkHttpClient) {
private val regexPlaylist = Regex("src\":\"(\\S+?)\"")
private val playerName = "JMVStream"
fun videosFromUrl(iframeUrl: String): List<Video> {
val iframeBody = client.newCall(GET(iframeUrl)).execute()
.use { it.body.string() }
val playlistUrl = regexPlaylist.find(iframeBody)!!.groupValues.get(1)
val playlistData = client.newCall(GET(playlistUrl)).execute()
.use { it.body.string() }
val separator = "#EXT-X-STREAM-INF:"
return playlistData.substringAfter(separator).split(separator).map {
val quality = it.substringAfter("RESOLUTION=")
.substringAfter("x")
.substringBefore("\n")
.substringBefore(",") + "p"
val path = it.substringAfter("\n").substringBefore("\n")
val url = playlistUrl.replace("playlist.m3u8", path)
Video(url, "$playerName - $quality", url)
}
}
}

View File

@ -23,7 +23,7 @@ class DooPlayGenerator : ThemeSourceGenerator {
SingleLang("JetAnime", "https://ssl.jetanimes.com", "fr", isNsfw = false, overrideVersionCode = 2),
SingleLang("Kinoking", "https://kinoking.cc", "de", isNsfw = false, overrideVersionCode = 19),
SingleLang("Multimovies", "https://multimovies.live", "en", isNsfw = false, overrideVersionCode = 13),
SingleLang("Pi Fansubs", "https://pifansubs.org", "pt-BR", isNsfw = true, overrideVersionCode = 17),
SingleLang("Pi Fansubs", "https://pifansubs.club", "pt-BR", isNsfw = true, overrideVersionCode = 18),
SingleLang("Pobreflix", "https://pobreflix.biz", "pt-BR", isNsfw = true, overrideVersionCode = 3),
SingleLang("UniqueStream", "https://uniquestream.net", "en", isNsfw = false, overrideVersionCode = 2),
SingleLang("VoirCartoon", "https://voircartoon.com", "fr", isNsfw = true),