Skip to content
Snippets Groups Projects

Compare revisions

Changes are shown as if the source revision was being merged into the target revision. Learn more about comparing revisions.

Source

Select target project
No results found
Select Git revision
  • android-components-102.0.14-12.5-1
  • android-components-102.0.14-12.0-1
  • android-components-102.0.14-11.5-1
  • android-components-99.0.3-11.5-1
  • android-components-100.0.8-11.5-1
  • android-components-99.0.10-11.0-1
  • android-components-96.0.15-11.0-1
  • android-components-96.0.15-11.5-1
  • android-components-96.0.13-11.5-1
  • android-components-95.0.10-11.5-1
  • android-components-95.0.14-11.5-1
  • android-components-94.0.12-11.5-1
  • android-components-95.0.10-11.0-1
  • android-components-94.0.12-11.0-1
  • android-components-93.0.12-11.0-1
  • android-components-91.0.13-10.5-1
  • android-components-91.0.13-11.0-1
  • android-components-91.0.12-10.5-1
  • android-components-91.0.12-11.0-1
  • android-components-91.0.8-11.0-1
  • android-components-91.0.7-11.0-1
  • android-components-91.0.1-11.0-1
  • android-components-90.0.12-11.0-1
  • android-components-90.0.12-10.5-1
  • android-components-90.0.11-10.5-1
  • android-components-90.0.11-11.0-1
  • android-components-75.0.22-10.0-1
  • android-components-75.0.22-10.5-1
  • android-components-75.0.21-10.5-1
  • android-components-75.0.11-10.5-1
  • android-components-74.0.13-10.0-1
  • android-components-74.0.13-10.5-1
  • android-components-74.0.11-10.5-1
  • android-components-74.0.10-10.5-1
  • android-components-74.0.6-10.5-1
  • android-components-73.0.11-10.0-1
  • android-components-73.0.11-10.5-1
  • android-components-73.0.3-10.5-1
  • android-components-72.0.15-10.0-1
  • android-components-72.0.15-10.5-1
  • android-components-72.0.14-10.5-1
  • android-components-72.0.5-10.5-1
  • android-components-72.0.1-10.5-1
  • android-components-70.0.16-10.0-1
  • android-components-70.0.16-10.5-1
  • android-components-70.0.11-10.5-1
  • android-components-67.0.17-10.0-1
  • android-components-70.0.0-10.5-1
  • android-components-67.0.11-10.0-1
  • android-components-67.0.11-10.5-1
  • android-components-67.0.10-10.5-1
  • android-components-67.0.10-10.0-1
  • android-components-67.0.3-10.5-1
  • android-components-63.0.9-10.0-1
  • android-components-63.0.8-10.5-1
  • android-components-60.0.5-10.5-1
  • android-components-63.0.1-10.5-1
  • android-components-60.0.5-10.0-1
  • android-components-63.0.1-10.0-1
  • android-components-60.0.3-10.0-1
  • android-components-63.0.0-10.0-1
  • android-components-57.0.7-10.0-1
  • android-components-57.0.6-10.0-2
  • android-components-57.0.6-10.0-1
  • android-components-57.0.0-10.0-1
  • releases/57.0
  • android-components-102.0.14-11.5-1-build1
  • android-components-102.0.14-11.5-1-build2
  • android-components-102.0.14-11.5-1-build3
  • android-components-102.0.14-12.0-1-build1
  • android-components-102.0.14-12.0-1-build2
  • android-components-102.0.14-12.0-1-build3
  • android-components-102.0.14-12.0-1-build4
  • android-components-102.0.14-12.0-1-build5
  • android-components-102.0.14-12.0-1-build6
  • android-components-102.0.14-12.5-1-build1
  • android-components-102.0.14-12.5-1-build2
  • android-components-102.0.14-12.5-1-build3
  • android-components-57.0.7-10.0-1-build1
  • android-components-60.0.5-10.0-1-build1
  • android-components-63.0.8-10.5-1-build1
  • android-components-63.0.9-10.0-1-build1
  • android-components-67.0.11-10.0-1-build1
  • android-components-67.0.11-10.5-1-build1
  • android-components-67.0.17-10.0-1-build1
  • android-components-67.0.3-10.5-1-build1
  • android-components-70.0.11-10.5-1-build1
  • android-components-70.0.16-10.0-1-build1
  • android-components-70.0.16-10.5-1-build1
  • android-components-72.0.15-10.0-1-build1
  • android-components-72.0.15-10.5-1-build1
  • android-components-72.0.5-10.5-1-build1
  • android-components-73.0.11-10.0-1-build1
  • android-components-73.0.11-10.5-1-build1
  • android-components-73.0.3-10.5-1-build1
  • android-components-74.0.11-10.5-1-build1
  • android-components-74.0.13-10.0-1-build1
  • android-components-74.0.13-10.5-1-build1
  • android-components-75.0.22-10.0-1-build1
  • android-components-75.0.22-10.5-1-build1
  • android-components-90.0.11-11.0-1-build1
  • android-components-90.0.12-10.5-1-build1
  • android-components-90.0.12-11.0-1-build1
  • android-components-91.0.12-11.0-1-build1
  • android-components-91.0.13-10.5-1-build1
  • android-components-91.0.13-11.0-1-build1
  • android-components-91.0.8-11.0-1-build1
  • android-components-94.0.12-11.0-1-build1
  • android-components-94.0.12-11.5-1-build1
  • android-components-96.0.15-11.0-1-build1
  • android-components-96.0.15-11.0-1-build2
  • android-components-96.0.15-11.5-1-build1
  • android-components-99.0.3-11.5-1-build1
  • android-components-99.0.3-11.5-1-build2
  • android-components-99.0.3-11.5-1-build3
  • android-components-99.0.3-11.5-1-build4
  • v102.0.14
  • v57.0.0
