mirror of
https://github.com/gedoor/legado.git
synced 2025-08-10 00:52:30 +00:00
fix:书源校验可识别js错误,其余原因视为网站失效
This commit is contained in:
@@ -24,6 +24,6 @@
|
||||
* 校验所选
|
||||
* 校验书源可批量校验书源,由于网络等原因结果仅限参考
|
||||
* "校验成功"是指所选的校验项目全部通过
|
||||
* 可正常识别搜索为空、发现为空、搜索(发现)目录为空、搜索(发现)正文为空、校验超时导致的失效,其余原因(网站异常、源码变动)导致的视为规则失效
|
||||
* 可正常识别搜索为空、发现为空、搜索(发现)目录为空、搜索(发现)正文为空、校验超时、js执行错误导致的失效,其余的原因视为网站失效
|
||||
* 校验搜索优先使用书源填写的校验关键词,不存在时使用用户输入的关键词
|
||||
* 校验结束后会自动筛选"失效"书源
|
||||
@@ -24,6 +24,8 @@ import kotlinx.coroutines.asCoroutineDispatcher
|
||||
import kotlinx.coroutines.launch
|
||||
import java.util.concurrent.Executors
|
||||
import kotlin.math.min
|
||||
import org.mozilla.javascript.WrappedException
|
||||
import javax.script.ScriptException
|
||||
|
||||
/**
|
||||
* 校验书源
|
||||
@@ -176,18 +178,15 @@ class CheckSourceService : BaseService() {
|
||||
}.timeout(CheckSource.timeout)
|
||||
.onError(searchCoroutine) {
|
||||
when(it) {
|
||||
//校验超时不能正常实现 不能识别
|
||||
is TimeoutCancellationException -> source.addGroup("校验超时")
|
||||
//NoStackTraceException 已经添加了分组,其余的视为规则失效
|
||||
!is NoStackTraceException -> source.addGroup("规则失效")
|
||||
is ScriptException, is WrappedException -> source.addGroup("js失效")
|
||||
!is NoStackTraceException -> source.addGroup("网站失效")
|
||||
}
|
||||
source.bookSourceComment =
|
||||
"Error: ${it.localizedMessage}" + if (source.bookSourceComment.isNullOrBlank())
|
||||
"" else "\n\n${source.bookSourceComment}"
|
||||
Debug.updateFinalMessage(source.bookSourceUrl, "校验失败:${it.localizedMessage}")
|
||||
}.onSuccess(searchCoroutine) {
|
||||
source.removeGroup("失效")
|
||||
source.removeGroup("规则失效")
|
||||
source.removeGroup("校验超时")
|
||||
Debug.updateFinalMessage(source.bookSourceUrl, "校验成功")
|
||||
}.onFinally(IO) {
|
||||
@@ -230,7 +229,6 @@ class CheckSourceService : BaseService() {
|
||||
when (it) {
|
||||
is ContentEmptyException -> source.addGroup("${bookType}正文失效")
|
||||
is TocEmptyException -> source.addGroup("${bookType}目录失效")
|
||||
//超时 网站异常 源码改变
|
||||
else -> throw it
|
||||
}
|
||||
}.onSuccess {
|
||||
|
||||
Reference in New Issue
Block a user