diff --git a/src/es/hackstore/build.gradle b/src/es/hackstore/build.gradle index 7703dd23ed..8b114c6d51 100644 --- a/src/es/hackstore/build.gradle +++ b/src/es/hackstore/build.gradle @@ -1,7 +1,7 @@ ext { extName = 'Hackstore' extClass = '.Hackstore' - extVersionCode = 3 + extVersionCode = 4 } apply from: "$rootDir/common.gradle" diff --git a/src/es/hackstore/src/eu/kanade/tachiyomi/animeextension/es/hackstore/Hackstore.kt b/src/es/hackstore/src/eu/kanade/tachiyomi/animeextension/es/hackstore/Hackstore.kt index 54ac53b9a7..c63d9c600f 100644 --- a/src/es/hackstore/src/eu/kanade/tachiyomi/animeextension/es/hackstore/Hackstore.kt +++ b/src/es/hackstore/src/eu/kanade/tachiyomi/animeextension/es/hackstore/Hackstore.kt @@ -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 @@ -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