|
@@ -2,17 +2,14 @@ package eu.kanade.tachiyomi.network
|
|
|
|
|
|
import android.annotation.SuppressLint
|
|
|
import android.content.Context
|
|
|
+import android.os.Build
|
|
|
import android.os.Handler
|
|
|
import android.os.Looper
|
|
|
-import android.webkit.WebResourceRequest
|
|
|
-import android.webkit.WebResourceResponse
|
|
|
import android.webkit.WebSettings
|
|
|
import android.webkit.WebView
|
|
|
import android.widget.Toast
|
|
|
-import androidx.webkit.WebResourceErrorCompat
|
|
|
-import androidx.webkit.WebViewClientCompat
|
|
|
-import androidx.webkit.WebViewFeature
|
|
|
import eu.kanade.tachiyomi.R
|
|
|
+import eu.kanade.tachiyomi.util.system.WebViewClientCompat
|
|
|
import eu.kanade.tachiyomi.util.system.isOutdated
|
|
|
import eu.kanade.tachiyomi.util.system.toast
|
|
|
import okhttp3.Cookie
|
|
@@ -102,39 +99,24 @@ class CloudflareInterceptor(private val context: Context) : Interceptor {
|
|
|
}
|
|
|
|
|
|
// HTTP error codes are only received since M
|
|
|
- if (WebViewFeature.isFeatureSupported(WebViewFeature.RECEIVE_WEB_RESOURCE_ERROR) &&
|
|
|
- url == origRequestUrl && !challengeFound
|
|
|
+ if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M &&
|
|
|
+ url == origRequestUrl && !challengeFound
|
|
|
) {
|
|
|
// The first request didn't return the challenge, abort.
|
|
|
latch.countDown()
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- override fun onReceivedHttpError(
|
|
|
+ override fun onReceivedErrorCompat(
|
|
|
view: WebView,
|
|
|
- request: WebResourceRequest,
|
|
|
- errorResponse: WebResourceResponse
|
|
|
+ errorCode: Int,
|
|
|
+ description: String?,
|
|
|
+ failingUrl: String,
|
|
|
+ isMainFrame: Boolean
|
|
|
) {
|
|
|
- if (request.isForMainFrame) {
|
|
|
- if (errorResponse.statusCode == 503) {
|
|
|
- // Found the Cloudflare challenge page.
|
|
|
- challengeFound = true
|
|
|
- } else {
|
|
|
- // Unlock thread, the challenge wasn't found.
|
|
|
- latch.countDown()
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- @SuppressLint("RequiresFeature")
|
|
|
- override fun onReceivedError(
|
|
|
- view: WebView,
|
|
|
- request: WebResourceRequest,
|
|
|
- error: WebResourceErrorCompat
|
|
|
- ) {
|
|
|
- if (request.isForMainFrame) {
|
|
|
- if (error.errorCode == 503) {
|
|
|
- // Found the Cloudflare challenge page.
|
|
|
+ if (isMainFrame) {
|
|
|
+ if (errorCode == 503) {
|
|
|
+ // Found the cloudflare challenge page.
|
|
|
challengeFound = true
|
|
|
} else {
|
|
|
// Unlock thread, the challenge wasn't found.
|