HiperDex: Update domain (#3688)
* Update domain * Refactoring of preference URL settings * Add useLoadMoreRequest
This commit is contained in:
parent
d55da9562b
commit
14eefec146
|
@ -2,8 +2,8 @@ ext {
|
||||||
extName = 'Hiperdex'
|
extName = 'Hiperdex'
|
||||||
extClass = '.Hiperdex'
|
extClass = '.Hiperdex'
|
||||||
themePkg = 'madara'
|
themePkg = 'madara'
|
||||||
baseUrl = 'https://hiperdex.com'
|
baseUrl = 'https://hiperdex.top'
|
||||||
overrideVersionCode = 12
|
overrideVersionCode = 13
|
||||||
isNsfw = true
|
isNsfw = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
package eu.kanade.tachiyomi.extension.en.hiperdex
|
package eu.kanade.tachiyomi.extension.en.hiperdex
|
||||||
|
|
||||||
import android.app.Application
|
import android.app.Application
|
||||||
import android.content.SharedPreferences
|
|
||||||
import android.widget.Toast
|
import android.widget.Toast
|
||||||
import androidx.preference.EditTextPreference
|
import androidx.preference.EditTextPreference
|
||||||
import androidx.preference.PreferenceScreen
|
import androidx.preference.PreferenceScreen
|
||||||
|
@ -10,114 +9,69 @@ import eu.kanade.tachiyomi.lib.randomua.getPrefCustomUA
|
||||||
import eu.kanade.tachiyomi.lib.randomua.getPrefUAType
|
import eu.kanade.tachiyomi.lib.randomua.getPrefUAType
|
||||||
import eu.kanade.tachiyomi.lib.randomua.setRandomUserAgent
|
import eu.kanade.tachiyomi.lib.randomua.setRandomUserAgent
|
||||||
import eu.kanade.tachiyomi.multisrc.madara.Madara
|
import eu.kanade.tachiyomi.multisrc.madara.Madara
|
||||||
|
import eu.kanade.tachiyomi.network.interceptor.rateLimit
|
||||||
import eu.kanade.tachiyomi.source.ConfigurableSource
|
import eu.kanade.tachiyomi.source.ConfigurableSource
|
||||||
import okhttp3.HttpUrl.Companion.toHttpUrl
|
|
||||||
import okhttp3.Interceptor
|
|
||||||
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
|
||||||
|
|
||||||
class Hiperdex :
|
class Hiperdex :
|
||||||
Madara(
|
Madara(
|
||||||
"Hiperdex",
|
"Hiperdex",
|
||||||
"https://hiperdex.com",
|
"https://hiperdex.top",
|
||||||
"en",
|
"en",
|
||||||
),
|
),
|
||||||
ConfigurableSource {
|
ConfigurableSource {
|
||||||
override val useNewChapterEndpoint: Boolean = true
|
|
||||||
|
private val preferences =
|
||||||
|
Injekt.get<Application>().getSharedPreferences("source_$id", 0x0000)
|
||||||
|
|
||||||
override val baseUrl by lazy { getPrefBaseUrl() }
|
override val baseUrl by lazy { getPrefBaseUrl() }
|
||||||
|
|
||||||
private val preferences by lazy {
|
|
||||||
Injekt.get<Application>().getSharedPreferences("source_$id", 0x0000)
|
|
||||||
}
|
|
||||||
|
|
||||||
override val client = super.client.newBuilder()
|
override val client = super.client.newBuilder()
|
||||||
.addInterceptor(::domainChangeIntercept)
|
|
||||||
.setRandomUserAgent(
|
.setRandomUserAgent(
|
||||||
preferences.getPrefUAType(),
|
preferences.getPrefUAType(),
|
||||||
preferences.getPrefCustomUA(),
|
preferences.getPrefCustomUA(),
|
||||||
)
|
)
|
||||||
|
.rateLimit(3)
|
||||||
.build()
|
.build()
|
||||||
|
|
||||||
private var lastDomain = ""
|
override val useLoadMoreRequest = LoadMoreStrategy.Never
|
||||||
|
|
||||||
private fun domainChangeIntercept(chain: Interceptor.Chain): Response {
|
|
||||||
val request = chain.request()
|
|
||||||
|
|
||||||
if (request.url.host !in listOf(preferences.baseUrlHost, lastDomain)) {
|
|
||||||
return chain.proceed(request)
|
|
||||||
}
|
|
||||||
|
|
||||||
if (lastDomain.isNotEmpty()) {
|
|
||||||
val newUrl = request.url.newBuilder()
|
|
||||||
.host(preferences.baseUrlHost)
|
|
||||||
.build()
|
|
||||||
|
|
||||||
return chain.proceed(
|
|
||||||
request.newBuilder()
|
|
||||||
.url(newUrl)
|
|
||||||
.build(),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
val response = chain.proceed(request)
|
|
||||||
|
|
||||||
if (request.url.host == response.request.url.host) return response
|
|
||||||
|
|
||||||
response.close()
|
|
||||||
|
|
||||||
preferences.baseUrlHost = response.request.url.host
|
|
||||||
|
|
||||||
lastDomain = request.url.host
|
|
||||||
|
|
||||||
val newUrl = request.url.newBuilder()
|
|
||||||
.host(response.request.url.host)
|
|
||||||
.build()
|
|
||||||
|
|
||||||
return chain.proceed(
|
|
||||||
request.newBuilder()
|
|
||||||
.url(newUrl)
|
|
||||||
.build(),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
companion object {
|
|
||||||
private const val defaultBaseUrlHost = "hiperdex.com"
|
|
||||||
private const val RESTART_TACHIYOMI = "Restart Tachiyomi to apply new setting."
|
|
||||||
private const val BASE_URL_PREF_TITLE = "Override BaseUrl"
|
|
||||||
private const val BASE_URL_PREF = "overrideBaseUrl_v2"
|
|
||||||
private const val BASE_URL_PREF_SUMMARY = "Enter a complete url starting with http"
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun setupPreferenceScreen(screen: PreferenceScreen) {
|
override fun setupPreferenceScreen(screen: PreferenceScreen) {
|
||||||
val baseUrlPref = EditTextPreference(screen.context).apply {
|
EditTextPreference(screen.context).apply {
|
||||||
key = BASE_URL_PREF
|
key = BASE_URL_PREF
|
||||||
title = BASE_URL_PREF_TITLE
|
title = BASE_URL_PREF_TITLE
|
||||||
summary = BASE_URL_PREF_SUMMARY
|
summary = BASE_URL_PREF_SUMMARY
|
||||||
this.setDefaultValue(defaultBaseUrlHost)
|
|
||||||
dialogTitle = BASE_URL_PREF_TITLE
|
dialogTitle = BASE_URL_PREF_TITLE
|
||||||
|
dialogMessage = "Default URL:\n\t${super.baseUrl}"
|
||||||
|
setDefaultValue(super.baseUrl)
|
||||||
|
setOnPreferenceChangeListener { _, newValue ->
|
||||||
|
Toast.makeText(screen.context, RESTART_APP_MESSAGE, Toast.LENGTH_LONG).show()
|
||||||
|
true
|
||||||
|
}
|
||||||
|
}.also { screen.addPreference(it) }
|
||||||
|
|
||||||
setOnPreferenceChangeListener { _, newVal ->
|
|
||||||
val url = newVal as String
|
|
||||||
runCatching {
|
|
||||||
val host = url.toHttpUrl().host
|
|
||||||
|
|
||||||
Toast.makeText(screen.context, RESTART_TACHIYOMI, Toast.LENGTH_LONG).show()
|
|
||||||
preferences.edit().putString(BASE_URL_PREF, host).commit()
|
|
||||||
}
|
|
||||||
false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
screen.addPreference(baseUrlPref)
|
|
||||||
addRandomUAPreferenceToScreen(screen)
|
addRandomUAPreferenceToScreen(screen)
|
||||||
}
|
}
|
||||||
|
|
||||||
private var SharedPreferences.baseUrlHost
|
private fun getPrefBaseUrl(): String = preferences.getString(BASE_URL_PREF, super.baseUrl)!!
|
||||||
get() = getString(BASE_URL_PREF, defaultBaseUrlHost) ?: defaultBaseUrlHost
|
|
||||||
set(newHost) {
|
init {
|
||||||
edit().putString(BASE_URL_PREF, newHost).commit()
|
preferences.getString(DEFAULT_BASE_URL_PREF, null).let { defaultBaseUrl ->
|
||||||
|
if (defaultBaseUrl != super.baseUrl) {
|
||||||
|
preferences.edit()
|
||||||
|
.putString(BASE_URL_PREF, super.baseUrl)
|
||||||
|
.putString(DEFAULT_BASE_URL_PREF, super.baseUrl)
|
||||||
|
.apply()
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun getPrefBaseUrl(): String = preferences.baseUrlHost.let { "https://$it" }
|
companion object {
|
||||||
|
private const val BASE_URL_PREF = "overrideBaseUrl"
|
||||||
|
private const val BASE_URL_PREF_TITLE = "Edit source URL (requires restart)"
|
||||||
|
private const val BASE_URL_PREF_SUMMARY = "The default settings will be applied when the extension is next updated"
|
||||||
|
private const val DEFAULT_BASE_URL_PREF = "defaultBaseUrl"
|
||||||
|
private const val RESTART_APP_MESSAGE = "Restart app to apply new setting."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue