mirror of
https://github.com/gedoor/legado.git
synced 2025-08-10 00:52:30 +00:00
Merge remote-tracking branch 'origin/master'
This commit is contained in:
@@ -12,6 +12,7 @@ import splitties.init.appCtx
|
||||
|
||||
object SourceVerificationHelp {
|
||||
|
||||
private var key: String = ""
|
||||
/**
|
||||
* 获取书源验证结果
|
||||
* 图片验证码 防爬 滑动验证码 点击字符 等等
|
||||
@@ -19,7 +20,7 @@ object SourceVerificationHelp {
|
||||
fun getVerificationResult(source: BaseSource?, url: String, title: String, useBrowser: Boolean): String {
|
||||
source ?: throw NoStackTraceException("getVerificationResult parameter source cannot be null")
|
||||
return runBlocking {
|
||||
val key = "${source.getKey()}_verificationResult"
|
||||
key = "${source.getKey()}_verificationResult"
|
||||
CacheManager.delete(key)
|
||||
|
||||
if (!useBrowser) {
|
||||
@@ -52,6 +53,7 @@ object SourceVerificationHelp {
|
||||
*/
|
||||
fun startBrowser(source: BaseSource?, url: String, title: String, saveResult: Boolean? = false) {
|
||||
source ?: throw NoStackTraceException("startBrowser parameter source cannot be null")
|
||||
key = "${source.getKey()}_verificationResult"
|
||||
appCtx.startActivity<WebViewActivity> {
|
||||
putExtra("title", title)
|
||||
putExtra("url", url)
|
||||
@@ -61,7 +63,7 @@ object SourceVerificationHelp {
|
||||
}
|
||||
}
|
||||
|
||||
private fun checkActivityStatus(): Boolean {
|
||||
return true
|
||||
fun checkResult() {
|
||||
CacheManager.get(key) ?: CacheManager.putMemory(key, "")
|
||||
}
|
||||
}
|
||||
@@ -135,17 +135,19 @@ class CheckSourceService : BaseService() {
|
||||
?.filterNot {
|
||||
it.startsWith("Error: ")
|
||||
}?.joinToString("\n")
|
||||
//校验搜索书籍 用户设置校验搜索 并且 搜索链接不为空
|
||||
if (CheckSource.checkSearch && !source.searchUrl.isNullOrBlank()) {
|
||||
val searchBooks = WebBook.searchBookAwait(this, source, searchWord)
|
||||
if (searchBooks.isEmpty()) {
|
||||
source.addGroup("搜索失效")
|
||||
if (!CheckSource.checkDiscovery) {
|
||||
throw NoStackTraceException("搜索书籍为空")
|
||||
//校验搜索书籍
|
||||
if (CheckSource.checkSearch) {
|
||||
if (!source.searchUrl.isNullOrBlank()) {
|
||||
source.removeGroup("搜索链接规则为空")
|
||||
val searchBooks = WebBook.searchBookAwait(this, source, searchWord)
|
||||
if (searchBooks.isEmpty()) {
|
||||
source.addGroup("搜索失效")
|
||||
} else {
|
||||
source.removeGroup("搜索失效")
|
||||
checkBook(searchBooks.first().toBook(), source)
|
||||
}
|
||||
} else {
|
||||
source.removeGroup("搜索失效")
|
||||
checkBook(searchBooks.first().toBook(), source)
|
||||
source.addGroup("搜索链接规则为空")
|
||||
}
|
||||
}
|
||||
//校验发现书籍
|
||||
@@ -159,18 +161,12 @@ class CheckSourceService : BaseService() {
|
||||
}
|
||||
}
|
||||
if (url.isNullOrBlank()) {
|
||||
when {
|
||||
!CheckSource.checkSearch -> throw NoStackTraceException("没有发现")
|
||||
source.hasGroup("搜索失效") -> throw NoStackTraceException("搜索内容为空并且没有发现")
|
||||
}
|
||||
source.addGroup("发现规则为空")
|
||||
} else {
|
||||
source.removeGroup("发现规则为空")
|
||||
val exploreBooks = WebBook.exploreBookAwait(this, source, url)
|
||||
if (exploreBooks.isEmpty()) {
|
||||
source.addGroup("发现失效")
|
||||
when {
|
||||
!CheckSource.checkSearch -> throw NoStackTraceException("发现书籍为空")
|
||||
source.hasGroup("搜索失效") -> throw NoStackTraceException("搜索内容和发现书籍为空")
|
||||
}
|
||||
} else {
|
||||
source.removeGroup("发现失效")
|
||||
checkBook(exploreBooks.first().toBook(), source, false)
|
||||
|
||||
@@ -12,6 +12,7 @@ import io.legado.app.R
|
||||
import io.legado.app.base.BaseDialogFragment
|
||||
import io.legado.app.databinding.DialogVerificationCodeViewBinding
|
||||
import io.legado.app.help.CacheManager
|
||||
import io.legado.app.help.SourceVerificationHelp
|
||||
import io.legado.app.help.glide.ImageLoader
|
||||
import io.legado.app.help.glide.OkHttpModelLoader
|
||||
import io.legado.app.lib.theme.primaryColor
|
||||
@@ -91,9 +92,7 @@ class VerificationCodeDialog() : BaseDialogFragment(R.layout.dialog_verification
|
||||
}
|
||||
|
||||
override fun onDestroy() {
|
||||
val sourceOrigin = arguments?.getString("sourceOrigin")
|
||||
val key = "${sourceOrigin}_verificationResult"
|
||||
CacheManager.get(key) ?: CacheManager.putMemory(key, "")
|
||||
SourceVerificationHelp.checkResult()
|
||||
super.onDestroy()
|
||||
activity?.finish()
|
||||
}
|
||||
|
||||
@@ -17,6 +17,7 @@ import io.legado.app.R
|
||||
import io.legado.app.base.VMBaseActivity
|
||||
import io.legado.app.constant.AppConst
|
||||
import io.legado.app.databinding.ActivityWebViewBinding
|
||||
import io.legado.app.help.SourceVerificationHelp
|
||||
import io.legado.app.help.config.AppConfig
|
||||
import io.legado.app.help.http.CookieStore
|
||||
import io.legado.app.lib.dialogs.SelectItem
|
||||
@@ -182,6 +183,7 @@ class WebViewActivity : VMBaseActivity<ActivityWebViewBinding, WebViewModel>() {
|
||||
}
|
||||
|
||||
override fun onDestroy() {
|
||||
SourceVerificationHelp.checkResult()
|
||||
super.onDestroy()
|
||||
binding.webView.destroy()
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user