Skip to content

Commit

Permalink
fix(es/hackstore): Video empty (aniyomiorg#2898)
Browse files Browse the repository at this point in the history
Co-authored-by: Secozzi <[email protected]>
  • Loading branch information
Dark25 and Secozzi authored Feb 9, 2024
1 parent c9629f7 commit be0a2bb
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 14 deletions.
2 changes: 1 addition & 1 deletion src/es/hackstore/build.gradle
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
ext {
extName = 'Hackstore'
extClass = '.Hackstore'
extVersionCode = 3
extVersionCode = 4
}

apply from: "$rootDir/common.gradle"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import eu.kanade.tachiyomi.network.GET
import eu.kanade.tachiyomi.util.asJsoup
import okhttp3.Request
import okhttp3.Response
import org.jsoup.Jsoup
import org.jsoup.nodes.Document
import org.jsoup.nodes.Element
import uy.kohesive.injekt.Injekt
Expand Down Expand Up @@ -195,22 +196,30 @@ class Hackstore : ConfigurableAnimeSource, ParsedAnimeHttpSource() {
override fun episodeFromElement(element: Element): SEpisode { throw UnsupportedOperationException() }

// ============================ Video Links =============================
private fun extractUrlFromDonFunction(fullUrl: String): String {
val response = client.newCall(GET(fullUrl, headers)).execute()
val body = response.body.string()
val document = Jsoup.parse(body)
val scriptElement = document.selectFirst("script:containsData(function don())")
val urlPattern = Regex("window\\.location\\.href\\s*=\\s*'([^']+)'")
val matchResult = scriptElement?.data()?.let { urlPattern.find(it) }
return matchResult?.groupValues?.get(1) ?: "url not found"
}

override fun videoListParse(response: Response): List<Video> {
val document = response.asJsoup()
val videoList = mutableListOf<Video>()

val table = document.select("table.episodes")
val rows = table.select("tbody tr.tabletr")

rows.forEach { row ->
val serverElement = row.select("td:eq(0)")
val linkElement = row.select("td:eq(1) a")

val server = serverElement.text()
val url = linkElement.attr("href")
val tabs = document.select("ul.TbVideoNv li.pres")

val isLatino = server.contains("latino")
val isSub = server.contains("subtitulado")
tabs.forEach { tab ->
val server = tab.select("a.playr").text()
val deco = tab.select("a.playr").attr("data-href")
val langs = tab.select("a.playr").attr("data-lang")
val fullUrl = baseUrl + deco
val url = extractUrlFromDonFunction(fullUrl)
val isLatino = langs.contains("latino")
val isSub = langs.contains("subtitulado") || langs.contains("sub") || langs.contains("japonés")

when {
server.contains("streamtape") -> {
Expand Down Expand Up @@ -240,7 +249,7 @@ class Hackstore : ConfigurableAnimeSource, ParsedAnimeHttpSource() {

return videoList
}
override fun videoListSelector(): String = "#onpn > table > tbody > tr > td.link-td > a"
override fun videoListSelector(): String = "ul.TbVideoNv li.pres a.playr"

override fun videoFromElement(element: Element): Video { throw UnsupportedOperationException() }

Expand Down Expand Up @@ -273,7 +282,7 @@ class Hackstore : ConfigurableAnimeSource, ParsedAnimeHttpSource() {

private const val PREF_SERVER_KEY = "preferred_server"
private const val PREF_SERVER_DEFAULT = "DoodStream"
private val SERVER_LIST = arrayOf("DoodStream", "StreamTape", "VOE", "Filemoon", "StreamWish")
private val SERVER_LIST = arrayOf("DoodStream", "StreamTape", "Voe", "Filemoon", "StreamWish")
}

override fun setupPreferenceScreen(screen: PreferenceScreen) {
Expand Down

0 comments on commit be0a2bb

Please sign in to comment.