157 lines
5.4 KiB
Kotlin
Executable File
157 lines
5.4 KiB
Kotlin
Executable File
package eu.kanade.tachiyomi.source
|
|
|
|
import android.content.Context
|
|
import com.elvishew.xlog.XLog
|
|
import eu.kanade.tachiyomi.R
|
|
import eu.kanade.tachiyomi.source.model.Page
|
|
import eu.kanade.tachiyomi.source.model.SChapter
|
|
import eu.kanade.tachiyomi.source.model.SManga
|
|
import eu.kanade.tachiyomi.data.preference.PreferencesHelper
|
|
import eu.kanade.tachiyomi.data.preference.getOrDefault
|
|
import eu.kanade.tachiyomi.source.online.HttpSource
|
|
import eu.kanade.tachiyomi.source.online.all.*
|
|
import eu.kanade.tachiyomi.source.online.english.HentaiCafe
|
|
import eu.kanade.tachiyomi.source.online.english.Tsumino
|
|
import rx.Observable
|
|
import exh.EH_SOURCE_ID
|
|
import exh.EXH_SOURCE_ID
|
|
import exh.PERV_EDEN_EN_SOURCE_ID
|
|
import exh.PERV_EDEN_IT_SOURCE_ID
|
|
import exh.metadata.metadata.PervEdenLang
|
|
import exh.source.BlacklistedSources
|
|
import exh.source.DelegatedHttpSource
|
|
import exh.source.EnhancedHttpSource
|
|
import uy.kohesive.injekt.injectLazy
|
|
import kotlin.reflect.KClass
|
|
|
|
open class SourceManager(private val context: Context) {
|
|
|
|
private val prefs: PreferencesHelper by injectLazy()
|
|
|
|
private val sourcesMap = mutableMapOf<Long, Source>()
|
|
|
|
private val stubSourcesMap = mutableMapOf<Long, StubSource>()
|
|
|
|
init {
|
|
createInternalSources().forEach { registerSource(it) }
|
|
|
|
//Recreate sources when they change
|
|
val prefEntries = arrayOf(
|
|
prefs.enableExhentai(),
|
|
prefs.imageQuality(),
|
|
prefs.useHentaiAtHome(),
|
|
prefs.useJapaneseTitle(),
|
|
prefs.ehSearchSize(),
|
|
prefs.thumbnailRows()
|
|
).map { it.asObservable() }
|
|
|
|
Observable.merge(prefEntries).skip(prefEntries.size - 1).subscribe {
|
|
createEHSources().forEach { registerSource(it) }
|
|
}
|
|
|
|
registerSource(MergedSource())
|
|
}
|
|
|
|
open fun get(sourceKey: Long): Source? {
|
|
return sourcesMap[sourceKey]
|
|
}
|
|
|
|
fun getOrStub(sourceKey: Long): Source {
|
|
return sourcesMap[sourceKey] ?: stubSourcesMap.getOrPut(sourceKey) {
|
|
StubSource(sourceKey)
|
|
}
|
|
}
|
|
|
|
fun getOnlineSources() = sourcesMap.values.filterIsInstance<HttpSource>()
|
|
|
|
fun getCatalogueSources() = sourcesMap.values.filterIsInstance<CatalogueSource>()
|
|
|
|
internal fun registerSource(source: Source, overwrite: Boolean = false) {
|
|
// EXH -->
|
|
val sourceQName = source::class.qualifiedName
|
|
val delegate = DELEGATED_SOURCES[sourceQName]
|
|
val newSource = if(source is HttpSource && delegate != null) {
|
|
XLog.d("[EXH] Delegating source: %s -> %s!", sourceQName, delegate.newSourceClass.qualifiedName)
|
|
EnhancedHttpSource(
|
|
source,
|
|
delegate.newSourceClass.constructors.find { it.parameters.size == 1 }!!.call(source)
|
|
)
|
|
} else source
|
|
|
|
if(source.id in BlacklistedSources.BLACKLISTED_EXT_SOURCES) {
|
|
XLog.d("[EXH] Removing blacklisted source: (id: %s, name: %s, lang: %s)!", source.id, source.name, (source as? CatalogueSource)?.lang)
|
|
return
|
|
}
|
|
// EXH <--
|
|
|
|
if (overwrite || !sourcesMap.containsKey(source.id)) {
|
|
sourcesMap[source.id] = newSource
|
|
}
|
|
}
|
|
|
|
internal fun unregisterSource(source: Source) {
|
|
sourcesMap.remove(source.id)
|
|
}
|
|
|
|
private fun createInternalSources(): List<Source> = listOf(
|
|
LocalSource(context)
|
|
)
|
|
|
|
private fun createEHSources(): List<Source> {
|
|
val exSrcs = mutableListOf<HttpSource>(
|
|
EHentai(EH_SOURCE_ID, false, context)
|
|
)
|
|
if(prefs.enableExhentai().getOrDefault()) {
|
|
exSrcs += EHentai(EXH_SOURCE_ID, true, context)
|
|
}
|
|
exSrcs += PervEden(PERV_EDEN_EN_SOURCE_ID, PervEdenLang.en)
|
|
exSrcs += PervEden(PERV_EDEN_IT_SOURCE_ID, PervEdenLang.it)
|
|
exSrcs += NHentai(context)
|
|
exSrcs += Tsumino(context)
|
|
exSrcs += Hitomi()
|
|
return exSrcs
|
|
}
|
|
|
|
private inner class StubSource(override val id: Long) : Source {
|
|
|
|
override val name: String
|
|
get() = id.toString()
|
|
|
|
override fun fetchMangaDetails(manga: SManga): Observable<SManga> {
|
|
return Observable.error(getSourceNotInstalledException())
|
|
}
|
|
|
|
override fun fetchChapterList(manga: SManga): Observable<List<SChapter>> {
|
|
return Observable.error(getSourceNotInstalledException())
|
|
}
|
|
|
|
override fun fetchPageList(chapter: SChapter): Observable<List<Page>> {
|
|
return Observable.error(getSourceNotInstalledException())
|
|
}
|
|
|
|
override fun toString(): String {
|
|
return name
|
|
}
|
|
|
|
private fun getSourceNotInstalledException(): Exception {
|
|
return Exception(context.getString(R.string.source_not_installed, id.toString()))
|
|
}
|
|
}
|
|
|
|
companion object {
|
|
val DELEGATED_SOURCES = listOf(
|
|
DelegatedSource(
|
|
"Hentai Cafe",
|
|
260868874183818481,
|
|
"eu.kanade.tachiyomi.extension.all.foolslide.HentaiCafe",
|
|
HentaiCafe::class
|
|
)
|
|
).associateBy { it.originalSourcePackageName }
|
|
|
|
data class DelegatedSource(val sourceName: String,
|
|
val sourceId: Long,
|
|
val originalSourcePackageName: String,
|
|
val newSourceClass: KClass<out DelegatedHttpSource>)
|
|
}
|
|
}
|