|
@@ -5,11 +5,15 @@ 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
|
|
@@ -97,8 +101,9 @@ class CloudflareInterceptor(private val context: Context) : Interceptor {
|
|
|
cloudflareBypassed = true
|
|
|
latch.countDown()
|
|
|
}
|
|
|
- // Http error codes are only received since M
|
|
|
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M &&
|
|
|
+
|
|
|
+ // HTTP error codes are only received since M
|
|
|
+ if (WebViewFeature.isFeatureSupported(WebViewFeature.RECEIVE_WEB_RESOURCE_ERROR) &&
|
|
|
url == origRequestUrl && !challengeFound
|
|
|
) {
|
|
|
// The first request didn't return the challenge, abort.
|
|
@@ -106,16 +111,31 @@ class CloudflareInterceptor(private val context: Context) : Interceptor {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- override fun onReceivedErrorCompat(
|
|
|
+ override fun onReceivedHttpError(
|
|
|
+ view: WebView,
|
|
|
+ request: WebResourceRequest,
|
|
|
+ errorResponse: WebResourceResponse
|
|
|
+ ) {
|
|
|
+ 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,
|
|
|
- errorCode: Int,
|
|
|
- description: String?,
|
|
|
- failingUrl: String,
|
|
|
- isMainFrame: Boolean
|
|
|
+ request: WebResourceRequest,
|
|
|
+ error: WebResourceErrorCompat
|
|
|
) {
|
|
|
- if (isMainFrame) {
|
|
|
- if (errorCode == 503) {
|
|
|
- // Found the cloudflare challenge page.
|
|
|
+ if (request.isForMainFrame) {
|
|
|
+ if (error.errorCode == 503) {
|
|
|
+ // Found the Cloudflare challenge page.
|
|
|
challengeFound = true
|
|
|
} else {
|
|
|
// Unlock thread, the challenge wasn't found.
|