118 results

Target

Select target project
  • aguestuser / android-components
  • Matthew Finkel / android-components
  • Alex Catarineu / android-components
  • Georg Koppen / android-components
  • Gaba / android-components
  • boklm / android-components
  • ma1 / android-components
  • morgan / android-components
  • Tommy Webb / android-components
  • cypherpunks1 / android-components
  • Dan Ballard / android-components
11 results
Select Git revision
  • android-components-102.0.14-12.5-1
  • android-components-102.0.14-12.0-1
  • android-components-102.0.14-11.5-1
  • android-components-99.0.3-11.5-1
  • android-components-100.0.8-11.5-1
  • android-components-99.0.10-11.0-1
  • android-components-96.0.15-11.0-1
  • android-components-96.0.15-11.5-1
  • android-components-96.0.13-11.5-1
  • android-components-95.0.10-11.5-1
  • android-components-95.0.14-11.5-1
  • android-components-94.0.12-11.5-1
  • android-components-95.0.10-11.0-1
  • android-components-94.0.12-11.0-1
  • android-components-93.0.12-11.0-1
  • android-components-91.0.13-10.5-1
  • android-components-91.0.13-11.0-1
  • android-components-91.0.12-10.5-1
  • android-components-91.0.12-11.0-1
  • android-components-91.0.8-11.0-1
  • android-components-91.0.7-11.0-1
  • android-components-91.0.1-11.0-1
  • android-components-90.0.12-11.0-1
  • android-components-90.0.12-10.5-1
  • android-components-90.0.11-10.5-1
  • android-components-90.0.11-11.0-1
  • android-components-75.0.22-10.0-1
  • android-components-75.0.22-10.5-1
  • android-components-75.0.21-10.5-1
  • android-components-75.0.11-10.5-1
  • android-components-74.0.13-10.0-1
  • android-components-74.0.13-10.5-1
  • android-components-74.0.11-10.5-1
  • android-components-74.0.10-10.5-1
  • android-components-74.0.6-10.5-1
  • android-components-73.0.11-10.0-1
  • android-components-73.0.11-10.5-1
  • android-components-73.0.3-10.5-1
  • android-components-72.0.15-10.0-1
  • android-components-72.0.15-10.5-1
  • android-components-72.0.14-10.5-1
  • android-components-72.0.5-10.5-1
  • android-components-72.0.1-10.5-1
  • android-components-70.0.16-10.0-1
  • android-components-70.0.16-10.5-1
  • android-components-70.0.11-10.5-1
  • android-components-67.0.17-10.0-1
  • android-components-70.0.0-10.5-1
  • android-components-67.0.11-10.0-1
  • android-components-67.0.11-10.5-1
  • android-components-67.0.10-10.5-1
  • android-components-67.0.10-10.0-1
  • android-components-67.0.3-10.5-1
  • android-components-63.0.9-10.0-1
  • android-components-63.0.8-10.5-1
  • android-components-60.0.5-10.5-1
  • android-components-63.0.1-10.5-1
  • android-components-60.0.5-10.0-1
  • android-components-63.0.1-10.0-1
  • android-components-60.0.3-10.0-1
  • android-components-63.0.0-10.0-1
  • android-components-57.0.7-10.0-1
  • android-components-57.0.6-10.0-2
  • android-components-57.0.6-10.0-1
  • android-components-57.0.0-10.0-1
  • releases/57.0
  • android-components-102.0.14-11.5-1-build1
  • android-components-102.0.14-11.5-1-build2
  • android-components-102.0.14-11.5-1-build3
  • android-components-102.0.14-12.0-1-build1
  • android-components-102.0.14-12.0-1-build2
  • android-components-102.0.14-12.0-1-build3
  • android-components-102.0.14-12.0-1-build4
  • android-components-102.0.14-12.0-1-build5
  • android-components-102.0.14-12.0-1-build6
  • android-components-102.0.14-12.5-1-build1
  • android-components-102.0.14-12.5-1-build2
  • android-components-102.0.14-12.5-1-build3
  • android-components-57.0.7-10.0-1-build1
  • android-components-60.0.5-10.0-1-build1
  • android-components-63.0.8-10.5-1-build1
  • android-components-63.0.9-10.0-1-build1
  • android-components-67.0.11-10.0-1-build1
  • android-components-67.0.11-10.5-1-build1
  • android-components-67.0.17-10.0-1-build1
  • android-components-67.0.3-10.5-1-build1
  • android-components-70.0.11-10.5-1-build1
  • android-components-70.0.16-10.0-1-build1
  • android-components-70.0.16-10.5-1-build1
  • android-components-72.0.15-10.0-1-build1
  • android-components-72.0.15-10.5-1-build1
  • android-components-72.0.5-10.5-1-build1
  • android-components-73.0.11-10.0-1-build1
  • android-components-73.0.11-10.5-1-build1
  • android-components-73.0.3-10.5-1-build1
  • android-components-74.0.11-10.5-1-build1
  • android-components-74.0.13-10.0-1-build1
  • android-components-74.0.13-10.5-1-build1
  • android-components-75.0.22-10.0-1-build1
  • android-components-75.0.22-10.5-1-build1
  • android-components-90.0.11-11.0-1-build1
  • android-components-90.0.12-10.5-1-build1
  • android-components-90.0.12-11.0-1-build1
  • android-components-91.0.12-11.0-1-build1
  • android-components-91.0.13-10.5-1-build1
  • android-components-91.0.13-11.0-1-build1
  • android-components-91.0.8-11.0-1-build1
  • android-components-94.0.12-11.0-1-build1
  • android-components-94.0.12-11.5-1-build1
  • android-components-96.0.15-11.0-1-build1
  • android-components-96.0.15-11.0-1-build2
  • android-components-96.0.15-11.5-1-build1
  • android-components-99.0.3-11.5-1-build1
  • android-components-99.0.3-11.5-1-build2
  • android-components-99.0.3-11.5-1-build3
  • android-components-99.0.3-11.5-1-build4
  • v102.0.14
  • v57.0.0
118 results
Show changes

Commits on Source 12

38 files
+ 228
914
Compare changes
  • Side-by-side
  • Inline

Files

+7 −1
Original line number Diff line number Diff line
@@ -106,7 +106,13 @@ subprojects {
            rename { 'manifest.json' }
            into extDir

            def values = ['version': rootProject.ext.config.componentsVersion + "." + new Date().format('MMddHHmmss')]
            def systemEnvBuildDate = System.getenv('MOZ_BUILD_DATE')
            // MOZ_BUILD_DATE is in the YYYYMMDDHHMMSS format. Thus, we only use a
            // substring of it if it is available.
            def values = ['version': rootProject.ext.config.componentsVersion + "." +
                          (systemEnvBuildDate != null ?
                           systemEnvBuildDate.substring(4) :
                           new Date().format('MMddHHmmss'))]
            inputs.properties(values)
            expand(values)
        }
+18 −0
Original line number Diff line number Diff line
@@ -634,6 +634,22 @@ class GeckoEngine(
        override var enterpriseRootsEnabled: Boolean
            get() = runtime.settings.enterpriseRootsEnabled
            set(value) { runtime.settings.enterpriseRootsEnabled = value }

        override var torSecurityLevel: Int
            get() = runtime.settings.torSecurityLevel
            set(value) {
                value.let {
                    runtime.settings.torSecurityLevel = it
                }
            }
        override var spoofEnglish: Boolean
            get() = runtime.settings.spoofEnglish
            set(value) {
                value.let {
                    runtime.settings.spoofEnglish = it
                    localeUpdater.updateValue()
                }
            }
    }.apply {
        defaultSettings?.let {
            this.javascriptEnabled = it.javascriptEnabled
@@ -652,6 +668,8 @@ class GeckoEngine(
            this.clearColor = it.clearColor
            this.loginAutofillEnabled = it.loginAutofillEnabled
            this.enterpriseRootsEnabled = it.enterpriseRootsEnabled
            this.torSecurityLevel = it.torSecurityLevel
            this.spoofEnglish = it.spoofEnglish
        }
    }

+1 −0
Original line number Diff line number Diff line
@@ -88,6 +88,7 @@ private fun Request.toWebRequest(): WebRequest = WebRequest.Builder(url)
    .addHeadersFrom(this)
    .addBodyFrom(this)
    .cacheMode(if (useCaches) CACHE_MODE_DEFAULT else CACHE_MODE_RELOAD)
    .origin(origin)
    .build()

private fun WebRequest.Builder.addHeadersFrom(request: Request): WebRequest.Builder {
+2 −1
Original line number Diff line number Diff line
@@ -52,7 +52,8 @@ class HttpIconLoader(
            connectTimeout = Pair(CONNECT_TIMEOUT, TimeUnit.SECONDS),
            readTimeout = Pair(READ_TIMEOUT, TimeUnit.SECONDS),
            redirect = Request.Redirect.FOLLOW,
            useCaches = true)
            useCaches = true,
            origin = request.url)

        return try {
            val response = httpClient.fetch(downloadRequest)
+6 −21
Original line number Diff line number Diff line
@@ -9,7 +9,6 @@ import androidx.annotation.ColorRes
import androidx.annotation.DrawableRes
import mozilla.components.browser.menu.item.BackPressMenuItem
import mozilla.components.browser.menu.item.BrowserMenuDivider
import mozilla.components.browser.menu.item.BrowserMenuImageText
import mozilla.components.browser.menu.item.NO_ID
import mozilla.components.browser.menu.item.ParentBrowserMenuItem
import mozilla.components.browser.menu.item.WebExtensionBrowserMenuItem
@@ -96,20 +95,10 @@ class WebExtensionBrowserMenuBuilder(
                iconTintColorResource = style.webExtIconTintColorResource
            )

            val addonsManagerMenuItem = BrowserMenuImageText(
                label = context.getString(R.string.mozac_browser_menu_addons_manager),
                imageResource = style.addonsManagerMenuItemDrawableRes,
                iconTintColorResource = style.webExtIconTintColorResource
            ) {
                onAddonsManagerTapped.invoke()
            }

            val webExtSubMenuItems = if (appendExtensionSubMenuAtStart) {
                listOf(backPressMenuItem) + BrowserMenuDivider() +
                filteredExtensionMenuItems +
                BrowserMenuDivider() + addonsManagerMenuItem
                filteredExtensionMenuItems
            } else {
                listOf(addonsManagerMenuItem) + BrowserMenuDivider() +
                filteredExtensionMenuItems +
                BrowserMenuDivider() + backPressMenuItem
            }
@@ -125,25 +114,21 @@ class WebExtensionBrowserMenuBuilder(
                endOfMenuAlwaysVisible = endOfMenuAlwaysVisible
            )
        } else {
            BrowserMenuImageText(
                label = context.getString(R.string.mozac_browser_menu_addons),
                imageResource = style.addonsManagerMenuItemDrawableRes,
                iconTintColorResource = style.webExtIconTintColorResource
            ) {
                onAddonsManagerTapped.invoke()
            }
            null
        }
        val mainMenuIndex = items.indexOfFirst { browserMenuItem ->
            (browserMenuItem as? WebExtensionPlaceholderMenuItem)?.id ==
                WebExtensionPlaceholderMenuItem.MAIN_EXTENSIONS_MENU_ID
        }

        return if (mainMenuIndex != -1) {
        return if (mainMenuIndex != -1 && addonsMenuItem != null) {
            items[mainMenuIndex] = addonsMenuItem
            items
            // if we do not have a placeholder we should add the extension submenu at top or bottom
        } else {
            if (appendExtensionSubMenuAtStart) {
            if (addonsMenuItem == null) {
                items
            } else if (appendExtensionSubMenuAtStart) {
                listOf(addonsMenuItem) + items
            } else {
                items + addonsMenuItem
+1 −0
Original line number Diff line number Diff line
@@ -499,6 +499,7 @@ class DisplayToolbar internal constructor(
        @ColorInt val color = when (siteSecurity) {
            Toolbar.SiteSecurity.INSECURE -> colors.securityIconInsecure
            Toolbar.SiteSecurity.SECURE -> colors.securityIconSecure
            Toolbar.SiteSecurity.ONION -> colors.securityIconSecure
        }
        if (color == Color.TRANSPARENT) {
            views.securityIndicator.clearColorFilter()
+5 −0
Original line number Diff line number Diff line
@@ -43,6 +43,11 @@ internal class SiteSecurityIconView @JvmOverloads constructor(
                View.mergeDrawableStates(drawableState, intArrayOf(R.attr.state_site_secure))
                drawableState
            }
            SiteSecurity.ONION -> {
                val drawableState = super.onCreateDrawableState(extraSpace + 1)
                View.mergeDrawableStates(drawableState, intArrayOf(R.attr.state_site_onion))
                drawableState
            }
        }
    }
}
+3 −0
Original line number Diff line number Diff line
@@ -3,6 +3,9 @@
   - License, v. 2.0. If a copy of the MPL was not distributed with this
   - file, You can obtain one at http://mozilla.org/MPL/2.0/. -->
<selector xmlns:android="http://schemas.android.com/apk/res/android" xmlns:ac="http://schemas.android.com/apk/res-auto">
    <item
        android:drawable="@drawable/mozac_ic_onion"
        ac:state_site_onion="true" />
    <item
        android:drawable="@drawable/mozac_ic_lock"
        ac:state_site_secure="true" />
+4 −0
Original line number Diff line number Diff line
@@ -27,6 +27,10 @@
    <attr name="state_site_secure" format="boolean"/>
  </declare-styleable>

  <declare-styleable name="BrowserToolbarSiteOnionState">
    <attr name="state_site_onion" format="boolean"/>
  </declare-styleable>

  <declare-styleable name="ActionContainer">
    <attr name="actionContainerItemSize" format="dimension" />
  </declare-styleable>
+4 −1
Original line number Diff line number Diff line
@@ -9,6 +9,7 @@ import android.graphics.Bitmap
import androidx.annotation.CallSuper
import mozilla.components.concept.engine.EngineSession.TrackingProtectionPolicy.CookiePolicy.ACCEPT_ALL
import mozilla.components.concept.engine.EngineSession.TrackingProtectionPolicy.CookiePolicy.ACCEPT_NON_TRACKERS
import mozilla.components.concept.engine.EngineSession.TrackingProtectionPolicy.CookiePolicy.ACCEPT_ONLY_FIRST_PARTY
import mozilla.components.concept.engine.content.blocking.Tracker
import mozilla.components.concept.engine.history.HistoryItem
import mozilla.components.concept.engine.manifest.WebAppManifest
@@ -384,7 +385,9 @@ abstract class EngineSession(
        companion object {
            fun none() = TrackingProtectionPolicy(
                trackingCategories = arrayOf(TrackingCategory.NONE),
                cookiePolicy = ACCEPT_ALL
                useForPrivateSessions = false,
                useForRegularSessions = false,
                cookiePolicy = ACCEPT_ONLY_FIRST_PARTY
            )

            /**
+10 −1
Original line number Diff line number Diff line
@@ -184,6 +184,13 @@ abstract class Settings {
     * Setting to control whether enterprise root certs are enabled.
     */
    open var enterpriseRootsEnabled: Boolean by UnsupportedSetting()

    /**
     * Setting to control the current security level
     */
    open var torSecurityLevel: Int by UnsupportedSetting()

    open var spoofEnglish: Boolean by UnsupportedSetting()
}

/**
@@ -220,7 +227,9 @@ data class DefaultSettings(
    override var forceUserScalableContent: Boolean = false,
    override var loginAutofillEnabled: Boolean = false,
    override var clearColor: Int? = null,
    override var enterpriseRootsEnabled: Boolean = false
    override var enterpriseRootsEnabled: Boolean = false,
    override var torSecurityLevel: Int = 4,
    override var spoofEnglish: Boolean = false
) : Settings()

class UnsupportedSetting<T> {
+2 −1
Original line number Diff line number Diff line
@@ -48,7 +48,8 @@ data class Request(
    val redirect: Redirect = Redirect.FOLLOW,
    val cookiePolicy: CookiePolicy = CookiePolicy.INCLUDE,
    val useCaches: Boolean = true,
    val private: Boolean = false
    val private: Boolean = false,
    val origin: String? = null
) {
    /**
     * A [Body] to be send with the [Request].
+1 −0
Original line number Diff line number Diff line
@@ -414,6 +414,7 @@ interface Toolbar {
    enum class SiteSecurity {
        INSECURE,
        SECURE,
        ONION,
    }

    /**
+3 −3
Original line number Diff line number Diff line
@@ -58,7 +58,7 @@ internal const val PAGE_SIZE = 50
 * cache is being used by default
 */
@Suppress("LongParameterList")
class AddonCollectionProvider(
open class AddonCollectionProvider(
    private val context: Context,
    private val client: Client,
    private val serverURL: String = DEFAULT_SERVER_URL,
@@ -173,7 +173,7 @@ class AddonCollectionProvider(
     * a connectivity problem or a timeout.
     */
    @Throws(IOException::class)
    suspend fun getAddonIconBitmap(addon: Addon): Bitmap? {
    open suspend fun getAddonIconBitmap(addon: Addon): Bitmap? {
        var bitmap: Bitmap? = null
        if (addon.iconUrl != "") {
            client.fetch(
@@ -191,7 +191,7 @@ class AddonCollectionProvider(
    }

    @VisibleForTesting
    internal fun writeToDiskCache(collectionResponse: String, language: String?) {
    protected fun writeToDiskCache(collectionResponse: String, language: String?) {
        synchronized(diskCacheLock) {
            getCacheFile(context, language, useFallbackFile = false).writeString { collectionResponse }
        }
+1 −0
Original line number Diff line number Diff line
@@ -63,6 +63,7 @@
        />

    <androidx.appcompat.widget.AppCompatCheckBox
        android:visibility="gone"
        android:id="@+id/allow_in_private_browsing"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
+1 −0
Original line number Diff line number Diff line
@@ -42,6 +42,7 @@ dependencies {

    implementation Dependencies.kotlin_stdlib
    implementation Dependencies.kotlin_coroutines
    implementation project(path: ':support-utils')

    testImplementation project(':support-test')
    testImplementation project(':support-test-libstate')
+1 −1
Original line number Diff line number Diff line
@@ -100,7 +100,7 @@ class AppLinksFeature(
            )
        }

        if (!tab.content.private || fragmentManager == null) {
        if (true || !tab.content.private || fragmentManager == null) {
            doOpenApp()
            return
        }
+2 −1
Original line number Diff line number Diff line
@@ -21,6 +21,7 @@ import mozilla.components.support.ktx.android.net.isHttpOrHttps
import java.lang.Exception
import java.lang.NullPointerException
import java.net.URISyntaxException
import mozilla.components.support.utils.TorUtils

private const val EXTRA_BROWSER_FALLBACK_URL = "browser_fallback_url"
private const val MARKET_INTENT_URI_PACKAGE_PREFIX = "market://details?id="
@@ -211,7 +212,7 @@ class AppLinksUseCases(
                    if (launchInNewTask) {
                        it.flags = it.flags or Intent.FLAG_ACTIVITY_NEW_TASK
                    }
                    context.startActivity(it)
                    TorUtils.startActivityPrompt(context, it)
                } catch (e: Exception) {
                    when (e) {
                        is ActivityNotFoundException, is SecurityException, is NullPointerException -> {
+2 −1
Original line number Diff line number Diff line
@@ -23,6 +23,7 @@ import mozilla.components.support.ktx.android.content.addContact
import mozilla.components.support.ktx.android.content.share
import mozilla.components.support.ktx.kotlin.stripMailToProtocol
import mozilla.components.support.ktx.kotlin.takeOrReplace
import mozilla.components.support.utils.TorUtils

/**
 * A candidate for an item to be displayed in the context menu.
@@ -358,7 +359,7 @@ data class ContextMenuCandidate(
                    context.getString(R.string.mozac_feature_contextmenu_share_link)
                ).addFlags(Intent.FLAG_ACTIVITY_NEW_TASK)

                context.startActivity(shareIntent)
                TorUtils.startActivityPrompt(context, shareIntent)
            }
        )

+2 −0
Original line number Diff line number Diff line
@@ -21,6 +21,8 @@ android {
                arg("room.schemaLocation", "$projectDir/schemas".toString())
            }
        }

        buildConfigField("boolean", "ANDROID_DOWNLOADS_INTEGRATION", "false")
    }

    buildTypes {
+8 −3
Original line number Diff line number Diff line
@@ -74,6 +74,7 @@ import mozilla.components.support.ktx.kotlin.ifNullOrEmpty
import mozilla.components.support.ktx.kotlin.sanitizeURL
import mozilla.components.support.ktx.kotlinx.coroutines.throttleLatest
import mozilla.components.support.utils.DownloadUtils
import mozilla.components.support.utils.TorUtils
import java.io.File
import java.io.FileOutputStream
import java.io.IOException
@@ -370,7 +371,9 @@ abstract class AbstractFetchDownloadService : Service() {
                style.notificationAccentColor
            )
            COMPLETED -> {
                if (BuildConfig.ANDROID_DOWNLOADS_INTEGRATION) {
                    addToDownloadSystemDatabaseCompat(download.state, scope)
                }
                DownloadNotification.createDownloadCompletedNotification(
                    context,
                    download,
@@ -835,7 +838,9 @@ abstract class AbstractFetchDownloadService : Service() {
    }

    @VisibleForTesting
    internal fun shouldUseScopedStorage() = getSdkVersion() >= Build.VERSION_CODES.Q
    internal fun shouldUseScopedStorage() =
            BuildConfig.ANDROID_DOWNLOADS_INTEGRATION &&
            getSdkVersion() >= Build.VERSION_CODES.Q

    /**
     * Gets the SDK version from the system.
@@ -947,7 +952,7 @@ abstract class AbstractFetchDownloadService : Service() {
            }

            return try {
                applicationContext.startActivity(newIntent)
                TorUtils.startActivityPrompt(applicationContext, newIntent)
                true
            } catch (error: ActivityNotFoundException) {
                false
+1 −2
Original line number Diff line number Diff line
@@ -25,7 +25,6 @@ import mozilla.components.browser.state.state.SessionState
import mozilla.components.browser.state.state.content.DownloadState
import mozilla.components.browser.state.store.BrowserStore
import mozilla.components.feature.downloads.DownloadDialogFragment.Companion.FRAGMENT_TAG
import mozilla.components.feature.downloads.manager.AndroidDownloadManager
import mozilla.components.feature.downloads.manager.DownloadManager
import mozilla.components.feature.downloads.manager.noop
import mozilla.components.feature.downloads.manager.onDownloadStopped
@@ -70,7 +69,7 @@ class DownloadsFeature(
    internal val useCases: DownloadsUseCases,
    override var onNeedToRequestPermissions: OnNeedToRequestPermissions = { },
    onDownloadStopped: onDownloadStopped = noop,
    private val downloadManager: DownloadManager = AndroidDownloadManager(applicationContext, store),
    private val downloadManager: DownloadManager,
    private val tabId: String? = null,
    private val fragmentManager: FragmentManager? = null,
    private val promptsStyling: PromptsStyling? = null,
+1 −0
Original line number Diff line number Diff line
@@ -47,6 +47,7 @@ class PrivateNotificationFeature<T : AbstractPrivateNotificationService>(
    }

    override fun stop() {
        applicationContext.stopService(Intent(applicationContext, notificationServiceClass.java))
        scope?.cancel()
    }
}
+3 −851

File changed.

Preview size limit exceeded, changes collapsed.

+11 −0
Original line number Diff line number Diff line
<SearchPlugin xmlns="http://www.mozilla.org/2006/browser/search/">
<ShortName>DuckDuckGoOnion</ShortName>
<Description>Duck Duck Go Onion</Description>
<InputEncoding>UTF-8</InputEncoding>
<Image height="16" width="16"></Image>
<Url type="text/html" method="POST" template="https://duckduckgogg42xjoc72x3sjasowoarfbgcmvfimaftt6twagswzczad.onion">
  <Param name="q" value="{searchTerms}"/>
</Url>
<SearchForm>https://duckduckgogg42xjoc72x3sjasowoarfbgcmvfimaftt6twagswzczad.onion</SearchForm>
</SearchPlugin>
+2 −11
Original line number Diff line number Diff line
@@ -4,20 +4,11 @@

<SearchPlugin xmlns="http://www.mozilla.org/2006/browser/search/">
<ShortName>DuckDuckGo</ShortName>
<Description>Duck Duck Go</Description>
<InputEncoding>UTF-8</InputEncoding>
<Image width="16" height="16"></Image>
<Url type="application/x-suggestions+json" method="GET" template="https://ac.duckduckgo.com/ac/">
<Url type="text/html" method="POST" template="https://duckduckgo.com">
  <Param name="q" value="{searchTerms}"/>
  <Param name="type" value="list"/>
</Url>
<!-- this is effectively x-moz-phonesearch, but search service expects a text/html entry -->
<Url type="text/html" method="GET" template="https://duckduckgo.com/">
  <Param name="q" value="{searchTerms}" />
  <Param name="t" value="fpas" />
</Url>
<Url type="application/x-moz-tabletsearch" method="GET" template="https://duckduckgo.com/">
  <Param name="q" value="{searchTerms}" />
  <Param name="t" value="ftas" />
</Url>
<SearchForm>https://duckduckgo.com</SearchForm>
</SearchPlugin>
+11 −0
Original line number Diff line number Diff line
<SearchPlugin xmlns="http://www.mozilla.org/2006/browser/search/">
<ShortName>Startpage</ShortName>
<Description>Start Page</Description>
<InputEncoding>UTF-8</InputEncoding>
<Image width="16" height="16"></Image>

<Url type="text/html" method="POST" template="https://startpage.com/rto/search">
  <Param name="q" value="{searchTerms}"/>
</Url>
<SearchForm>https://startpage.com/rto/search/</SearchForm>
</SearchPlugin>
+22 −0
Original line number Diff line number Diff line
<!-- This Source Code Form is subject to the terms of the Mozilla Public
   - License, v. 2.0. If a copy of the MPL was not distributed with this
   - file, You can obtain one at http://mozilla.org/MPL/2.0/. -->

<SearchPlugin xmlns="http://www.mozilla.org/2006/browser/search/">
<ShortName>Yahoo</ShortName>
<Description>Yahoo Search</Description>
<InputEncoding>UTF-8</InputEncoding>
<Image width="16" height="16"></Image>
<Url type="application/x-suggestions+json" method="GET"
     template="https://search.yahoo.com/sugg/ff">
  <Param name="output"  value="fxjson" />
  <Param name="appid"   value="ffd" />
  <Param name="command" value="{searchTerms}" />
</Url>
<Url type="text/html" method="GET" template="https://search.yahoo.com/yhs/search"
     resultdomain="yahoo.com" rel="searchform">
  <Param name="p" value="{searchTerms}"/>
  <Param name="ei" value="UTF-8"/>
  <Param name="hspart" value="mozilla"/>
</Url>
</SearchPlugin>
+6 −1
Original line number Diff line number Diff line
@@ -18,6 +18,7 @@ import mozilla.components.concept.toolbar.Toolbar.Highlight
import mozilla.components.concept.toolbar.Toolbar.SiteTrackingProtection
import mozilla.components.feature.toolbar.internal.URLRenderer
import mozilla.components.lib.state.ext.flowScoped
import mozilla.components.support.ktx.kotlin.isOnionUrl
import mozilla.components.support.ktx.kotlinx.coroutines.flow.ifChanged

/**
@@ -65,7 +66,11 @@ class ToolbarPresenter(
            toolbar.displayProgress(tab.content.progress)

            toolbar.siteSecure = if (tab.content.securityInfo.secure) {
                if (tab.content.url.isOnionUrl()) {
                    Toolbar.SiteSecurity.ONION
                } else {
                    Toolbar.SiteSecurity.SECURE
                }
            } else {
                Toolbar.SiteSecurity.INSECURE
            }
+5 −4
Original line number Diff line number Diff line
@@ -39,6 +39,7 @@ import mozilla.components.support.base.log.Log
import mozilla.components.support.base.log.logger.Logger
import mozilla.components.support.ktx.R
import mozilla.components.support.ktx.android.content.res.resolveAttribute
import mozilla.components.support.utils.TorUtils
import java.io.File

/**
@@ -110,7 +111,7 @@ fun Context.share(text: String, subject: String = getString(R.string.mozac_suppo
            flags = FLAG_ACTIVITY_NEW_TASK
        }

        startActivity(shareIntent)
        TorUtils.startActivityPrompt(this, shareIntent)
        true
    } catch (e: ActivityNotFoundException) {
        Log.log(Log.Priority.WARN, message = "No activity to share to found", throwable = e, tag = "Reference-Browser")
@@ -191,7 +192,7 @@ fun Context.email(
            flags = FLAG_ACTIVITY_NEW_TASK
        }

        startActivity(emailIntent)
        TorUtils.startActivityPrompt(this, emailIntent)
        true
    } catch (e: ActivityNotFoundException) {
        Logger.warn("No activity found to handle email intent", throwable = e)
@@ -222,7 +223,7 @@ fun Context.call(
            flags = FLAG_ACTIVITY_NEW_TASK
        }

        startActivity(callIntent)
        TorUtils.startActivityPrompt(this, callIntent)
        true
    } catch (e: ActivityNotFoundException) {
        Logger.warn("No activity found to handle dial intent", throwable = e)
@@ -250,7 +251,7 @@ fun Context.addContact(
            addFlags(FLAG_ACTIVITY_NEW_TASK)
        }

        startActivity(intent)
        TorUtils.startActivityPrompt(this, intent)
        true
    } catch (e: ActivityNotFoundException) {
        Logger.warn("No activity found to handle dial intent", throwable = e)
+9 −0
Original line number Diff line number Diff line
@@ -113,6 +113,15 @@ fun String.tryGetHostFromUrl(): String = try {
    this
}

/**
 * Returns whether the string is an .onion URL.
 */
fun String.isOnionUrl(): Boolean = try {
    URL(this).host.endsWith(".onion")
} catch (e: MalformedURLException) {
    false
}

/**
 * Compares 2 URLs and returns true if they have the same origin,
 * which means: same protocol, same host, same port.
+2 −2
Original line number Diff line number Diff line
@@ -93,7 +93,7 @@ sealed class Migration(val currentVersion: Int) {
    /**
     * Migrates all Fennec settings backed by SharedPreferences.
     */
    object Settings : Migration(currentVersion = 2)
    object Settings : Migration(currentVersion = 3)

    /**
     * Migrates / Disables all currently unsupported Add-ons.
@@ -989,7 +989,7 @@ class FennecMigrator private constructor(

        return try {
            logger.debug("Migrating gecko files...")
            val result = GeckoMigration.migrate(profile.path, migrationVersion)
            val result = GeckoMigration.migrate(profile.path, migrationVersion, context)
            logger.debug("Migrated gecko files.")

            if (result is Result.Failure<GeckoMigrationResult>) {
+2 −7
Original line number Diff line number Diff line
@@ -44,16 +44,11 @@ internal object FennecSettingsMigration {
        return migrateTelemetryOptInStatus(fennecAppPrefs, fenixAppPrefs)
    }

    @Suppress("UNUSED_PARAMETER")
    private fun migrateTelemetryOptInStatus(
        fennecPrefs: SharedPreferences,
        fenixPrefs: SharedPreferences
    ): Result<SettingsMigrationResult> {
        // Sanity check: make sure we actually have an FHR value set.
        if (!fennecPrefs.contains(FENNEC_PREFS_FHR_KEY)) {
            logger.warn("Missing FHR pref value")
            return Result.Failure(SettingsMigrationException(SettingsMigrationResult.Failure.MissingFHRPrefValue))
        }

        // Fennec has two telemetry settings:
        // - Firefox Health Report (FHR) - defaults to 'on',
        // - Telemetry - defaults to 'off'.
@@ -66,7 +61,7 @@ internal object FennecSettingsMigration {
        // If FHR is disabled by the user, we'll disable telemetry in Fenix. Otherwise, it will be enabled.

        // Read Fennec prefs.
        val fennecFHRState = fennecPrefs.getBoolean(FENNEC_PREFS_FHR_KEY, false)
        val fennecFHRState = false
        logger.info("Fennec FHR state is: $fennecFHRState")

        // Update Fenix prefs.
+26 −1
Original line number Diff line number Diff line
@@ -4,6 +4,7 @@

package mozilla.components.support.migration

import android.content.Context
import android.util.AtomicFile
import androidx.annotation.VisibleForTesting
import mozilla.components.support.ktx.util.writeString
@@ -12,6 +13,9 @@ import java.io.IOException

private const val PREFS_FILE = "prefs.js"
private const val PREFS_BACKUP_FILE = "prefs.js.backup.v"
private const val SEC_LEVEL_OFFSET = 50
private const val SEC_LEVEL_MIN = 0
private const val SEC_LEVEL_MAX = 4

@VisibleForTesting
internal var userPrefsToKeep = setOf("extensions.webextensions.uuids")
@@ -95,7 +99,8 @@ internal object GeckoMigration {
     */
    fun migrate(
        profilePath: String,
        migrationVersion: Int
        migrationVersion: Int,
        context: Context
    ): Result<GeckoMigrationResult> {
        // GeckoView will happily pick up the profile from Fennec and reuse all data in it. So this
        // migration is mostly focused on removing all prefs that we do not want to reuse.
@@ -118,6 +123,26 @@ internal object GeckoMigration {
            }.toList()
        }

        val secLevel = prefsjs.useLines {
            // The prefs are auto-generated, so we can expect the offset to be always the same
            it.find { line -> line.startsWith("$USER_PREF(\"extensions.torbutton.security_slider\"") }
                    ?.substring(SEC_LEVEL_OFFSET, SEC_LEVEL_OFFSET + 1)?.toIntOrNull()
        }

        if (secLevel != null && secLevel > SEC_LEVEL_MIN && secLevel < SEC_LEVEL_MAX) {
            val prefVal = when (secLevel) {
                1 -> "pref_key_tor_security_level_safest_option"
                else -> "pref_key_tor_security_level_safer_option"
            }
            val fenixAppPrefs = context.getSharedPreferences(
                FennecSettingsMigration.FENIX_SHARED_PREFS_NAME, Context.MODE_PRIVATE
            )
            fenixAppPrefs.edit()
                    .putBoolean("pref_key_tor_security_level_standard_option", false)
                    .putBoolean(prefVal, true)
                    .apply()
        }

        return if (transformed.isEmpty()) {
            removePrefsFile(prefsjs)
        } else {
+26 −0
Original line number Diff line number Diff line
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

package mozilla.components.support.utils

import android.app.PendingIntent
import android.content.Context
import android.content.Intent

object TorUtils {
    const val TORBROWSER_START_ACTIVITY_PROMPT = "torbrowser_start_activity_prompt"

    // Delegates showing prompt and possibly starting the activity to the main app activity.
    // Highly dependant on Fenix/Tor Browser for Android.
    // One downside of this implementation is that it does not throw exceptions like the
    // direct context.startActivity, so the UI will behave as if the startActivity call was
    // done successfully, which may not always be the case.
    fun startActivityPrompt(context: Context, intent: Intent) {
        val intentContainer = Intent()
        intentContainer.setPackage(context.applicationContext.packageName)
        intentContainer.putExtra(TORBROWSER_START_ACTIVITY_PROMPT, PendingIntent.getActivity(context, 0, intent, 0))
        intentContainer.flags = Intent.FLAG_ACTIVITY_NEW_TASK
        context.startActivity(intentContainer)
    }
}
+14 −0
Original line number Diff line number Diff line
<?xml version="1.0" encoding="utf-8"?>
<!-- This Source Code Form is subject to the terms of the Mozilla Public
   - License, v. 2.0. If a copy of the MPL was not distributed with this
   - file, You can obtain one at http://mozilla.org/MPL/2.0/. -->
<vector xmlns:android="http://schemas.android.com/apk/res/android"
        android:width="24dp"
        android:height="24dp"
        android:viewportWidth="24"
        android:viewportHeight="24">
    <path
        android:pathData="m12.0215,20.5903c0,0 0,-1.2728 0,-1.2728 4.0319,-0.0117 7.2965,-3.283 7.2965,-7.3177 0,-4.0345 -3.2646,-7.3058 -7.2965,-7.3175 0,0 0,-1.2728 0,-1.2728 4.7348,0.0119 8.5691,3.8529 8.5691,8.5903 0,4.7377 -3.8342,8.5789 -8.5691,8.5906 0,0 0,0 0,0m0,-4.4551c2.2741,-0.012 4.1148,-1.8582 4.1148,-4.1355 0,-2.277 -1.8407,-4.1233 -4.1148,-4.1352 0,0 0,-1.2726 0,-1.2726 2.9773,0.0116 5.3877,2.4278 5.3877,5.4078 0,2.9802 -2.4103,5.3964 -5.3877,5.408 0,0 0,-1.2725 0,-1.2725m0,-6.3616c1.2199,0.0116 2.2057,1.0033 2.2057,2.2261 0,1.2231 -0.9858,2.2147 -2.2057,2.2264 0,0 0,-4.4525 0,-4.4525M1.5,11.9997C1.5,17.799 6.2008,22.5 12,22.5 17.799,22.5 22.5,17.799 22.5,11.9997 22.5,6.2008 17.799,1.5 12,1.5 6.2008,1.5 1.5,6.2008 1.5,11.9997c0,0 0,0 0,0"
        android:strokeWidth="1.49999"
        android:fillColor="@color/mozac_ui_icons_fill"/>
</vector>
+2 −0
Original line number Diff line number Diff line
@@ -8,6 +8,7 @@
    <ID>ComplexMethod:Browsers.kt$Browsers$findKnownBrowsers</ID>
    <ID>ComplexMethod:Evaluator.kt$Evaluator$filterStatic</ID>
    <ID>ComplexMethod:ExperimentEvaluator.kt$ExperimentEvaluator$matches</ID>
    <ID>ComplexMethod:GeckoMigration.kt$GeckoMigration$migrate</ID>
    <ID>ComplexMethod:InlineAutocompleteEditText.kt$InlineAutocompleteEditText$addAutocompleteText</ID>
    <ID>ComplexMethod:InlineAutocompleteEditText.kt$InlineAutocompleteEditText.TextChangeListener$afterTextChanged</ID>
    <ID>ComplexMethod:LegacySessionManager.kt$LegacySessionManager$findNearbySession</ID>
@@ -253,6 +254,7 @@
    <ID>UndocumentedPublicClass:ToolbarFeature.kt$ToolbarFeature.RenderStyle$ColoredUrl : RenderStyle</ID>
    <ID>UndocumentedPublicClass:ToolbarFeature.kt$ToolbarFeature.RenderStyle$RegistrableDomain : RenderStyle</ID>
    <ID>UndocumentedPublicClass:ToolbarFeature.kt$ToolbarFeature.RenderStyle$UncoloredUrl : RenderStyle</ID>
    <ID>UndocumentedPublicClass:TorUtils.kt$TorUtils</ID>
    <ID>UndocumentedPublicClass:URLStringUtils.kt$URLStringUtils</ID>
    <ID>UndocumentedPublicClass:WebAppManifest.kt$WebAppManifest.Icon$Purpose</ID>
    <ID>UndocumentedPublicClass:WorkManagerSyncManager.kt$WorkManagerSyncDispatcher : SyncDispatcherObservableCloseable</ID>
+1 −0
Original line number Diff line number Diff line
@@ -70,6 +70,7 @@
                app:drawableStartCompat="@drawable/mozac_ic_permissions" />

        <androidx.appcompat.widget.SwitchCompat
            android:visibility="gone"
            android:id="@+id/allow_in_private_browsing_switch"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"