From 260fb7ebf5f70bcbf277dd2acf04517aba30a711 Mon Sep 17 00:00:00 2001 From: Robozinho <65715921+RobozinhoD@users.noreply.github.com> Date: Sun, 14 Jul 2024 17:10:50 -0300 Subject: [PATCH] restrict deck option links --- .../java/com/ichi2/anki/pages/DeckOptions.kt | 29 ++++++++++++++++--- 1 file changed, 25 insertions(+), 4 deletions(-) diff --git a/AnkiDroid/src/main/java/com/ichi2/anki/pages/DeckOptions.kt b/AnkiDroid/src/main/java/com/ichi2/anki/pages/DeckOptions.kt index 8b3e73c031b9..050f7964f2c9 100644 --- a/AnkiDroid/src/main/java/com/ichi2/anki/pages/DeckOptions.kt +++ b/AnkiDroid/src/main/java/com/ichi2/anki/pages/DeckOptions.kt @@ -18,6 +18,8 @@ package com.ichi2.anki.pages import android.content.Context import android.content.Intent import android.os.Bundle +import android.webkit.WebResourceRequest +import android.webkit.WebView import androidx.activity.OnBackPressedCallback import androidx.fragment.app.FragmentActivity import anki.collection.OpChanges @@ -25,6 +27,7 @@ import com.ichi2.anki.CollectionManager import com.ichi2.anki.OnPageFinishedCallback import com.ichi2.anki.R import com.ichi2.anki.dialogs.DiscardChangesDialog +import com.ichi2.anki.utils.openUrl import com.ichi2.anki.withProgress import com.ichi2.annotations.NeedsTest import com.ichi2.libanki.undoableOp @@ -60,10 +63,28 @@ class DeckOptions : PageFragment() { override fun onCreateWebViewClient(savedInstanceState: Bundle?): PageWebViewClient { requireActivity().onBackPressedDispatcher.addCallback(this, onBackSaveCallback) requireActivity().onBackPressedDispatcher.addCallback(this, onBackCallback) - return PageWebViewClient().apply { - onPageFinishedCallback = OnPageFinishedCallback { view -> - Timber.v("canGoBack: %b", view.canGoBack()) - onBackCallback.isEnabled = view.canGoBack() + + return object : PageWebViewClient() { + private val ankiManualHostRegex = Regex("^docs\\.ankiweb\\.net\$") + + init { + onPageFinishedCallback = OnPageFinishedCallback { view -> + Timber.v("canGoBack: %b", view.canGoBack()) + onBackCallback.isEnabled = view.canGoBack() + } + } + + override fun shouldOverrideUrlLoading( + view: WebView?, + request: WebResourceRequest? + ): Boolean { + val host = request?.url?.host ?: return shouldOverrideUrlLoading(view, request) + return if (ankiManualHostRegex.matches(host)) { + super.shouldOverrideUrlLoading(view, request) + } else { + openUrl(request.url) + true + } } } }