diff --git a/src/en/gogoanime/build.gradle b/src/en/gogoanime/build.gradle
index 66483bb20..0f548c326 100644
--- a/src/en/gogoanime/build.gradle
+++ b/src/en/gogoanime/build.gradle
@@ -5,7 +5,7 @@ ext {
extName = 'Gogoanime'
pkgNameSuffix = 'en.gogoanime'
extClass = '.GogoAnime'
- extVersionCode = 4
+ extVersionCode = 5
libVersion = '11'
}
dependencies {
diff --git a/src/en/gogoanime/src/eu/kanade/tachiyomi/animeextension/en/gogoanime/GogoAnime.kt b/src/en/gogoanime/src/eu/kanade/tachiyomi/animeextension/en/gogoanime/GogoAnime.kt
index b93179061..059e7fd81 100644
--- a/src/en/gogoanime/src/eu/kanade/tachiyomi/animeextension/en/gogoanime/GogoAnime.kt
+++ b/src/en/gogoanime/src/eu/kanade/tachiyomi/animeextension/en/gogoanime/GogoAnime.kt
@@ -23,7 +23,7 @@ class GogoAnime : ParsedAnimeHttpSource() {
override val name = "Gogoanime"
- override val baseUrl = "https://www1.gogoanime.ai"
+ override val baseUrl = "https://gogoanime.pe"
override val lang = "en"
@@ -71,7 +71,7 @@ class GogoAnime : ParsedAnimeHttpSource() {
private suspend fun linkRequest(response: Response): List {
val elements = response.asJsoup()
val link = elements.select("a[data-video*=streamani.net/load.php]").attr("data-video")
- val dlResponse = client.newCall(GET("https:$link", Headers.headersOf("referer", "https://www1.gogoanime.ai")))
+ val dlResponse = client.newCall(GET("https:$link", Headers.headersOf("referer", baseUrl)))
.await()
val document = dlResponse.asJsoup()
return linksFromElement(document.select(episodeLinkSelector()).first())
@@ -107,12 +107,35 @@ class GogoAnime : ParsedAnimeHttpSource() {
}
val quality = jsonObject["label"].asString
Log.i("links:", "$link - $quality")
- links.add(Link(link, quality))
+ if (links.isEmpty() || !links.last().url.contains(link.substringAfterLast("/"))) {
+ if (link.contains("m3u8")) {
+ val individualLinks = runBlocking { getIndividualLinks(link) }
+ individualLinks.forEach { links.add(it) }
+ } else {
+ links.add(Link(link, quality))
+ }
+ }
hit = content.indexOf("playerInstance.setup(", hit + 1)
}
return links
}
+ private suspend fun getIndividualLinks(link: String): List {
+ val response = client.newCall(GET(link)).await().body!!.string()
+ Log.i("links", response)
+ val links = response.split("\n").filter { !it.startsWith("#") && it.isNotEmpty() }.toMutableList()
+ val qualities = response.split("\n").filter { it.startsWith("#EXT-X-STREAM-INF") }.toMutableList()
+ Log.i("links", links.lastIndex.toString() + qualities.lastIndex.toString())
+ val linkList = mutableListOf()
+ if (qualities.lastIndex != links.lastIndex) return emptyList()
+ for (i in 0..qualities.lastIndex) {
+ links[i] = link.substringBeforeLast("/") + "/" + links[i]
+ qualities[i] = qualities[i].substringAfter("NAME=").replace("\"", "")
+ linkList.add(Link(links[i], qualities[i]))
+ }
+ return linkList.reversed()
+ }
+
override fun searchAnimeFromElement(element: Element): SAnime {
val anime = SAnime.create()
anime.setUrlWithoutDomain(element.attr("href"))