xfani: format source info for aniyomi
Tmporary disable ssl check for site certificate issue.
This commit is contained in:
parent
80f3773bc1
commit
0b13e55d99
2 changed files with 42 additions and 5 deletions
|
@ -1,7 +1,7 @@
|
||||||
ext {
|
ext {
|
||||||
extName = 'Xfani'
|
extName = 'Xfani'
|
||||||
extClass = '.Xfani'
|
extClass = '.Xfani'
|
||||||
extVersionCode = 1
|
extVersionCode = 2
|
||||||
}
|
}
|
||||||
|
|
||||||
apply from: "$rootDir/common.gradle"
|
apply from: "$rootDir/common.gradle"
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
package eu.kanade.tachiyomi.animeextension.zh.xfani
|
package eu.kanade.tachiyomi.animeextension.zh.xfani
|
||||||
|
|
||||||
|
import android.annotation.SuppressLint
|
||||||
import android.app.Application
|
import android.app.Application
|
||||||
import android.content.SharedPreferences
|
import android.content.SharedPreferences
|
||||||
import androidx.preference.ListPreference
|
import androidx.preference.ListPreference
|
||||||
|
@ -20,11 +21,17 @@ import kotlinx.serialization.json.jsonObject
|
||||||
import kotlinx.serialization.json.jsonPrimitive
|
import kotlinx.serialization.json.jsonPrimitive
|
||||||
import okhttp3.HttpUrl.Companion.toHttpUrl
|
import okhttp3.HttpUrl.Companion.toHttpUrl
|
||||||
import okhttp3.MultipartBody
|
import okhttp3.MultipartBody
|
||||||
|
import okhttp3.OkHttpClient
|
||||||
import okhttp3.Request
|
import okhttp3.Request
|
||||||
import okhttp3.Response
|
import okhttp3.Response
|
||||||
import uy.kohesive.injekt.Injekt
|
import uy.kohesive.injekt.Injekt
|
||||||
import uy.kohesive.injekt.api.get
|
import uy.kohesive.injekt.api.get
|
||||||
import uy.kohesive.injekt.injectLazy
|
import uy.kohesive.injekt.injectLazy
|
||||||
|
import java.security.SecureRandom
|
||||||
|
import java.security.cert.X509Certificate
|
||||||
|
import javax.net.ssl.SSLContext
|
||||||
|
import javax.net.ssl.TrustManager
|
||||||
|
import javax.net.ssl.X509TrustManager
|
||||||
|
|
||||||
class Xfani : AnimeHttpSource(), ConfigurableAnimeSource {
|
class Xfani : AnimeHttpSource(), ConfigurableAnimeSource {
|
||||||
override val baseUrl: String
|
override val baseUrl: String
|
||||||
|
@ -41,11 +48,41 @@ class Xfani : AnimeHttpSource(), ConfigurableAnimeSource {
|
||||||
Injekt.get<Application>().getSharedPreferences("source_$id", 0x0000)
|
Injekt.get<Application>().getSharedPreferences("source_$id", 0x0000)
|
||||||
}
|
}
|
||||||
private val numberRegex = Regex("\\d+")
|
private val numberRegex = Regex("\\d+")
|
||||||
|
private fun OkHttpClient.Builder.ignoreAllSSLErrors(): OkHttpClient.Builder {
|
||||||
|
val naiveTrustManager =
|
||||||
|
@SuppressLint("CustomX509TrustManager")
|
||||||
|
object : X509TrustManager {
|
||||||
|
override fun getAcceptedIssuers(): Array<X509Certificate> = emptyArray()
|
||||||
|
override fun checkClientTrusted(certs: Array<X509Certificate>, authType: String) =
|
||||||
|
Unit
|
||||||
|
|
||||||
|
override fun checkServerTrusted(certs: Array<X509Certificate>, authType: String) =
|
||||||
|
Unit
|
||||||
|
}
|
||||||
|
|
||||||
|
val insecureSocketFactory = SSLContext.getInstance("TLSv1.2").apply {
|
||||||
|
val trustAllCerts = arrayOf<TrustManager>(naiveTrustManager)
|
||||||
|
init(null, trustAllCerts, SecureRandom())
|
||||||
|
}.socketFactory
|
||||||
|
|
||||||
|
sslSocketFactory(insecureSocketFactory, naiveTrustManager)
|
||||||
|
hostnameVerifier { _, _ -> true }
|
||||||
|
return this
|
||||||
|
}
|
||||||
|
|
||||||
|
override val client: OkHttpClient
|
||||||
|
get() = network.client.newBuilder().ignoreAllSSLErrors().build()
|
||||||
|
|
||||||
private val selectedVideoSource
|
private val selectedVideoSource
|
||||||
get() = preferences.getString(PREF_KEY_VIDEO_SOURCE, DEFAULT_VIDEO_SOURCE)!!.toInt()
|
get() = preferences.getString(PREF_KEY_VIDEO_SOURCE, DEFAULT_VIDEO_SOURCE)!!.toInt()
|
||||||
|
|
||||||
override fun animeDetailsParse(response: Response): SAnime = SAnime.create()
|
override fun animeDetailsParse(response: Response): SAnime {
|
||||||
|
val jsoup = response.asJsoup()
|
||||||
|
return SAnime.create().apply {
|
||||||
|
description = jsoup.select("#height_limit.text").text()
|
||||||
|
title = jsoup.select(".slide-info-title").text()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
override fun episodeListParse(response: Response): List<SEpisode> {
|
override fun episodeListParse(response: Response): List<SEpisode> {
|
||||||
val jsoup = response.asJsoup()
|
val jsoup = response.asJsoup()
|
||||||
|
@ -61,7 +98,7 @@ class Xfani : AnimeHttpSource(), ConfigurableAnimeSource {
|
||||||
url = it.attr("href")
|
url = it.attr("href")
|
||||||
episode_number = numberRegex.find(name)?.value?.toFloat() ?: -1F
|
episode_number = numberRegex.find(name)?.value?.toFloat() ?: -1F
|
||||||
}
|
}
|
||||||
}
|
}.sortedByDescending { it.episode_number }
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun videoListParse(response: Response): List<Video> {
|
override fun videoListParse(response: Response): List<Video> {
|
||||||
|
@ -92,9 +129,9 @@ class Xfani : AnimeHttpSource(), ConfigurableAnimeSource {
|
||||||
url = "/bangumi/${it.vodId}.html"
|
url = "/bangumi/${it.vodId}.html"
|
||||||
thumbnail_url = it.vodPicThumb.ifEmpty { it.vodPic }
|
thumbnail_url = it.vodPicThumb.ifEmpty { it.vodPic }
|
||||||
title = it.vodName
|
title = it.vodName
|
||||||
author = it.vodActor
|
author = it.vodActor.replace(",,,", "")
|
||||||
description = it.vodBlurb
|
description = it.vodBlurb
|
||||||
genre = it.vodClass
|
genre = it.vodClass.replace(",", ", ")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return AnimesPage(
|
return AnimesPage(
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue