Try fix crunchy
This commit is contained in:
parent
c874e063ce
commit
ec1ed7957a
|
@ -1,5 +1,5 @@
|
|||
// use an integer for version numbers
|
||||
version = 1
|
||||
version = 2
|
||||
|
||||
|
||||
cloudstream {
|
||||
|
@ -19,5 +19,4 @@ cloudstream {
|
|||
status = 1 // will be 3 if unspecified
|
||||
tvTypes = listOf("AnimeMovie", "Anime", "OVA")
|
||||
iconUrl = "https://www.google.com/s2/favicons?domain=crunchyroll.com&sz=%size%"
|
||||
|
||||
}
|
|
@ -1,110 +1,50 @@
|
|||
package com.lagradost
|
||||
////Credits https://github.com/ArjixWasTaken/CloudStream-3/blob/master/app/src/main/java/com/ArjixWasTaken/cloudstream3/utils/HttpSession.kt
|
||||
//import com.lagradost.KrunchyProvider
|
||||
//import khttp.responses.Response
|
||||
//import khttp.structures.authorization.Authorization
|
||||
//import khttp.structures.cookie.Cookie
|
||||
//import khttp.structures.cookie.CookieJar
|
||||
//import khttp.structures.files.FileLike
|
||||
//import okhttp3.CookieJar
|
||||
//import java.util.ArrayList
|
||||
//
|
||||
///**
|
||||
// * An HTTP session manager.
|
||||
// *
|
||||
// * This class simply keeps cookies across requests.
|
||||
// *
|
||||
// * @property sessionCookies A cookie jar.
|
||||
// */
|
||||
//class HttpSession {
|
||||
// companion object {
|
||||
// const val DEFAULT_TIMEOUT = 30.0
|
||||
//
|
||||
// fun mergeCookies(cookie1: CookieJar, cookie2: Map<String, String>?): Map<String, String> {
|
||||
// if (!cookie2.isNullOrEmpty()) {
|
||||
// cookie1.putAll(cookie2)
|
||||
// }
|
||||
// return a
|
||||
// }
|
||||
// }
|
||||
//
|
||||
// val sessionCookies = CookieJar()
|
||||
//
|
||||
// fun get(
|
||||
// url: String,
|
||||
// headers: Map<String, String?> = mapOf(),
|
||||
// params: Map<String, String> = mapOf(),
|
||||
// data: Any? = null,
|
||||
// json: Any? = null,
|
||||
// auth: Authorization? = null,
|
||||
// cookies: Map<String, String>? = null,
|
||||
// timeout: Double = DEFAULT_TIMEOUT,
|
||||
// allowRedirects: Boolean? = null,
|
||||
// stream: Boolean = false,
|
||||
// files: List<FileLike> = listOf(),
|
||||
// ): Response {
|
||||
// val res =
|
||||
// khttp.get(
|
||||
// url,
|
||||
// headers,
|
||||
// params,
|
||||
// data,
|
||||
// json,
|
||||
// auth,
|
||||
// mergeCookies(sessionCookies, cookies),
|
||||
// timeout,
|
||||
// allowRedirects,
|
||||
// stream,
|
||||
// files
|
||||
// )
|
||||
// sessionCookies.putAll(res.cookies)
|
||||
// sessionCookies.putAll(
|
||||
// CookieJar(
|
||||
// *res.headers
|
||||
// .filter { it.key.toLowerCase() == "set-cookie" }
|
||||
// .map { Cookie(it.value) }
|
||||
// .toTypedArray()
|
||||
// )
|
||||
// )
|
||||
// return res
|
||||
// }
|
||||
//
|
||||
// fun post(
|
||||
// url: String,
|
||||
// headers: Map<String, String?> = mapOf(),
|
||||
// params: Map<String, String> = mapOf(),
|
||||
// data: Any? = null,
|
||||
// json: Any? = null,
|
||||
// auth: Authorization? = null,
|
||||
// cookies: Map<String, String>? = null,
|
||||
// timeout: Double = DEFAULT_TIMEOUT,
|
||||
// allowRedirects: Boolean? = null,
|
||||
// stream: Boolean = false,
|
||||
// files: List<FileLike> = listOf()
|
||||
// ): Response {
|
||||
// val res =
|
||||
// khttp.post(
|
||||
// url,
|
||||
// headers,
|
||||
// params,
|
||||
// data,
|
||||
// json,
|
||||
// auth,
|
||||
// mergeCookies(sessionCookies, cookies),
|
||||
// timeout,
|
||||
// allowRedirects,
|
||||
// stream,
|
||||
// files
|
||||
// )
|
||||
// sessionCookies.putAll(res.cookies)
|
||||
// sessionCookies.putAll(
|
||||
// CookieJar(
|
||||
// *res.headers
|
||||
// .filter { it.key.toLowerCase() == "set-cookie" }
|
||||
// .map { Cookie(it.value) }
|
||||
// .toTypedArray()
|
||||
// )
|
||||
// )
|
||||
// return res
|
||||
// }
|
||||
//}
|
||||
//Credits https://github.com/ArjixWasTaken/CloudStream-3/blob/master/app/src/main/java/com/ArjixWasTaken/cloudstream3/utils/HttpSession.kt
|
||||
import com.lagradost.cloudstream3.app
|
||||
import com.lagradost.nicehttp.NiceResponse
|
||||
|
||||
/**
|
||||
* An HTTP session manager.
|
||||
*
|
||||
* This class simply keeps cookies across requests.
|
||||
*
|
||||
* @property sessionCookies A cookie jar.
|
||||
*
|
||||
* TODO: be replaced with built in Session once that works as it should.
|
||||
*/
|
||||
class HttpSession {
|
||||
private val sessionCookies: MutableMap<String, String> = mutableMapOf()
|
||||
|
||||
suspend fun get(
|
||||
url: String,
|
||||
headers: Map<String, String> = mapOf(),
|
||||
cookies: Map<String, String> = mapOf(),
|
||||
): NiceResponse {
|
||||
sessionCookies.putAll(cookies)
|
||||
val res =
|
||||
app.get(
|
||||
url,
|
||||
headers,
|
||||
cookies = sessionCookies,
|
||||
)
|
||||
sessionCookies.putAll(res.headers.filter { it.first.lowercase() == "set-cookie" })
|
||||
return res
|
||||
}
|
||||
|
||||
suspend fun post(
|
||||
url: String,
|
||||
headers: Map<String, String> = mapOf(),
|
||||
cookies: Map<String, String> = mapOf(),
|
||||
): NiceResponse {
|
||||
sessionCookies.putAll(cookies)
|
||||
val res =
|
||||
app.post(
|
||||
url,
|
||||
headers,
|
||||
cookies = sessionCookies,
|
||||
)
|
||||
|
||||
sessionCookies.putAll(res.headers.filter { it.first.lowercase() == "set-cookie" })
|
||||
return res
|
||||
}
|
||||
}
|
|
@ -1,14 +1,13 @@
|
|||
package com.lagradost
|
||||
|
||||
import com.fasterxml.jackson.annotation.JsonProperty
|
||||
import com.fasterxml.jackson.databind.DeserializationFeature
|
||||
import com.fasterxml.jackson.databind.json.JsonMapper
|
||||
import com.fasterxml.jackson.module.kotlin.KotlinModule
|
||||
import com.lagradost.cloudstream3.*
|
||||
import com.lagradost.cloudstream3.utils.*
|
||||
import com.lagradost.cloudstream3.utils.AppUtils.parseJson
|
||||
import com.lagradost.cloudstream3.utils.ExtractorLink
|
||||
import com.lagradost.cloudstream3.utils.M3u8Helper
|
||||
import com.lagradost.cloudstream3.utils.Qualities
|
||||
import com.lagradost.cloudstream3.utils.getQualityFromName
|
||||
import com.lagradost.nicehttp.NiceResponse
|
||||
import com.lagradost.nicehttp.Session
|
||||
import org.jsoup.Jsoup
|
||||
import java.net.URI
|
||||
import java.util.*
|
||||
|
@ -26,7 +25,7 @@ class KrunchyGeoBypasser {
|
|||
"User-Agent" to "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.159 Safari/537.36".toAscii()
|
||||
)
|
||||
var sessionId: String? = null
|
||||
val session = Session(app.baseClient)
|
||||
val session = HttpSession()
|
||||
}
|
||||
|
||||
data class KrunchySession(
|
||||
|
@ -68,8 +67,6 @@ class KrunchyProvider : MainAPI() {
|
|||
companion object {
|
||||
val crUnblock = KrunchyGeoBypasser()
|
||||
val episodeNumRegex = Regex("""Episode (\d+)""")
|
||||
val mapper: JsonMapper = JsonMapper.builder().addModule(KotlinModule())
|
||||
.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false).build()
|
||||
}
|
||||
|
||||
override var mainUrl = "http://www.crunchyroll.com"
|
||||
|
|
Loading…
Reference in New Issue