From fafd8f8ee649cb542ade40d60a1e26920a3a35c1 Mon Sep 17 00:00:00 2001 From: Contribucious <4764956+contribucious@users.noreply.github.com> Date: Tue, 5 May 2020 16:52:54 +0200 Subject: [PATCH] [Browser lists] Global clarification (#876) * AccessibilityHelpers.cs: global clarification * AutofillHelpers.cs: global clarification * autofillservice.xml: global clarification --- .../Accessibility/AccessibilityHelpers.cs | 43 +++++++++++-------- src/Android/Autofill/AutofillHelpers.cs | 19 +++++--- src/Android/Resources/xml/autofillservice.xml | 11 +++-- 3 files changed, 47 insertions(+), 26 deletions(-) diff --git a/src/Android/Accessibility/AccessibilityHelpers.cs b/src/Android/Accessibility/AccessibilityHelpers.cs index b7ffa10db..39a2b218f 100644 --- a/src/Android/Accessibility/AccessibilityHelpers.cs +++ b/src/Android/Accessibility/AccessibilityHelpers.cs @@ -23,11 +23,14 @@ namespace Bit.Droid.Accessibility public static bool IsAutofillTileAdded = false; public static bool IsAccessibilityBroadcastReady = false; - // Be sure to keep these entries sorted alphabetically + // Be sure to keep these two sections sorted alphabetically public static Dictionary SupportedBrowsers => new List { - new Browser("acr.browser.barebones", "search"), - new Browser("acr.browser.lightning", "search"), + // [Section A] Entries also present in the list of Autofill Framework + // + // So keep them in sync with: + // - AutofillHelpers.{TrustedBrowsers,CompatBrowsers} + // - Resources/xml/autofillservice.xml new Browser("com.amazon.cloud9", "url"), new Browser("com.android.browser", "url"), new Browser("com.android.chrome", "url_bar"), @@ -42,20 +45,11 @@ namespace Bit.Droid.Accessibility new Browser("com.chrome.dev", "url_bar"), new Browser("com.duckduckgo.mobile.android", "omnibarTextInput"), new Browser("com.ecosia.android", "url_bar"), - new Browser("com.feedback.browser.wjbrowser", "addressbar_url"), - new Browser("com.ghostery.android.ghostery", "search_field"), new Browser("com.google.android.apps.chrome", "url_bar"), new Browser("com.google.android.apps.chrome_dev", "url_bar"), - new Browser("com.htc.sense.browser", "title"), - new Browser("com.jerky.browser2", "enterUrl"), new Browser("com.kiwibrowser.browser", "url_bar"), - new Browser("com.ksmobile.cb", "address_bar_edit_text"), - new Browser("com.linkbubble.playstore", "url_text"), new Browser("com.microsoft.emmx", "url_bar"), - new Browser("com.mx.browser", "address_editor_with_progress"), - new Browser("com.mx.browser.tablet", "address_editor_with_progress"), new Browser("com.naver.whale", "url_bar"), - new Browser("com.nubelacorp.javelin", "enterUrl"), new Browser("com.opera.browser", "url_field"), new Browser("com.opera.browser.beta", "url_field"), new Browser("com.opera.mini.native", "url_field"), @@ -69,18 +63,13 @@ namespace Bit.Droid.Accessibility new Browser("com.vivaldi.browser.sopranos", "url_bar"), new Browser("com.yandex.browser", "bro_omnibar_address_title_text,bro_omnibox_collapsed_title", (s) => s.Split(new char[]{' ', ' '}).FirstOrDefault()), // 0 = Regular Space, 1 = No-break space (00A0) - new Browser("jp.co.fenrir.android.sleipnir", "url_text"), - new Browser("jp.co.fenrir.android.sleipnir_black", "url_text"), - new Browser("jp.co.fenrir.android.sleipnir_test", "url_text"), new Browser("mark.via.gp", "aw"), - new Browser("mobi.mgeek.TunnyBrowser", "title"), new Browser("org.adblockplus.browser", "url_bar,url_bar_title"), new Browser("org.adblockplus.browser.beta", "url_bar,url_bar_title"), new Browser("org.bromite.bromite", "url_bar"), new Browser("org.chromium.chrome", "url_bar"), new Browser("org.codeaurora.swe.browser", "url_bar"), new Browser("org.gnu.icecat", "url_bar_title"), - new Browser("org.iron.srware", "url_bar"), new Browser("org.mozilla.fenix", "mozac_browser_toolbar_url_view"), new Browser("org.mozilla.fenix.nightly", "mozac_browser_toolbar_url_view"), new Browser("org.mozilla.fennec_aurora", "url_bar_title"), @@ -93,6 +82,26 @@ namespace Bit.Droid.Accessibility new Browser("org.mozilla.rocket", "display_url"), new Browser("org.torproject.torbrowser", "url_bar_title"), new Browser("org.torproject.torbrowser_alpha", "url_bar_title"), + + // [Section B] Entries only present here + // + // FIXME: Test the compatibility of these with Autofill Framework + new Browser("acr.browser.barebones", "search"), + new Browser("acr.browser.lightning", "search"), + new Browser("com.feedback.browser.wjbrowser", "addressbar_url"), + new Browser("com.ghostery.android.ghostery", "search_field"), + new Browser("com.htc.sense.browser", "title"), + new Browser("com.jerky.browser2", "enterUrl"), + new Browser("com.ksmobile.cb", "address_bar_edit_text"), + new Browser("com.linkbubble.playstore", "url_text"), + new Browser("com.mx.browser", "address_editor_with_progress"), + new Browser("com.mx.browser.tablet", "address_editor_with_progress"), + new Browser("com.nubelacorp.javelin", "enterUrl"), + new Browser("jp.co.fenrir.android.sleipnir", "url_text"), + new Browser("jp.co.fenrir.android.sleipnir_black", "url_text"), + new Browser("jp.co.fenrir.android.sleipnir_test", "url_text"), + new Browser("mobi.mgeek.TunnyBrowser", "title"), + new Browser("org.iron.srware", "url_bar"), }.ToDictionary(n => n.PackageName); // Known packages to skip diff --git a/src/Android/Autofill/AutofillHelpers.cs b/src/Android/Autofill/AutofillHelpers.cs index aa859733b..cc501b96a 100644 --- a/src/Android/Autofill/AutofillHelpers.cs +++ b/src/Android/Autofill/AutofillHelpers.cs @@ -16,8 +16,12 @@ namespace Bit.Droid.Autofill { private static int _pendingIntentId = 0; - // These browser work natively with the autofill framework - // Be sure to keep these entries sorted alphabetically + // These browsers work natively with the Autofill Framework + // + // Be sure: + // - to keep these entries sorted alphabetically and + // + // - ... to keep this list in sync with values in AccessibilityHelpers.SupportedBrowsers [Section A], too. public static HashSet TrustedBrowsers = new HashSet { "com.duckduckgo.mobile.android", @@ -25,10 +29,13 @@ namespace Bit.Droid.Autofill "org.mozilla.klar", }; - // These browsers work using the compatibility shim for the autofill framework - // Be sure to: - // - keep these entries sorted alphabetically - // - keep this list in sync with values in Resources/xml/autofillservice.xml + // These browsers work using the compatibility shim for the Autofill Framework + // + // Be sure: + // - to keep these entries sorted alphabetically, + // - to keep this list in sync with values in Resources/xml/autofillservice.xml, and + // + // - ... to keep this list in sync with values in AccessibilityHelpers.SupportedBrowsers [Section A], too. public static HashSet CompatBrowsers = new HashSet { "com.amazon.cloud9", diff --git a/src/Android/Resources/xml/autofillservice.xml b/src/Android/Resources/xml/autofillservice.xml index b8eaa2fcb..7b110765d 100644 --- a/src/Android/Resources/xml/autofillservice.xml +++ b/src/Android/Resources/xml/autofillservice.xml @@ -1,8 +1,13 @@