├── .github
└── ISSUE_TEMPLATE
│ ├── bug.yml
│ ├── config.yml
│ ├── enhancement.yml
│ └── other.yml
├── .gitignore
├── .gitlab-ci.yml
├── .gitlab
└── issue_templates
│ ├── default.md
│ ├── enhancement.md
│ └── other.md
├── Dockerfile
├── LICENSE
├── README.md
├── assets
├── accrescent.png
├── f-droid.png
├── f-droid_qr.png
├── ironfox.png
└── obtainium.png
├── patches
├── a-c-overlay
│ └── components
│ │ └── feature
│ │ └── search
│ │ └── src
│ │ └── main
│ │ └── assets
│ │ ├── search
│ │ └── list.json
│ │ └── searchplugins
│ │ ├── ddghtml.xml
│ │ ├── ddglite.xml
│ │ ├── leta-brave.xml
│ │ ├── leta-google.xml
│ │ ├── mojeek.xml
│ │ ├── no-search.xml
│ │ └── startpage.xml
├── allow-build-date-override.patch
├── block-autoplay-by-default.patch
├── block-cookie-banners.patch
├── branding.patch
├── certificate-pinning.patch
├── configure-doh.patch
├── disable-accessibility-services-by-default.patch
├── disable-autocomplete.patch
├── disable-autofill.patch
├── disable-cfrs.patch
├── disable-csp-reporting.patch
├── disable-default-browser-engagement-prompts.patch
├── disable-doh-canary.patch
├── disable-firefox-suggest.patch
├── disable-geoip.patch
├── disable-hls.patch
├── disable-link-sharing.patch
├── disable-microsurveys.patch
├── disable-nimbus.patch
├── disable-pocket.patch
├── disable-search-suggestions.patch
├── disable-shipped-domains.patch
├── disable-sync-by-default.patch
├── disable-telemetry.patch
├── domain-highlighting-and-alignment.patch
├── enable-light-mode-by-default.patch
├── enable-secret-settings.patch
├── expose-aboutconfig.patch
├── fenix-liberate.patch
├── fenix-overlay
│ ├── branding
│ │ ├── ic_launcher-web.webp
│ │ ├── ic_launcher_private-web.webp
│ │ └── res
│ │ │ ├── drawable-hdpi
│ │ │ ├── fenix_search_widget.webp
│ │ │ ├── ic_logo_wordmark_normal.webp
│ │ │ ├── ic_logo_wordmark_private.webp
│ │ │ ├── ic_wordmark_logo.webp
│ │ │ ├── ic_wordmark_text_normal.webp
│ │ │ └── ic_wordmark_text_private.webp
│ │ │ ├── drawable-mdpi
│ │ │ ├── ic_logo_wordmark_normal.webp
│ │ │ ├── ic_logo_wordmark_private.webp
│ │ │ ├── ic_wordmark_logo.webp
│ │ │ ├── ic_wordmark_text_normal.webp
│ │ │ └── ic_wordmark_text_private.webp
│ │ │ ├── drawable-xhdpi
│ │ │ ├── ic_logo_wordmark_normal.webp
│ │ │ ├── ic_logo_wordmark_private.webp
│ │ │ ├── ic_wordmark_logo.webp
│ │ │ ├── ic_wordmark_text_normal.webp
│ │ │ └── ic_wordmark_text_private.webp
│ │ │ ├── drawable-xxhdpi
│ │ │ ├── ic_logo_wordmark_normal.webp
│ │ │ ├── ic_logo_wordmark_private.webp
│ │ │ ├── ic_wordmark_logo.webp
│ │ │ ├── ic_wordmark_text_normal.webp
│ │ │ └── ic_wordmark_text_private.webp
│ │ │ ├── drawable-xxxhdpi
│ │ │ ├── ic_logo_wordmark_normal.webp
│ │ │ ├── ic_logo_wordmark_private.webp
│ │ │ ├── ic_wordmark_logo.webp
│ │ │ ├── ic_wordmark_text_normal.webp
│ │ │ └── ic_wordmark_text_private.webp
│ │ │ ├── drawable
│ │ │ ├── ic_launcher_foreground.xml
│ │ │ ├── ic_launcher_monochrome.xml
│ │ │ └── ic_launcher_private_foreground.xml
│ │ │ ├── mipmap-anydpi-v26
│ │ │ ├── ic_launcher.xml
│ │ │ ├── ic_launcher_private.xml
│ │ │ ├── ic_launcher_private_round.xml
│ │ │ └── ic_launcher_round.xml
│ │ │ ├── mipmap-hdpi
│ │ │ ├── ic_launcher.webp
│ │ │ ├── ic_launcher_private.webp
│ │ │ ├── ic_launcher_private_round.webp
│ │ │ └── ic_launcher_round.webp
│ │ │ ├── mipmap-mdpi
│ │ │ ├── ic_launcher.webp
│ │ │ ├── ic_launcher_private.webp
│ │ │ ├── ic_launcher_private_round.webp
│ │ │ └── ic_launcher_round.webp
│ │ │ ├── mipmap-xhdpi
│ │ │ ├── ic_launcher.webp
│ │ │ ├── ic_launcher_private.webp
│ │ │ ├── ic_launcher_private_round.webp
│ │ │ └── ic_launcher_round.webp
│ │ │ ├── mipmap-xxhdpi
│ │ │ ├── ic_launcher.webp
│ │ │ ├── ic_launcher_private.webp
│ │ │ ├── ic_launcher_private_round.webp
│ │ │ └── ic_launcher_round.webp
│ │ │ ├── mipmap-xxxhdpi
│ │ │ ├── ic_launcher.webp
│ │ │ ├── ic_launcher_private.webp
│ │ │ ├── ic_launcher_private_round.webp
│ │ │ └── ic_launcher_round.webp
│ │ │ └── values
│ │ │ ├── ic_launcher_background.xml
│ │ │ └── ic_launcher_private_background.xml
│ └── initial_experiments
│ │ └── initial_experiments.json
├── force-enable-zoom.patch
├── gecko-fix-125-compile.patch
├── gecko-liberate.patch
├── gecko-localize_maven.patch
├── gecko-overlay
│ ├── branding
│ │ └── ironfox
│ │ │ ├── configure.sh
│ │ │ ├── content
│ │ │ ├── favicon32.png
│ │ │ ├── favicon64.png
│ │ │ ├── jar.mn
│ │ │ └── moz.build
│ │ │ ├── locales
│ │ │ ├── en-US
│ │ │ │ ├── brand.ftl
│ │ │ │ └── brand.properties
│ │ │ ├── jar.mn
│ │ │ └── moz.build
│ │ │ └── moz.build
│ ├── rfptargets
│ │ └── RFPTargetsDefault.inc
│ └── rs-dumps
│ │ └── main
│ │ └── ironfox-fingerprinting-protection-overrides.json
├── global-privacy-control.patch
├── harden-pdfjs.patch
├── https_only.patch
├── include-fonts.patch
├── install-ublock.patch
├── ironfox-content-settings.patch
├── ironfox-fingerprinting-protection-overrides.patch
├── ironfox-static-strings.patch
├── js-settings.patch
├── librewolf-rs-blocker.patch
├── locales
├── preferences
│ ├── ironfox.js
│ ├── pdf.js
│ ├── phoenix-extended.js
│ └── phoenix.js
├── prevent-extensions-from-changing-browser-settings.patch
├── remote-debugging.patch
├── remove-autoconfig-dependency.patch
├── remove-default-sites.patch
├── remove-webcompat-reporter.patch
├── restrict-mozaddonmanager.patch
├── rs-dumps.patch
├── safe-browsing.patch
├── sanitize-on-exit.patch
├── search-engines.patch
├── strict_etp.patch
├── tor-spoof-english.patch
└── ublock-assets.patch
├── pyrightconfig.json
├── scripts
├── build.sh
├── ci-build.sh
├── ci-publish-packages.sh
├── ci-update-fdroid.sh
├── ci-update-site.sh
├── env_common.sh
├── env_fdroid.sh
├── gen_wordmark.sh
├── get_latest_version.py
├── get_sources.sh
├── localize_maven.py
├── patches.sh
├── patches.yaml
├── prebuild.sh
├── setup-android-sdk.sh
└── versions.sh
└── uBlock
├── assets.dev.json
└── assets.main.json
/.github/ISSUE_TEMPLATE/bug.yml:
--------------------------------------------------------------------------------
1 | name: Bug
2 | description: For any general issues or unexpected/unintended behavior you come across while using IronFox.
3 | title: "[BUG] PLEASE REPLACE THIS TEXT WITH A SUMMARY OF YOUR ISSUE..."
4 | labels: ["bug"]
5 | body:
6 | - type: textarea
7 | id: version
8 | attributes:
9 | label: What version of IronFox are you using?
10 | description: |
11 | An easy way to tell is by navigating to `Settings` -> `About` -> `About IronFox`.
12 | validations:
13 | required: true
14 |
15 | - type: textarea
16 | id: android
17 | attributes:
18 | label: What version of Android are you using with IronFox?
19 | description: |
20 | Steps will vary depending on your OEM, but on AOSP, this can be typically be found by navigating to your `Settings` app -> `About (`phone` or `tablet`, depending on your device)` -> `Device details` -> `Android version`.
21 | validations:
22 | required: true
23 |
24 | - type: textarea
25 | id: reason
26 | attributes:
27 | label: Please explain the issue you are experiencing.
28 | description: |
29 | Be sure to include as many relevant details as possible! :)
30 | validations:
31 | required: true
32 |
--------------------------------------------------------------------------------
/.github/ISSUE_TEMPLATE/config.yml:
--------------------------------------------------------------------------------
1 | blank_issues_enabled: false
2 | contact_links:
3 | - name: Web Compat (Codeberg)
4 | url: https://codeberg.org/celenity/Phoenix/issues/new?template=.github%2fISSUE_TEMPLATE%2fweb-compat.yml
5 | about: Please report issues with breakage or unexpected/unintended behavior on specific websites here.
6 | - name: Web Compat (GitLab)
7 | url: https://gitlab.com/celenityy/Phoenix/-/issues/new?issuable_template=web-compat#
8 | about: Please report issues with breakage or unexpected/unintended behavior on specific websites here.
9 | - name: Web Compat (GitHub)
10 | url: https://github.com/celenityy/Phoenix/issues
11 | about: Please report issues with breakage or unexpected/unintended behavior on specific websites here.
12 |
--------------------------------------------------------------------------------
/.github/ISSUE_TEMPLATE/enhancement.yml:
--------------------------------------------------------------------------------
1 | name: Enhancement
2 | description: Have any new features you want to see or any ideas to make IronFox better? Here's your place ;)
3 | title: "[ENHANCEMENT] PLEASE REPLACE THIS TEXT WITH A SUMMARY OF YOUR SUGGESTION..."
4 | labels: ["enhancement"]
5 | body:
6 | - type: textarea
7 | id: reason
8 | attributes:
9 | label: Please explain your proposal with as many details as necessary (Ex. what you're suggesting, why you're suggesting it, what need you thinks it will fill, who it will benefit, etc...).
10 | validations:
11 | required: true
12 |
--------------------------------------------------------------------------------
/.github/ISSUE_TEMPLATE/other.yml:
--------------------------------------------------------------------------------
1 | name: Other
2 | description: Anything else not already covered by other categories.
3 | title: "[OTHER] PLEASE REPLACE THIS TEXT WITH A SUMMARY OF YOUR ISSUE..."
4 | labels: ["other"]
5 | body:
6 | - type: textarea
7 | id: reason
8 | attributes:
9 | label: Please explain your inquiry.
10 | validations:
11 | required: true
12 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | __pycache__
2 |
3 | /env
4 | /build
5 | /gecko
6 | /glean
7 | /appservices
8 | /gmscore
9 | /wasi-sdk
10 | /scripts/env_local.sh
11 | .DS_Store
12 |
--------------------------------------------------------------------------------
/.gitlab-ci.yml:
--------------------------------------------------------------------------------
1 | .build_setup_steps: &build_setup_steps
2 | before_script:
3 | - mkdir -p "$GRADLE_USER_HOME"
4 | - mkdir -p "$CARGO_HOME"
5 | - mkdir -p /opt/IronFox
6 | - echo "$SB_GAPI_KEY" > "$SB_GAPI_KEY_FILE"
7 | - |
8 | curl \
9 | --request GET \
10 | --header "JOB-TOKEN: $CI_JOB_TOKEN" \
11 | "${CI_API_V4_URL}/projects/$CI_PROJECT_ID/secure_files/$KEYSTORE_SECFILEID/download" \
12 | --output "$KEYSTORE"
13 |
14 | .build_cache: &build_cache
15 | - key: cache-cargo-$CI_COMMIT_REF_SLUG
16 | policy: pull-push
17 | paths:
18 | # Cargo cache
19 | # See: https://doc.rust-lang.org/cargo/guide/cargo-home.html#caching-the-cargo-home-in-ci
20 | - .cache/cargo/.crates.toml
21 | - .cache/cargo/.crates2.json
22 | - .cache/cargo/bin/
23 | - .cache/cargo/registry/index/
24 | - .cache/cargo/registry/cache/
25 | - .cache/cargo/git/db/
26 | - key: cache-gradle-$CI_COMMIT_REF_SLUG
27 | policy: pull-push
28 | paths:
29 | - .cache/gradle/caches
30 | - .cache/gradle/wrapper
31 |
32 | default:
33 | cache: []
34 |
35 | variables: &build_variables
36 | PRODUCTION_BRANCH: main
37 | SB_GAPI_KEY_FILE: /opt/IronFox/sb-gapi.data
38 | KEYSTORE: /opt/IronFox/signing-key.jks
39 | GRADLE_USER_HOME: "$CI_PROJECT_DIR/.cache/gradle"
40 | CARGO_HOME: "$CI_PROJECT_DIR/.cache/cargo"
41 | BUNDLETOOL: 1.18.0
42 |
43 | stages:
44 | - build_fdroid
45 | - build_site
46 | - build_docker
47 | - build_ironfox
48 | - release
49 |
50 | update-fdroid-repo:
51 | image: fedora:42
52 | stage: build_fdroid
53 | rules:
54 | - if: $CI_COMMIT_TAG
55 | variables:
56 | TARGET_REPO_PATH: ironfox-oss/fdroid
57 | TARGET_REPO_BRANCH: dev
58 | META_FILE: "./fdroid/metadata/org.ironfoxoss.ironfox.yml"
59 | REPO_DIR: "./fdroid/repo"
60 | <<: *build_variables
61 | before_script:
62 | - sudo dnf install -y bash curl git jq make python3 python3-pip
63 | - pip install androguard
64 | - git config --global user.email "ci@ironfoxoss.org"
65 | - git config --global user.name "IronFox CI"
66 | script:
67 | - bash -x scripts/ci-update-fdroid.sh
68 |
69 | update-site-repo:
70 | image: fedora:42
71 | stage: build_site
72 | rules:
73 | - if: $CI_COMMIT_TAG
74 | - if: $CI_COMMIT_BRANCH == "dev"
75 | changes:
76 | - scripts/patches.yaml
77 | - scripts/ci-update-site.sh
78 | variables:
79 | TARGET_REPO_PATH: ironfox-oss/ironfoxoss.org
80 | TARGET_REPO_BRANCH: dev
81 | <<: *build_variables
82 | before_script:
83 | - sudo dnf install -y bash curl git make python3 python3-pip yq
84 | - pip install pyyaml
85 | - git config --global user.email "ci@ironfoxoss.org"
86 | - git config --global user.name "IronFox CI"
87 | script:
88 | - bash -x scripts/ci-update-site.sh
89 |
90 | build-docker:
91 | image: docker:cli
92 | stage: build_docker
93 | services:
94 | - docker:dind
95 | variables:
96 | DOCKER_IMAGE_NAME: $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
97 | before_script:
98 | - docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY
99 | script:
100 | - docker build --pull -t "$DOCKER_IMAGE_NAME" .
101 | - docker push "$DOCKER_IMAGE_NAME"
102 | - |
103 | if [[ "$CI_COMMIT_BRANCH" == "$CI_DEFAULT_BRANCH" ]]; then
104 | docker tag "$DOCKER_IMAGE_NAME" "$CI_REGISTRY_IMAGE:latest"
105 | docker push "$CI_REGISTRY_IMAGE:latest"
106 | fi
107 | rules:
108 | - if: $CI_COMMIT_BRANCH
109 | exists:
110 | - Dockerfile
111 | changes:
112 | - Dockerfile
113 | - .gitlab-ci.yml
114 | - scripts/setup-android-sdk.sh
115 | - if: $CI_COMMIT_BRANCH == $PRODUCTION_BRANCH
116 |
117 | build-apk:
118 | image: $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
119 | stage: build_ironfox
120 | timeout: 2h
121 | needs:
122 | - job: "build-docker"
123 | optional: true
124 | tags:
125 | - saas-linux-xlarge-amd64
126 | parallel:
127 | matrix:
128 | - BUILD_VARIANT: ["arm", "arm64", "x86_64"]
129 | variables:
130 | <<: *build_variables
131 | <<: *build_setup_steps
132 | script:
133 | - bash -x scripts/ci-build.sh
134 | artifacts:
135 | untracked: false
136 | when: on_success
137 | access: all
138 | expire_in: "30 days"
139 | paths:
140 | - $CI_PROJECT_DIR/artifacts/apk/**/*
141 | - $CI_PROJECT_DIR/artifacts/aar/**/*
142 | rules:
143 | - changes:
144 | - patches/**/*
145 | - scripts/**/*
146 | - Dockerfile
147 | - .gitlab-ci.yml
148 | - if: $CI_COMMIT_TAG
149 | when: never
150 |
151 | build-bundle:
152 | image: $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
153 | stage: build_ironfox
154 | timeout: 2h
155 | needs:
156 | - job: "build-docker"
157 | optional: true
158 | - job: "build-apk"
159 | artifacts: true
160 | optional: false
161 | tags:
162 | - saas-linux-xlarge-amd64
163 | variables:
164 | BUILD_VARIANT: "bundle"
165 | <<: *build_variables
166 | <<: *build_setup_steps
167 | script:
168 | - bash -x scripts/ci-build.sh
169 | artifacts:
170 | untracked: false
171 | when: on_success
172 | access: all
173 | expire_in: "30 days"
174 | paths:
175 | - $CI_PROJECT_DIR/artifacts/apks/**/*
176 | rules:
177 | - changes:
178 | - patches/**/*
179 | - scripts/**/*
180 | - Dockerfile
181 | - .gitlab-ci.yml
182 | - if: $CI_COMMIT_TAG
183 | when: never
184 |
185 | prepare-release:
186 | image: alpine:latest
187 | stage: release
188 | interruptible: true
189 | needs:
190 | - job: "build-docker"
191 | optional: true
192 | - job: "build-apk"
193 | artifacts: true
194 | optional: true
195 | - job: "build-bundle"
196 | artifacts: true
197 | optional: true
198 | rules:
199 | - if: $CI_COMMIT_TAG
200 | when: never
201 | - if: $CI_COMMIT_BRANCH == $PRODUCTION_BRANCH
202 | variables:
203 | <<: *build_variables
204 | before_script:
205 | - apk add --update --no-cache bash curl jq
206 | script:
207 | - bash -x scripts/ci-publish-packages.sh
208 | artifacts:
209 | untracked: false
210 | when: on_success
211 | access: all
212 | expire_in: "30 days"
213 | paths:
214 | - build/release.yml
215 |
216 | publish-release:
217 | image: registry.gitlab.com/gitlab-org/release-cli:latest
218 | stage: release
219 | interruptible: true
220 | needs:
221 | - job: "prepare-release"
222 | artifacts: true
223 | optional: false
224 | rules:
225 | - if: $CI_COMMIT_TAG
226 | when: never
227 | - if: $CI_COMMIT_BRANCH == $PRODUCTION_BRANCH
228 | variables:
229 | <<: *build_variables
230 | script:
231 | - |
232 | release-cli \
233 | --server-url "$CI_SERVER_URL" \
234 | --project-id "$CI_PROJECT_ID" \
235 | --private-token "$GITLAB_CI_API_TOKEN" \
236 | create-from-file \
237 | --file build/release.yml
238 |
--------------------------------------------------------------------------------
/.gitlab/issue_templates/default.md:
--------------------------------------------------------------------------------
1 | # BUG
2 |
3 |
19 |
20 | ### Confirmation
21 |
23 |
24 |
26 |
27 | ### Version
28 |
32 |
33 | ### Android
34 |
38 |
39 | ### Reason
40 |
44 |
--------------------------------------------------------------------------------
/.gitlab/issue_templates/enhancement.md:
--------------------------------------------------------------------------------
1 | # ENHANCEMENT
2 |
3 |
9 |
10 | ___
11 |
12 |
14 |
--------------------------------------------------------------------------------
/.gitlab/issue_templates/other.md:
--------------------------------------------------------------------------------
1 | # OTHER
2 |
3 |
9 |
10 | ___
11 |
12 |
14 |
--------------------------------------------------------------------------------
/Dockerfile:
--------------------------------------------------------------------------------
1 | FROM fedora:42
2 |
3 | # Add & enable Adoptium Repository
4 | RUN dnf install -y adoptium-temurin-java-repository && \
5 | dnf config-manager setopt adoptium-temurin-java-repository.enabled=1
6 |
7 | # Install required packages
8 | RUN dnf install -y \
9 | cmake \
10 | clang \
11 | gawk \
12 | git \
13 | gyp \
14 | temurin-17-jdk \
15 | m4 \
16 | make \
17 | nasm \
18 | ninja-build \
19 | patch \
20 | perl \
21 | python3.9 \
22 | shasum \
23 | wget \
24 | xz \
25 | yq \
26 | zlib-devel
27 |
28 | ENV ENVDOCKER=/opt/env_docker.sh
29 | ENV ANDROID_HOME=/root/android-sdk
30 | ENV JAVA_HOME=/usr/lib/jvm/temurin-17-jdk
31 |
32 | RUN echo "#!/bin/bash" >> $ENVDOCKER && \
33 | echo 'source /root/env/bin/activate' >> $ENVDOCKER
34 |
35 | # Set up Android SDK
36 | COPY scripts/setup-android-sdk.sh /tmp/setup-android-sdk.sh
37 | RUN bash -x /tmp/setup-android-sdk.sh && \
38 | echo "export ANDROID_HOME=$ANDROID_HOME" >> $ENVDOCKER && \
39 | echo "export ANDROID_SDK_ROOT=\$ANDROID_HOME" >> $ENVDOCKER
40 |
41 | # Set up gradle from F-Droid
42 | RUN mkdir -p /root/bin
43 | ADD https://gitlab.com/fdroid/fdroidserver/-/raw/master/gradlew-fdroid /root/bin/gradle
44 | RUN chmod +x "/root/bin/gradle" && \
45 | echo "export PATH=\$PATH:/root/bin" >> $ENVDOCKER
46 |
47 | # Set up Python virtual environment
48 | RUN python3.9 -m venv /root/env
49 |
50 | # Set JDK 17 as default
51 | RUN echo "export JAVA_HOME=$JAVA_HOME" >> $ENVDOCKER && \
52 | echo "export PATH=$JAVA_HOME/bin:/root/bin:/root/env/bin:\${PATH}" >> $ENVDOCKER
53 |
54 | # cd into working directory
55 | WORKDIR /app
56 |
57 | # Create entrypoint script to activate Python venv
58 | ENV ENTRYPOINT=/opt/entrypoint.sh
59 | RUN echo '#!/bin/bash' > $ENTRYPOINT && \
60 | echo "source $ENVDOCKER" >> $ENTRYPOINT && \
61 | echo 'exec "$@"' >> $ENTRYPOINT && \
62 | chmod +x $ENTRYPOINT
63 |
64 | ENTRYPOINT ["/opt/entrypoint.sh"]
65 | CMD ["/bin/bash"]
66 |
67 |
--------------------------------------------------------------------------------
/assets/accrescent.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/assets/accrescent.png
--------------------------------------------------------------------------------
/assets/f-droid.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/assets/f-droid.png
--------------------------------------------------------------------------------
/assets/f-droid_qr.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/assets/f-droid_qr.png
--------------------------------------------------------------------------------
/assets/ironfox.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/assets/ironfox.png
--------------------------------------------------------------------------------
/assets/obtainium.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/assets/obtainium.png
--------------------------------------------------------------------------------
/patches/a-c-overlay/components/feature/search/src/main/assets/searchplugins/ddghtml.xml:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 | DuckDuckGo (HTML)
7 | UTF-8
8 | 
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 | https://html.duckduckgo.com/html
21 |
22 |
--------------------------------------------------------------------------------
/patches/a-c-overlay/components/feature/search/src/main/assets/searchplugins/ddglite.xml:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 | DuckDuckGo (Lite)
7 | UTF-8
8 | 
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 | https://lite.duckduckgo.com/lite
21 |
22 |
--------------------------------------------------------------------------------
/patches/a-c-overlay/components/feature/search/src/main/assets/searchplugins/mojeek.xml:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 | Mojeek
7 | UTF-8
8 | 
9 |
10 |
11 |
12 | https://www.mojeek.com/
13 |
14 |
--------------------------------------------------------------------------------
/patches/a-c-overlay/components/feature/search/src/main/assets/searchplugins/no-search.xml:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 | No Search
7 | UTF-8
8 |
9 |
10 |
11 | https://nosearch.invalid/
12 |
13 |
--------------------------------------------------------------------------------
/patches/a-c-overlay/components/feature/search/src/main/assets/searchplugins/startpage.xml:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 | Startpage
7 | UTF-8
8 | 
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 | https://www.startpage.com/
20 |
21 |
--------------------------------------------------------------------------------
/patches/allow-build-date-override.patch:
--------------------------------------------------------------------------------
1 | From 7a7b1a0060d89ddf1f705b0e179de6bc30b9197f Mon Sep 17 00:00:00 2001
2 | From: Akash Yadav
3 | Date: Sun, 18 May 2025 02:17:20 +0530
4 | Subject: [PATCH] fix: allow overriding build date using system env
5 |
6 | Signed-off-by: Akash Yadav
7 | ---
8 | .../plugins/config/src/main/java/ConfigPlugin.kt | 8 +++++++-
9 | 1 file changed, 7 insertions(+), 1 deletion(-)
10 |
11 | diff --git a/mobile/android/android-components/plugins/config/src/main/java/ConfigPlugin.kt b/mobile/android/android-components/plugins/config/src/main/java/ConfigPlugin.kt
12 | index 4e86c3c8e3..252c605887 100644
13 | --- a/mobile/android/android-components/plugins/config/src/main/java/ConfigPlugin.kt
14 | +++ b/mobile/android/android-components/plugins/config/src/main/java/ConfigPlugin.kt
15 | @@ -71,7 +71,13 @@ object Config {
16 | private val fennecBaseVersionCode by lazy {
17 | val format = SimpleDateFormat("yyyyMMddHHmmss", Locale.US)
18 | val cutoff = format.parse("20141228000000")
19 | - val build = Date()
20 | + var build = Date()
21 | +
22 | + val buildDate = System.getenv("IF_BUILD_DATE")
23 | + if (!buildDate.isNullOrBlank()) {
24 | + println("[IronFox] Overriding build date to: '$buildDate'")
25 | + build = Date.from(java.time.Instant.parse(buildDate))
26 | + }
27 |
28 | Math.floor((build.time - cutoff.time) / (1000.0 * 60.0 * 60.0)).toInt()
29 | }
30 | --
31 | 2.49.0
32 |
33 |
--------------------------------------------------------------------------------
/patches/block-autoplay-by-default.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
2 | index 72493a2c21..e3b98da6c4 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
5 | @@ -1305,7 +1305,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
6 | * either [AUTOPLAY_ALLOW_ALL] or [AUTOPLAY_BLOCK_ALL]. Because of this, we are forced to save
7 | * the user selected setting as well.
8 | */
9 | - fun getAutoplayUserSetting() = preferences.getInt(AUTOPLAY_USER_SETTING, AUTOPLAY_BLOCK_AUDIBLE)
10 | + fun getAutoplayUserSetting() = preferences.getInt(AUTOPLAY_USER_SETTING, AUTOPLAY_BLOCK_ALL)
11 |
12 | private fun getSitePermissionsPhoneFeatureAutoplayAction(
13 | feature: PhoneFeature,
14 | @@ -1334,7 +1334,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
15 | ),
16 | autoplayInaudible = getSitePermissionsPhoneFeatureAutoplayAction(
17 | feature = PhoneFeature.AUTOPLAY_INAUDIBLE,
18 | - default = AutoplayAction.ALLOWED,
19 | + default = AutoplayAction.BLOCKED,
20 | ),
21 | persistentStorage = getSitePermissionsPhoneFeatureAction(PhoneFeature.PERSISTENT_STORAGE),
22 | crossOriginStorageAccess = getSitePermissionsPhoneFeatureAction(PhoneFeature.CROSS_ORIGIN_STORAGE_ACCESS),
23 |
--------------------------------------------------------------------------------
/patches/block-cookie-banners.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
2 | index 72493a2c21..c62c18809d 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
5 | @@ -757,20 +757,17 @@ class Settings(private val appContext: Context) : PreferencesHolder {
6 | false,
7 | )
8 |
9 | - var shouldUseCookieBannerPrivateMode by lazyFeatureFlagPreference(
10 | + var shouldUseCookieBannerPrivateMode by booleanPreference(
11 | appContext.getPreferenceKey(R.string.pref_key_cookie_banner_private_mode),
12 | - featureFlag = true,
13 | - default = { shouldUseCookieBannerPrivateModeDefaultValue },
14 | + default = true,
15 | )
16 |
17 | - val shouldUseCookieBannerPrivateModeDefaultValue: Boolean
18 | - get() = cookieBannersSection[CookieBannersSection.FEATURE_SETTING_VALUE_PBM] == 1
19 | + val shouldUseCookieBannerPrivateModeDefaultValue: Boolean = true
20 |
21 | val shouldUseCookieBanner: Boolean
22 | get() = cookieBannersSection[CookieBannersSection.FEATURE_SETTING_VALUE] == 1
23 |
24 | - val shouldShowCookieBannerUI: Boolean
25 | - get() = cookieBannersSection[CookieBannersSection.FEATURE_UI] == 1
26 | + val shouldShowCookieBannerUI: Boolean = true
27 |
28 | val shouldEnableCookieBannerDetectOnly: Boolean
29 | get() = cookieBannersSection[CookieBannersSection.FEATURE_SETTING_DETECT_ONLY] == 1
30 | diff --git a/mobile/android/fenix/app/src/main/res/xml/preferences.xml b/mobile/android/fenix/app/src/main/res/xml/preferences.xml
31 | index 4c6b14bf87..2e4227a392 100644
32 | --- a/mobile/android/fenix/app/src/main/res/xml/preferences.xml
33 | +++ b/mobile/android/fenix/app/src/main/res/xml/preferences.xml
34 | @@ -113,7 +113,7 @@
35 |
41 |
42 |
20 |
26 |
27 |
--------------------------------------------------------------------------------
/patches/disable-autofill.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
2 | index 72493a2c21..c0116767c7 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
5 | @@ -1385,12 +1385,12 @@ class Settings(private val appContext: Context) : PreferencesHolder {
6 |
7 | var shouldPromptToSaveLogins by booleanPreference(
8 | appContext.getPreferenceKey(R.string.pref_key_save_logins),
9 | - default = true,
10 | + default = false,
11 | )
12 |
13 | var shouldAutofillLogins by booleanPreference(
14 | appContext.getPreferenceKey(R.string.pref_key_autofill_logins),
15 | - default = true,
16 | + default = false,
17 | )
18 |
19 | /**
20 | @@ -1722,7 +1722,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
21 | */
22 | var shouldAutofillCreditCardDetails by booleanPreference(
23 | appContext.getPreferenceKey(R.string.pref_key_credit_cards_save_and_autofill_cards),
24 | - default = true,
25 | + default = false,
26 | )
27 |
28 | /**
29 | @@ -1733,7 +1733,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
30 | */
31 | var shouldAutofillAddressDetails by booleanPreference(
32 | appContext.getPreferenceKey(R.string.pref_key_addresses_save_and_autofill_addresses),
33 | - default = true,
34 | + default = false,
35 | )
36 |
37 | /**
38 | diff --git a/mobile/android/fenix/app/src/main/res/xml/autofill_preferences.xml b/mobile/android/fenix/app/src/main/res/xml/autofill_preferences.xml
39 | index aa1efa9665..1ccfc1fefa 100644
40 | --- a/mobile/android/fenix/app/src/main/res/xml/autofill_preferences.xml
41 | +++ b/mobile/android/fenix/app/src/main/res/xml/autofill_preferences.xml
42 | @@ -10,7 +10,7 @@
43 | android:title="@string/preferences_addresses">
44 |
45 |
51 | @@ -23,7 +23,7 @@
52 | android:layout="@layout/preference_cat_style"
53 | android:title="@string/preferences_credit_cards_2">
54 |
60 | diff --git a/mobile/android/fenix/app/src/main/res/xml/credit_cards_preferences.xml b/mobile/android/fenix/app/src/main/res/xml/credit_cards_preferences.xml
61 | index 00caf8e1bb..b4efbb89a5 100644
62 | --- a/mobile/android/fenix/app/src/main/res/xml/credit_cards_preferences.xml
63 | +++ b/mobile/android/fenix/app/src/main/res/xml/credit_cards_preferences.xml
64 | @@ -5,7 +5,7 @@
65 |
67 |
73 | diff --git a/mobile/android/fenix/app/src/main/res/xml/logins_preferences.xml b/mobile/android/fenix/app/src/main/res/xml/logins_preferences.xml
74 | index 1a8810eca7..1f3ad71295 100644
75 | --- a/mobile/android/fenix/app/src/main/res/xml/logins_preferences.xml
76 | +++ b/mobile/android/fenix/app/src/main/res/xml/logins_preferences.xml
77 | @@ -9,7 +9,7 @@
78 | android:summary="@string/preferences_passwords_save_logins_ask_to_save"
79 | android:title="@string/preferences_passwords_save_logins_2" />
80 |
86 | diff --git a/mobile/android/fenix/app/src/main/res/xml/save_logins_preferences.xml b/mobile/android/fenix/app/src/main/res/xml/save_logins_preferences.xml
87 | index 3fc38f2070..1c88040284 100644
88 | --- a/mobile/android/fenix/app/src/main/res/xml/save_logins_preferences.xml
89 | +++ b/mobile/android/fenix/app/src/main/res/xml/save_logins_preferences.xml
90 | @@ -4,11 +4,11 @@
91 | - file, You can obtain one at http://mozilla.org/MPL/2.0/. -->
92 |
93 |
98 |
103 |
104 |
--------------------------------------------------------------------------------
/patches/disable-cfrs.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/nimbus.fml.yaml b/mobile/android/fenix/app/nimbus.fml.yaml
2 | index 1a47d3dcdf..4f056022c1 100644
3 | --- a/mobile/android/fenix/app/nimbus.fml.yaml
4 | +++ b/mobile/android/fenix/app/nimbus.fml.yaml
5 | @@ -103,10 +103,10 @@ features:
6 | default:
7 | {
8 | "home-onboarding-dialog-existing-users": true,
9 | - "sync-cfr": true,
10 | + "sync-cfr": false,
11 | "wallpapers-selection-tool": true,
12 | - "jump-back-in-cfr": true,
13 | - "tcp-cfr": true,
14 | + "jump-back-in-cfr": false,
15 | + "tcp-cfr": false,
16 | "tcp-feature": true,
17 | }
18 | defaults:
19 | @@ -114,9 +114,9 @@ features:
20 | value: {
21 | "sections-enabled": {
22 | "home-onboarding-dialog-existing-users": true,
23 | - "sync-cfr": true,
24 | + "sync-cfr": false,
25 | "wallpapers-selection-tool": true,
26 | - "jump-back-in-cfr": true,
27 | + "jump-back-in-cfr": false,
28 | }
29 | }
30 | query-parameter-stripping:
31 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
32 | index 72493a2c21..27da6ea281 100644
33 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
34 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
35 | @@ -210,8 +210,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
36 | default = 0L,
37 | )
38 |
39 | - val canShowCfr: Boolean
40 | - get() = (System.currentTimeMillis() - lastCfrShownTimeInMillis) > THREE_DAYS_MS
41 | + val canShowCfr: Boolean = false
42 |
43 | var forceEnableZoom by booleanPreference(
44 | appContext.getPreferenceKey(R.string.pref_key_accessibility_force_enable_zoom),
45 | @@ -910,30 +909,16 @@ class Settings(private val appContext: Context) : PreferencesHolder {
46 | /**
47 | * Indicates if the total cookie protection CRF should be shown.
48 | */
49 | - var shouldShowEraseActionCFR by lazyFeatureFlagPreference(
50 | - appContext.getPreferenceKey(R.string.pref_key_should_show_erase_action_popup),
51 | - featureFlag = true,
52 | - default = { feltPrivateBrowsingEnabled },
53 | - )
54 | + var shouldShowEraseActionCFR = false
55 |
56 | /**
57 | * Indicates if the cookie banners CRF should be shown.
58 | */
59 | - var shouldShowCookieBannersCFR by lazyFeatureFlagPreference(
60 | - appContext.getPreferenceKey(R.string.pref_key_should_show_cookie_banners_action_popup),
61 | - featureFlag = true,
62 | - default = { shouldShowCookieBannerUI },
63 | - )
64 | + var shouldShowCookieBannersCFR = false
65 |
66 | - var shouldShowTabSwipeCFR by booleanPreference(
67 | - appContext.getPreferenceKey(R.string.pref_key_toolbar_tab_swipe_cfr),
68 | - default = false,
69 | - )
70 | + var shouldShowTabSwipeCFR = false
71 |
72 | - var hasShownTabSwipeCFR by booleanPreference(
73 | - appContext.getPreferenceKey(R.string.pref_key_toolbar_has_shown_tab_swipe_cfr),
74 | - default = false,
75 | - )
76 | + var hasShownTabSwipeCFR = false
77 |
78 | val blockCookiesSelectionInCustomTrackingProtection by stringPreference(
79 | key = appContext.getPreferenceKey(R.string.pref_key_tracking_protection_custom_cookies_select),
80 | @@ -1211,23 +1196,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
81 | private val userNeedsToVisitInstallableSites: Boolean
82 | get() = pwaInstallableVisitCount.underMaxCount()
83 |
84 | - val shouldShowPwaCfr: Boolean
85 | - get() {
86 | - if (!canShowCfr) return false
87 | - // We only want to show this on the 3rd time a user visits a site
88 | - if (userNeedsToVisitInstallableSites) return false
89 | -
90 | - // ShortcutManager::pinnedShortcuts is only available on Oreo+
91 | - if (!userKnowsAboutPwas && Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
92 | - val manager = appContext.getSystemService(ShortcutManager::class.java)
93 | - val alreadyHavePwaInstalled = manager != null && manager.pinnedShortcuts.size > 0
94 | -
95 | - // Users know about PWAs onboarding if they already have PWAs installed.
96 | - userKnowsAboutPwas = alreadyHavePwaInstalled
97 | - }
98 | - // Show dialog only if user does not know abut PWAs
99 | - return !userKnowsAboutPwas
100 | - }
101 | + val shouldShowPwaCfr: Boolean = false
102 |
103 | var userKnowsAboutPwas by booleanPreference(
104 | appContext.getPreferenceKey(R.string.pref_key_user_knows_about_pwa),
105 | @@ -1239,8 +1208,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
106 | default = true,
107 | )
108 |
109 | - val shouldShowOpenInAppCfr: Boolean
110 | - get() = canShowCfr && shouldShowOpenInAppBanner
111 | + val shouldShowOpenInAppCfr: Boolean = false
112 |
113 | var shouldShowAutoCloseTabsBanner by booleanPreference(
114 | appContext.getPreferenceKey(R.string.pref_key_should_show_auto_close_tabs_banner),
115 | @@ -1676,11 +1644,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
116 | /**
117 | * Indicates if sync onboarding CFR should be shown.
118 | */
119 | - var showSyncCFR by lazyFeatureFlagPreference(
120 | - appContext.getPreferenceKey(R.string.pref_key_should_show_sync_cfr),
121 | - featureFlag = true,
122 | - default = { mr2022Sections[Mr2022Section.SYNC_CFR] == true },
123 | - )
124 | + var showSyncCFR = false
125 |
126 | /**
127 | * Indicates if home onboarding dialog should be shown.
128 | @@ -1894,26 +1858,17 @@ class Settings(private val appContext: Context) : PreferencesHolder {
129 | /**
130 | * Indicates if the navigation bar CFR should be displayed to the user.
131 | */
132 | - var shouldShowNavigationBarCFR by booleanPreference(
133 | - key = appContext.getPreferenceKey(R.string.pref_key_should_navbar_cfr),
134 | - default = true,
135 | - )
136 | + var shouldShowNavigationBarCFR = false
137 |
138 | /**
139 | * Indicates if the search bar CFR should be displayed to the user.
140 | */
141 | - var shouldShowSearchBarCFR by booleanPreference(
142 | - key = appContext.getPreferenceKey(R.string.pref_key_should_searchbar_cfr),
143 | - default = false,
144 | - )
145 | + var shouldShowSearchBarCFR = false
146 |
147 | /**
148 | * Indicates Navigation Bar's Navigation buttons CFR should be displayed to the user.
149 | */
150 | - var shouldShowNavigationButtonsCFR by booleanPreference(
151 | - key = appContext.getPreferenceKey(R.string.pref_key_toolbar_navigation_cfr),
152 | - default = true,
153 | - )
154 | + var shouldShowNavigationButtonsCFR = false
155 |
156 | /**
157 | * Indicates whether or not to use remote server search configuration.
158 | @@ -1926,10 +1881,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
159 | /**
160 | * Indicates if the menu CFR should be displayed to the user.
161 | */
162 | - var shouldShowMenuCFR by booleanPreference(
163 | - key = appContext.getPreferenceKey(R.string.pref_key_menu_cfr),
164 | - default = true,
165 | - )
166 | + var shouldShowMenuCFR = false
167 |
168 | /**
169 | * Get the current mode for how https-only is enabled.
170 |
--------------------------------------------------------------------------------
/patches/disable-csp-reporting.patch:
--------------------------------------------------------------------------------
1 | diff --git a/dom/security/nsCSPContext.cpp b/dom/security/nsCSPContext.cpp
2 | index e3fb7b6e9a..81a42f99b0 100644
3 | --- a/dom/security/nsCSPContext.cpp
4 | +++ b/dom/security/nsCSPContext.cpp
5 | @@ -1218,7 +1218,6 @@ nsresult nsCSPContext::SendReports(
6 |
7 | //[Deprecated] CSP Level 2 Reporting
8 | if (!reportURIs.IsEmpty()) {
9 | - return SendReportsToURIs(reportURIs, aViolationEventInit);
10 | }
11 |
12 | return NS_OK;
13 |
--------------------------------------------------------------------------------
/patches/disable-default-browser-engagement-prompts.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
2 | index 72493a2c21..024440d98a 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
5 | @@ -800,12 +800,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
6 | * This will lead to a performance regression since that function can be expensive to call.
7 | */
8 | fun checkIfFenixIsDefaultBrowserOnAppResume(): Boolean {
9 | - val prefKey = appContext.getPreferenceKey(R.string.pref_key_default_browser)
10 | - val isDefaultBrowserNow = isDefaultBrowserBlocking()
11 | - val wasDefaultBrowserOnLastResume =
12 | - this.preferences.getBoolean(prefKey, isDefaultBrowserNow)
13 | - this.preferences.edit { putBoolean(prefKey, isDefaultBrowserNow) }
14 | - return isDefaultBrowserNow && !wasDefaultBrowserOnLastResume
15 | + return false
16 | }
17 |
18 | /**
19 | @@ -817,40 +812,31 @@ class Settings(private val appContext: Context) : PreferencesHolder {
20 | return browsers.isDefaultBrowser
21 | }
22 |
23 | - var reEngagementNotificationShown by booleanPreference(
24 | - appContext.getPreferenceKey(R.string.pref_key_re_engagement_notification_shown),
25 | - default = false,
26 | - )
27 | + var reEngagementNotificationShown = true
28 |
29 | /**
30 | * Check if we should set the re-engagement notification.
31 | */
32 | fun shouldSetReEngagementNotification(): Boolean {
33 | - return numberOfAppLaunches <= 1 && !reEngagementNotificationShown
34 | + return false
35 | }
36 |
37 | /**
38 | * Check if we should show the re-engagement notification.
39 | */
40 | fun shouldShowReEngagementNotification(): Boolean {
41 | - return !reEngagementNotificationShown && !isDefaultBrowserBlocking()
42 | + return false
43 | }
44 |
45 | /**
46 | * Indicates if the re-engagement notification feature is enabled
47 | */
48 | - var reEngagementNotificationEnabled by lazyFeatureFlagPreference(
49 | - key = appContext.getPreferenceKey(R.string.pref_key_re_engagement_notification_enabled),
50 | - default = { FxNimbus.features.reEngagementNotification.value().enabled },
51 | - featureFlag = true,
52 | - )
53 | + var reEngagementNotificationEnabled = false
54 |
55 | /**
56 | * Indicates if the re-engagement notification feature is enabled
57 | */
58 | - val reEngagementNotificationType: Int
59 | - get() =
60 | - FxNimbus.features.reEngagementNotification.value().type
61 | + val reEngagementNotificationType: Int = 0
62 |
63 | val shouldUseAutoBatteryTheme by booleanPreference(
64 | appContext.getPreferenceKey(R.string.pref_key_auto_battery_theme),
65 | @@ -2327,12 +2313,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
66 | /**
67 | * Indicates if the Set as default Browser prompt should be displayed to the user.
68 | */
69 | - val shouldShowSetAsDefaultPrompt: Boolean
70 | - get() =
71 | - (System.currentTimeMillis() - lastSetAsDefaultPromptShownTimeInMillis) >
72 | - DAYS_BETWEEN_DEFAULT_BROWSER_PROMPTS * ONE_DAY_MS &&
73 | - numberOfSetAsDefaultPromptShownTimes < MAX_NUMBER_OF_DEFAULT_BROWSER_PROMPTS &&
74 | - coldStartsBetweenSetAsDefaultPrompts >= APP_COLD_STARTS_TO_SHOW_DEFAULT_PROMPT
75 | + val shouldShowSetAsDefaultPrompt: Boolean = false
76 |
77 | /**
78 | * Updates the relevant settings when the "Set as Default Browser" prompt is shown.
79 |
--------------------------------------------------------------------------------
/patches/disable-doh-canary.patch:
--------------------------------------------------------------------------------
1 | diff --git a/toolkit/components/doh/DoHHeuristics.sys.mjs b/toolkit/components/doh/DoHHeuristics.sys.mjs
2 | index fd39a9be17..6bc9650775 100644
3 | --- a/toolkit/components/doh/DoHHeuristics.sys.mjs
4 | +++ b/toolkit/components/doh/DoHHeuristics.sys.mjs
5 | @@ -29,7 +29,7 @@ ChromeUtils.defineESModuleGetters(lazy, {
6 | DoHConfigController: "resource://gre/modules/DoHConfig.sys.mjs",
7 | });
8 |
9 | -const GLOBAL_CANARY = "use-application-dns.net.";
10 | +const GLOBAL_CANARY = "";
11 |
12 | const NXDOMAIN_ERR = "NS_ERROR_UNKNOWN_HOST";
13 |
14 | @@ -358,7 +358,7 @@ async function safeSearch() {
15 | }
16 |
17 | async function zscalerCanary() {
18 | - const ZSCALER_CANARY = "sitereview.zscaler.com.";
19 | + const ZSCALER_CANARY = "";
20 |
21 | let { addresses } = await dnsLookup(ZSCALER_CANARY);
22 | for (let address of addresses) {
23 |
--------------------------------------------------------------------------------
/patches/disable-geoip.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/android-components/components/service/location/src/main/java/mozilla/components/service/location/MozillaLocationService.kt b/mobile/android/android-components/components/service/location/src/main/java/mozilla/components/service/location/MozillaLocationService.kt
2 | index 8bea197568..1677b822ed 100644
3 | --- a/mobile/android/android-components/components/service/location/src/main/java/mozilla/components/service/location/MozillaLocationService.kt
4 | +++ b/mobile/android/android-components/components/service/location/src/main/java/mozilla/components/service/location/MozillaLocationService.kt
5 | @@ -25,10 +25,10 @@ import org.json.JSONObject
6 | import java.io.IOException
7 | import java.util.concurrent.TimeUnit
8 |
9 | -private const val GEOIP_SERVICE_URL = "https://location.services.mozilla.com/v1/"
10 | +private const val GEOIP_SERVICE_URL = ""
11 | private const val CONNECT_TIMEOUT_SECONDS = 10L
12 | private const val READ_TIMEOUT_SECONDS = 10L
13 | -private const val USER_AGENT = "MozAC/" + Build.version
14 | +private const val USER_AGENT = ""
15 | private const val EMPTY_REQUEST_BODY = "{}"
16 | private const val CACHE_FILE = "mozac.service.location.region"
17 | private const val KEY_COUNTRY_CODE = "country_code"
18 | @@ -94,7 +94,7 @@ class MozillaLocationService(
19 | * Check to see if the cache is still valid.
20 | */
21 | private fun isCacheValid(): Boolean {
22 | - return currentTime() < context.cachedAt() + CACHE_LIFETIME_IN_MS
23 | + return true
24 | }
25 |
26 | private fun Context.cacheRegion(region: LocationService.Region) {
27 |
--------------------------------------------------------------------------------
/patches/disable-hls.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/moz.configure b/mobile/android/moz.configure
2 | index c900501ee6..dba0c2ce55 100644
3 | --- a/mobile/android/moz.configure
4 | +++ b/mobile/android/moz.configure
5 | @@ -13,7 +13,7 @@ project_flag(
6 | project_flag(
7 | "MOZ_ANDROID_HLS_SUPPORT",
8 | help="Enable HLS (HTTP Live Streaming) support (currently using the ExoPlayer library)",
9 | - default=True,
10 | + default=False,
11 | )
12 |
13 | option(
14 |
--------------------------------------------------------------------------------
/patches/disable-link-sharing.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/SettingsFragment.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/SettingsFragment.kt
2 | index 64492271c3..48d4acfaed 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/SettingsFragment.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/SettingsFragment.kt
5 | @@ -751,7 +751,7 @@ class SettingsFragment : PreferenceFragmentCompat() {
6 | @VisibleForTesting
7 | internal fun setLinkSharingPreference() {
8 | with(requirePreference(R.string.pref_key_link_sharing)) {
9 | - isVisible = FxNimbus.features.sentFromFirefox.value().enabled
10 | + isVisible = false
11 | }
12 | }
13 |
14 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
15 | index 72493a2c21..7ee4d6c8ac 100644
16 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
17 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
18 | @@ -691,16 +691,9 @@ class Settings(private val appContext: Context) : PreferencesHolder {
19 | }
20 | }
21 |
22 | - var whatsappLinkSharingEnabled by lazyFeatureFlagPreference(
23 | - key = appContext.getPreferenceKey(R.string.pref_key_link_sharing),
24 | - featureFlag = true,
25 | - default = { FxNimbus.features.sentFromFirefox.value().enabled },
26 | - )
27 | + var whatsappLinkSharingEnabled = false
28 |
29 | - var linkSharingSettingsSnackbarShown by booleanPreference(
30 | - key = appContext.getPreferenceKey(R.string.pref_key_link_sharing_settings_snackbar),
31 | - default = false,
32 | - )
33 | + var linkSharingSettingsSnackbarShown = true
34 |
35 | /**
36 | * Get the display string for the current open links in apps setting
37 |
--------------------------------------------------------------------------------
/patches/disable-microsurveys.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/SecretSettingsFragment.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/SecretSettingsFragment.kt
2 | index b74145eb21..01386ed75d 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/SecretSettingsFragment.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/SecretSettingsFragment.kt
5 | @@ -251,8 +251,8 @@ class SecretSettingsFragment : PreferenceFragmentCompat() {
6 | }
7 |
8 | requirePreference(R.string.pref_key_microsurvey_feature_enabled).apply {
9 | - isVisible = true
10 | - isChecked = context.settings().microsurveyFeatureEnabled
11 | + isVisible = false
12 | + isChecked = false
13 | onPreferenceChangeListener = SharedPreferenceUpdater()
14 | }
15 |
16 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
17 | index 72493a2c21..b352a22247 100644
18 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
19 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
20 | @@ -2278,19 +2278,12 @@ class Settings(private val appContext: Context) : PreferencesHolder {
21 | /**
22 | * Indicates if the microsurvey feature is enabled.
23 | */
24 | - var microsurveyFeatureEnabled by lazyFeatureFlagPreference(
25 | - key = appContext.getPreferenceKey(R.string.pref_key_microsurvey_feature_enabled),
26 | - default = { FxNimbus.features.microsurveys.value().enabled },
27 | - featureFlag = true,
28 | - )
29 | + var microsurveyFeatureEnabled = false
30 |
31 | /**
32 | * Indicates if a microsurvey should be shown to the user.
33 | */
34 | - var shouldShowMicrosurveyPrompt by booleanPreference(
35 | - appContext.getPreferenceKey(R.string.pref_key_should_show_microsurvey_prompt),
36 | - default = false,
37 | - )
38 | + var shouldShowMicrosurveyPrompt = false
39 |
40 | /**
41 | * Last time the Set as default Browser prompt has been displayed to the user.
42 |
--------------------------------------------------------------------------------
/patches/disable-search-suggestions.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
2 | index 72493a2c21..d8f647227a 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
5 | @@ -1153,7 +1153,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
6 |
7 | val shouldShowSearchSuggestions by booleanPreference(
8 | appContext.getPreferenceKey(R.string.pref_key_show_search_suggestions),
9 | - default = true,
10 | + default = false,
11 | )
12 |
13 | val shouldAutocompleteInAwesomebar by booleanPreference(
14 | @@ -1195,10 +1195,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
15 | val shouldShowRecentSearchSuggestions: Boolean
16 | get() = recentSearchSuggestionsEnabled && isRecentSearchesVisible
17 |
18 | - var showSearchSuggestionsInPrivateOnboardingFinished by booleanPreference(
19 | - appContext.getPreferenceKey(R.string.pref_key_show_search_suggestions_in_private_onboarding),
20 | - default = false,
21 | - )
22 | + var showSearchSuggestionsInPrivateOnboardingFinished = true
23 |
24 | fun incrementVisitedInstallableCount() = pwaInstallableVisitCount.increment()
25 |
26 | diff --git a/mobile/android/fenix/app/src/main/res/xml/search_settings_preferences.xml b/mobile/android/fenix/app/src/main/res/xml/search_settings_preferences.xml
27 | index f7ca109331..f9820e2f98 100644
28 | --- a/mobile/android/fenix/app/src/main/res/xml/search_settings_preferences.xml
29 | +++ b/mobile/android/fenix/app/src/main/res/xml/search_settings_preferences.xml
30 | @@ -27,7 +27,7 @@
31 | android:layout="@layout/preference_category_no_icon_style">
32 |
38 |
7 |
8 |
14 |
15 |
21 |
22 |
28 |
29 |
35 |
36 |
42 |
43 |
44 | (
32 | + 0,
33 | + value.length,
34 | + Toolbar.RegistrableDomainColorSpan::class.java,
35 | + )
36 | +
37 | + if (spans.size != 1) {
38 | + return
39 | + }
40 | +
41 | + val valueUntilRegistrableDomainEnd = value.subSequence(0, value.getSpanEnd(spans[0]))
42 | +
43 | + val urlViewWidth = urlView.getWidth()
44 | + val valueWidth = urlView.getPaint().measureText(valueUntilRegistrableDomainEnd.toString())
45 | +
46 | + if (valueWidth > urlViewWidth) {
47 | + urlView.scrollTo((valueWidth - urlViewWidth).toInt(), 0)
48 | + }
49 | + }
50 | + }
51 |
52 | /**
53 | * Sets the colour of the text to be displayed when the URL of the toolbar is empty.
54 | diff --git a/mobile/android/android-components/components/concept/toolbar/src/main/java/mozilla/components/concept/toolbar/Toolbar.kt b/mobile/android/android-components/components/concept/toolbar/src/main/java/mozilla/components/concept/toolbar/Toolbar.kt
55 | index 77ffea44d7..8bdfaea7a5 100644
56 | --- a/mobile/android/android-components/components/concept/toolbar/src/main/java/mozilla/components/concept/toolbar/Toolbar.kt
57 | +++ b/mobile/android/android-components/components/concept/toolbar/src/main/java/mozilla/components/concept/toolbar/Toolbar.kt
58 | @@ -5,11 +5,13 @@
59 | package mozilla.components.concept.toolbar
60 |
61 | import android.graphics.drawable.Drawable
62 | +import android.text.style.ForegroundColorSpan
63 | import android.view.View
64 | import android.view.View.NO_ID
65 | import android.view.ViewGroup
66 | import android.widget.ImageButton
67 | import android.widget.ImageView
68 | +import androidx.annotation.ColorInt
69 | import androidx.annotation.ColorRes
70 | import androidx.annotation.Dimension
71 | import androidx.annotation.Dimension.Companion.DP
72 | @@ -548,6 +550,13 @@ interface Toolbar : ScrollableToolbar {
73 | */
74 | END,
75 | }
76 | +
77 | + /**
78 | + * Registrable domain foreground color span.
79 | + *
80 | + * This simple class extension is used so that we can filter for it elsewhere.
81 | + */
82 | + class RegistrableDomainColorSpan(@ColorInt color: Int) : ForegroundColorSpan(color)
83 | }
84 |
85 | private fun AppCompatImageButton.setTintResource(@ColorRes tintColorResource: Int) {
86 | diff --git a/mobile/android/android-components/components/feature/toolbar/src/main/java/mozilla/components/feature/toolbar/internal/URLRenderer.kt b/mobile/android/android-components/components/feature/toolbar/src/main/java/mozilla/components/feature/toolbar/internal/URLRenderer.kt
87 | index 53dcdf7bb9..83762aac98 100644
88 | --- a/mobile/android/android-components/components/feature/toolbar/src/main/java/mozilla/components/feature/toolbar/internal/URLRenderer.kt
89 | +++ b/mobile/android/android-components/components/feature/toolbar/src/main/java/mozilla/components/feature/toolbar/internal/URLRenderer.kt
90 | @@ -98,16 +98,19 @@ private suspend fun SpannableStringBuilder.colorRegistrableDomain(
91 |
92 | val registrableDomain = configuration
93 | .publicSuffixList
94 | - .getPublicSuffixPlusOne(host)
95 | + .getPublicSuffixPlusOne(host.removeSuffix("."))
96 | .await() ?: return
97 |
98 | - val index = url.indexOf(registrableDomain)
99 | - if (index == -1) {
100 | + val indexOfHost = url.indexOf(host)
101 | + val indexOfRegistrableDomain = host.lastIndexOf(registrableDomain)
102 | + if (indexOfHost == -1 || indexOfRegistrableDomain == -1) {
103 | return
104 | }
105 |
106 | + val index = indexOfHost + indexOfRegistrableDomain
107 | +
108 | setSpan(
109 | - ForegroundColorSpan(configuration.registrableDomainColor),
110 | + Toolbar.RegistrableDomainColorSpan(configuration.registrableDomainColor),
111 | index,
112 | index + registrableDomain.length,
113 | SPAN_INCLUSIVE_INCLUSIVE,
114 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/toolbar/ToolbarIntegration.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/toolbar/ToolbarIntegration.kt
115 | index 86b6454dac..16332ef912 100644
116 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/toolbar/ToolbarIntegration.kt
117 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/toolbar/ToolbarIntegration.kt
118 | @@ -60,6 +60,7 @@ abstract class ToolbarIntegration(
119 | urlRenderConfiguration = ToolbarFeature.UrlRenderConfiguration(
120 | context.components.publicSuffixList,
121 | context.getColorFromAttr(R.attr.textPrimary),
122 | + context.getColorFromAttr(R.attr.textSecondary),
123 | renderStyle = renderStyle,
124 | ),
125 | )
126 | @@ -142,7 +143,7 @@ class DefaultToolbarIntegration(
127 | interactor = interactor,
128 | customTabId = customTabId,
129 | isPrivate = isPrivate,
130 | - renderStyle = ToolbarFeature.RenderStyle.UncoloredUrl,
131 | + renderStyle = ToolbarFeature.RenderStyle.ColoredUrl,
132 | ) {
133 |
134 | @VisibleForTesting
135 |
--------------------------------------------------------------------------------
/patches/enable-light-mode-by-default.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
2 | index 72493a2c21..1a0c14ddbb 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
5 | @@ -455,7 +455,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
6 |
7 | var shouldUseLightTheme by booleanPreference(
8 | appContext.getPreferenceKey(R.string.pref_key_light_theme),
9 | - default = false,
10 | + default = true,
11 | )
12 |
13 | var shouldUseAutoSize by booleanPreference(
14 | diff --git a/mobile/android/fenix/app/src/main/res/xml/customization_preferences.xml b/mobile/android/fenix/app/src/main/res/xml/customization_preferences.xml
15 | index a24d1b7b2b..ea441ea576 100644
16 | --- a/mobile/android/fenix/app/src/main/res/xml/customization_preferences.xml
17 | +++ b/mobile/android/fenix/app/src/main/res/xml/customization_preferences.xml
18 | @@ -10,7 +10,7 @@
19 | android:title="@string/preferences_theme"
20 | app:iconSpaceReserved="false">
21 |
26 |
27 | @@ -26,7 +26,7 @@
28 | app:isPreferenceVisible="@bool/underAPI28" />
29 |
30 |
36 |
--------------------------------------------------------------------------------
/patches/expose-aboutconfig.patch:
--------------------------------------------------------------------------------
1 | diff --git a/docshell/base/nsAboutRedirector.cpp b/docshell/base/nsAboutRedirector.cpp
2 | index 77491402cb..fc64d6c537 100644
3 | --- a/docshell/base/nsAboutRedirector.cpp
4 | +++ b/docshell/base/nsAboutRedirector.cpp
5 | @@ -101,8 +101,7 @@ static const RedirEntry kRedirMap[] = {
6 | nsIAboutModule::IS_SECURE_CHROME_UI},
7 | #else
8 | {"config", "chrome://geckoview/content/config.xhtml",
9 | - nsIAboutModule::IS_SECURE_CHROME_UI |
10 | - nsIAboutModule::HIDE_FROM_ABOUTABOUT},
11 | + nsIAboutModule::IS_SECURE_CHROME_UI},
12 | #endif
13 | #ifdef MOZ_CRASHREPORTER
14 | {"crashes", "chrome://global/content/crashes.html",
15 |
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/ic_launcher-web.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/ic_launcher-web.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/ic_launcher_private-web.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/ic_launcher_private-web.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-hdpi/fenix_search_widget.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-hdpi/fenix_search_widget.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-hdpi/ic_logo_wordmark_normal.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-hdpi/ic_logo_wordmark_normal.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-hdpi/ic_logo_wordmark_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-hdpi/ic_logo_wordmark_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-hdpi/ic_wordmark_logo.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-hdpi/ic_wordmark_logo.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-hdpi/ic_wordmark_text_normal.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-hdpi/ic_wordmark_text_normal.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-hdpi/ic_wordmark_text_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-hdpi/ic_wordmark_text_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-mdpi/ic_logo_wordmark_normal.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-mdpi/ic_logo_wordmark_normal.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-mdpi/ic_logo_wordmark_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-mdpi/ic_logo_wordmark_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-mdpi/ic_wordmark_logo.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-mdpi/ic_wordmark_logo.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-mdpi/ic_wordmark_text_normal.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-mdpi/ic_wordmark_text_normal.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-mdpi/ic_wordmark_text_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-mdpi/ic_wordmark_text_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xhdpi/ic_logo_wordmark_normal.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xhdpi/ic_logo_wordmark_normal.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xhdpi/ic_logo_wordmark_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xhdpi/ic_logo_wordmark_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xhdpi/ic_wordmark_logo.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xhdpi/ic_wordmark_logo.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xhdpi/ic_wordmark_text_normal.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xhdpi/ic_wordmark_text_normal.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xhdpi/ic_wordmark_text_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xhdpi/ic_wordmark_text_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xxhdpi/ic_logo_wordmark_normal.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xxhdpi/ic_logo_wordmark_normal.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xxhdpi/ic_logo_wordmark_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xxhdpi/ic_logo_wordmark_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xxhdpi/ic_wordmark_logo.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xxhdpi/ic_wordmark_logo.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xxhdpi/ic_wordmark_text_normal.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xxhdpi/ic_wordmark_text_normal.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xxhdpi/ic_wordmark_text_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xxhdpi/ic_wordmark_text_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xxxhdpi/ic_logo_wordmark_normal.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xxxhdpi/ic_logo_wordmark_normal.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xxxhdpi/ic_logo_wordmark_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xxxhdpi/ic_logo_wordmark_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xxxhdpi/ic_wordmark_logo.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xxxhdpi/ic_wordmark_logo.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xxxhdpi/ic_wordmark_text_normal.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xxxhdpi/ic_wordmark_text_normal.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable-xxxhdpi/ic_wordmark_text_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/drawable-xxxhdpi/ic_wordmark_text_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable/ic_launcher_foreground.xml:
--------------------------------------------------------------------------------
1 |
7 |
11 |
13 |
14 |
20 |
21 |
22 |
23 |
24 |
25 |
28 |
31 |
32 |
33 |
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable/ic_launcher_monochrome.xml:
--------------------------------------------------------------------------------
1 |
2 |
7 |
12 |
15 |
16 |
17 |
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/drawable/ic_launcher_private_foreground.xml:
--------------------------------------------------------------------------------
1 |
7 |
11 |
13 |
14 |
20 |
21 |
22 |
23 |
24 |
25 |
28 |
31 |
32 |
33 |
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-anydpi-v26/ic_launcher.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-anydpi-v26/ic_launcher_private.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-anydpi-v26/ic_launcher_private_round.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-anydpi-v26/ic_launcher_round.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-hdpi/ic_launcher.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-hdpi/ic_launcher.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-hdpi/ic_launcher_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-hdpi/ic_launcher_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-hdpi/ic_launcher_private_round.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-hdpi/ic_launcher_private_round.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-hdpi/ic_launcher_round.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-hdpi/ic_launcher_round.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-mdpi/ic_launcher.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-mdpi/ic_launcher.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-mdpi/ic_launcher_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-mdpi/ic_launcher_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-mdpi/ic_launcher_private_round.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-mdpi/ic_launcher_private_round.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-mdpi/ic_launcher_round.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-mdpi/ic_launcher_round.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-xhdpi/ic_launcher.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-xhdpi/ic_launcher.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-xhdpi/ic_launcher_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-xhdpi/ic_launcher_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-xhdpi/ic_launcher_private_round.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-xhdpi/ic_launcher_private_round.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-xhdpi/ic_launcher_round.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-xhdpi/ic_launcher_round.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-xxhdpi/ic_launcher.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-xxhdpi/ic_launcher.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-xxhdpi/ic_launcher_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-xxhdpi/ic_launcher_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-xxhdpi/ic_launcher_private_round.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-xxhdpi/ic_launcher_private_round.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-xxhdpi/ic_launcher_round.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-xxhdpi/ic_launcher_round.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-xxxhdpi/ic_launcher.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-xxxhdpi/ic_launcher.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-xxxhdpi/ic_launcher_private.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-xxxhdpi/ic_launcher_private.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-xxxhdpi/ic_launcher_private_round.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-xxxhdpi/ic_launcher_private_round.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/mipmap-xxxhdpi/ic_launcher_round.webp:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/branding/res/mipmap-xxxhdpi/ic_launcher_round.webp
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/values/ic_launcher_background.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 | #ffffff
4 |
5 |
--------------------------------------------------------------------------------
/patches/fenix-overlay/branding/res/values/ic_launcher_private_background.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 | #ffffff
4 |
5 |
--------------------------------------------------------------------------------
/patches/fenix-overlay/initial_experiments/initial_experiments.json:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/fenix-overlay/initial_experiments/initial_experiments.json
--------------------------------------------------------------------------------
/patches/force-enable-zoom.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
2 | index 8e271198b0..e4a1f9d7ee 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
5 | @@ -215,7 +215,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
6 |
7 | var forceEnableZoom by booleanPreference(
8 | appContext.getPreferenceKey(R.string.pref_key_accessibility_force_enable_zoom),
9 | - default = false,
10 | + default = true,
11 | )
12 |
13 | var adjustCampaignId by stringPreference(
14 | diff --git a/mobile/android/fenix/app/src/main/res/xml/accessibility_preferences.xml b/mobile/android/fenix/app/src/main/res/xml/accessibility_preferences.xml
15 | index a810f76208..adba5368b6 100644
16 | --- a/mobile/android/fenix/app/src/main/res/xml/accessibility_preferences.xml
17 | +++ b/mobile/android/fenix/app/src/main/res/xml/accessibility_preferences.xml
18 | @@ -24,7 +24,7 @@
19 | app:seekBarIncrement="1"
20 | app:showSeekBarValue="true" />
21 | * mVector;
25 | } mArray[2];
26 |
--------------------------------------------------------------------------------
/patches/gecko-liberate.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/geckoview/build.gradle b/mobile/android/geckoview/build.gradle
2 | index 4afaf2493b..458ef0d0b1 100644
3 | --- a/mobile/android/geckoview/build.gradle
4 | +++ b/mobile/android/geckoview/build.gradle
5 | @@ -218,7 +218,7 @@ dependencies {
6 | implementation libs.androidx.collection
7 | implementation libs.androidx.core
8 |
9 | - implementation libs.play.services.fido
10 | + implementation "org.microg.gms:play-services-fido:v0.0.0.250932"
11 | implementation "org.yaml:snakeyaml:2.2"
12 |
13 | implementation libs.androidx.lifecycle.common
14 | diff --git a/mobile/android/geckoview/src/main/java/org/mozilla/geckoview/WebAuthnTokenManager.java b/mobile/android/geckoview/src/main/java/org/mozilla/geckoview/WebAuthnTokenManager.java
15 | index d688ff87f2..80b049ccac 100644
16 | --- a/mobile/android/geckoview/src/main/java/org/mozilla/geckoview/WebAuthnTokenManager.java
17 | +++ b/mobile/android/geckoview/src/main/java/org/mozilla/geckoview/WebAuthnTokenManager.java
18 | @@ -193,27 +193,14 @@ import org.mozilla.gecko.util.WebAuthnUtils;
19 |
20 | final Task intentTask;
21 |
22 | - if (BuildConfig.MOZILLA_OFFICIAL) {
23 | - // Certain Fenix builds and signing keys are whitelisted for Web Authentication.
24 | - // See https://wiki.mozilla.org/Security/Web_Authentication
25 | - //
26 | - // Third party apps will need to get whitelisted themselves.
27 | - final Fido2PrivilegedApiClient fidoClient =
28 | - Fido.getFido2PrivilegedApiClient(GeckoAppShell.getApplicationContext());
29 | -
30 | - intentTask = fidoClient.getRegisterPendingIntent(browserOptions);
31 | - } else {
32 | - // For non-official builds, websites have to opt-in to permit the
33 | - // particular version of Gecko to perform WebAuthn operations on
34 | - // them. See https://developers.google.com/digital-asset-links
35 | - // for the general form, and Step 1 of
36 | - // https://developers.google.com/identity/fido/android/native-apps
37 | - // for details about doing this correctly for the FIDO2 API.
38 | - final Fido2ApiClient fidoClient =
39 | - Fido.getFido2ApiClient(GeckoAppShell.getApplicationContext());
40 | -
41 | - intentTask = fidoClient.getRegisterPendingIntent(requestOptions);
42 | - }
43 | + // The privileged FIDO2 API normally is restricted to apps with package
44 | + // names and signatures that Google knows to be a browser. microG does not
45 | + // have such a list, instead it asks the user to confirm that the app doing
46 | + // the request is indeed a browser app (only for the first request from
47 | + // that app).
48 | + final Fido2PrivilegedApiClient fidoClient =
49 | + Fido.getFido2PrivilegedApiClient(GeckoAppShell.getApplicationContext());
50 | + intentTask = fidoClient.getRegisterPendingIntent(browserOptions);
51 |
52 | intentTask.addOnSuccessListener(
53 | pendingIntent -> {
54 | @@ -411,19 +398,12 @@ import org.mozilla.gecko.util.WebAuthnUtils;
55 | .build();
56 |
57 | final Task intentTask;
58 | - // See the makeCredential method for documentation about this
59 | - // conditional.
60 | - if (BuildConfig.MOZILLA_OFFICIAL) {
61 | - final Fido2PrivilegedApiClient fidoClient =
62 | - Fido.getFido2PrivilegedApiClient(GeckoAppShell.getApplicationContext());
63 | -
64 | - intentTask = fidoClient.getSignPendingIntent(browserOptions);
65 | - } else {
66 | - final Fido2ApiClient fidoClient =
67 | - Fido.getFido2ApiClient(GeckoAppShell.getApplicationContext());
68 | + // See the makeCredential method for documentation about the FIDO2 API and
69 | + // microG.
70 | + final Fido2PrivilegedApiClient fidoClient =
71 | + Fido.getFido2PrivilegedApiClient(GeckoAppShell.getApplicationContext());
72 |
73 | - intentTask = fidoClient.getSignPendingIntent(requestOptions);
74 | - }
75 | + intentTask = fidoClient.getSignPendingIntent(browserOptions);
76 |
77 | intentTask.addOnSuccessListener(
78 | pendingIntent -> {
79 | @@ -557,15 +537,9 @@ import org.mozilla.gecko.util.WebAuthnUtils;
80 | @WrapForJNI(calledFrom = "gecko")
81 | private static GeckoResult webAuthnIsUserVerifyingPlatformAuthenticatorAvailable() {
82 | final Task task;
83 | - if (BuildConfig.MOZILLA_OFFICIAL) {
84 | - final Fido2PrivilegedApiClient fidoClient =
85 | - Fido.getFido2PrivilegedApiClient(GeckoAppShell.getApplicationContext());
86 | - task = fidoClient.isUserVerifyingPlatformAuthenticatorAvailable();
87 | - } else {
88 | - final Fido2ApiClient fidoClient =
89 | - Fido.getFido2ApiClient(GeckoAppShell.getApplicationContext());
90 | - task = fidoClient.isUserVerifyingPlatformAuthenticatorAvailable();
91 | - }
92 | + final Fido2PrivilegedApiClient fidoClient =
93 | + Fido.getFido2PrivilegedApiClient(GeckoAppShell.getApplicationContext());
94 | + task = fidoClient.isUserVerifyingPlatformAuthenticatorAvailable();
95 |
96 | final GeckoResult res = new GeckoResult<>();
97 | task.addOnSuccessListener(
98 | diff --git a/toolkit/content/jar.mn b/toolkit/content/jar.mn
99 | index d3c34b7de2..7874643f0a 100644
100 | --- a/toolkit/content/jar.mn
101 | +++ b/toolkit/content/jar.mn
102 | @@ -158,9 +158,6 @@ toolkit.jar:
103 | #ifdef XP_MACOSX
104 | content/global/macWindowMenu.js
105 | #endif
106 | - content/global/gmp-sources/openh264.json (gmp-sources/openh264.json)
107 | - content/global/gmp-sources/widevinecdm.json (gmp-sources/widevinecdm.json)
108 | - content/global/gmp-sources/widevinecdm_l1.json (gmp-sources/widevinecdm_l1.json)
109 |
110 | # Third party files
111 | content/global/third_party/d3/d3.js (/third_party/js/d3/d3.js)
112 |
--------------------------------------------------------------------------------
/patches/gecko-overlay/branding/ironfox/configure.sh:
--------------------------------------------------------------------------------
1 | # This Source Code Form is subject to the terms of the Mozilla Public
2 | # License, v. 2.0. If a copy of the MPL was not distributed with this
3 | # file, You can obtain one at http://mozilla.org/MPL/2.0/.
4 |
5 | ANDROID_PACKAGE_NAME=org.ironfoxoss.ironfox
6 | MOZ_APP_DISPLAYNAME=IronFox
7 | MOZ_APP_REMOTINGNAME=ironfox
8 |
--------------------------------------------------------------------------------
/patches/gecko-overlay/branding/ironfox/content/favicon32.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/gecko-overlay/branding/ironfox/content/favicon32.png
--------------------------------------------------------------------------------
/patches/gecko-overlay/branding/ironfox/content/favicon64.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ironfox-oss/IronFox/a4ff4bc86e5191376db533ad308c8792a1fe2279/patches/gecko-overlay/branding/ironfox/content/favicon64.png
--------------------------------------------------------------------------------
/patches/gecko-overlay/branding/ironfox/content/jar.mn:
--------------------------------------------------------------------------------
1 | # This Source Code Form is subject to the terms of the Mozilla Public
2 | # License, v. 2.0. If a copy of the MPL was not distributed with this
3 | # file, You can obtain one at http://mozilla.org/MPL/2.0/.
4 |
5 | geckoview.jar:
6 | % content branding %content/branding/ contentaccessible=yes
7 | content/branding/favicon32.png (favicon32.png)
8 | content/branding/favicon64.png (favicon64.png)
9 |
--------------------------------------------------------------------------------
/patches/gecko-overlay/branding/ironfox/content/moz.build:
--------------------------------------------------------------------------------
1 | # -*- Mode: python; indent-tabs-mode: nil; tab-width: 40 -*-
2 | # vim: set filetype=python:
3 | # This Source Code Form is subject to the terms of the Mozilla Public
4 | # License, v. 2.0. If a copy of the MPL was not distributed with this
5 | # file, You can obtain one at http://mozilla.org/MPL/2.0/.
6 |
7 | JAR_MANIFESTS += ["jar.mn"]
8 |
--------------------------------------------------------------------------------
/patches/gecko-overlay/branding/ironfox/locales/en-US/brand.ftl:
--------------------------------------------------------------------------------
1 | # This Source Code Form is subject to the terms of the Mozilla Public
2 | # License, v. 2.0. If a copy of the MPL was not distributed with this
3 | # file, You can obtain one at http://mozilla.org/MPL/2.0/.
4 |
5 | -brand-full-name = IronFox
6 | -brand-product-name = IronFox
7 | -brand-short-name = IronFox
8 | -brand-shortcut-name = IronFox
9 | -brand-shorter-name = IronFox
10 | -vendor-short-name = IronFox OSS
11 |
--------------------------------------------------------------------------------
/patches/gecko-overlay/branding/ironfox/locales/en-US/brand.properties:
--------------------------------------------------------------------------------
1 | # This Source Code Form is subject to the terms of the Mozilla Public
2 | # License, v. 2.0. If a copy of the MPL was not distributed with this
3 | # file, You can obtain one at http://mozilla.org/MPL/2.0/.
4 |
5 | brandFullName=IronFox
6 | brandShorterName=IronFox
7 | brandShortName=IronFox
8 |
--------------------------------------------------------------------------------
/patches/gecko-overlay/branding/ironfox/locales/jar.mn:
--------------------------------------------------------------------------------
1 | #filter substitution
2 | # This Source Code Form is subject to the terms of the Mozilla Public
3 | # License, v. 2.0. If a copy of the MPL was not distributed with this
4 | # file, You can obtain one at http://mozilla.org/MPL/2.0/.
5 |
6 | [localization] @AB_CD@.jar:
7 | branding (%*.ftl)
8 |
9 | @AB_CD@.jar:
10 | % locale branding @AB_CD@ %locale/branding/
11 | locale/branding/brand.properties (en-US/brand.properties)
12 |
--------------------------------------------------------------------------------
/patches/gecko-overlay/branding/ironfox/locales/moz.build:
--------------------------------------------------------------------------------
1 | # -*- Mode: python; indent-tabs-mode: nil; tab-width: 40 -*-
2 | # vim: set filetype=python:
3 | # This Source Code Form is subject to the terms of the Mozilla Public
4 | # License, v. 2.0. If a copy of the MPL was not distributed with this
5 | # file, You can obtain one at http://mozilla.org/MPL/2.0/.
6 |
7 | JAR_MANIFESTS += ["jar.mn"]
8 |
--------------------------------------------------------------------------------
/patches/gecko-overlay/branding/ironfox/moz.build:
--------------------------------------------------------------------------------
1 | # -*- Mode: python; indent-tabs-mode: nil; tab-width: 40 -*-
2 | # vim: set filetype=python:
3 | # This Source Code Form is subject to the terms of the Mozilla Public
4 | # License, v. 2.0. If a copy of the MPL was not distributed with this
5 | # file, You can obtain one at http://mozilla.org/MPL/2.0/.
6 |
7 | DIRS += ["content", "locales"]
8 |
--------------------------------------------------------------------------------
/patches/gecko-overlay/rfptargets/RFPTargetsDefault.inc:
--------------------------------------------------------------------------------
1 | /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 | /* This Source Code Form is subject to the terms of the Mozilla Public
3 | * License, v. 2.0. If a copy of the MPL was not distributed with this
4 | * file, You can obtain one at https://mozilla.org/MPL/2.0/. */
5 |
6 | ANDROID_DEFAULT(AudioContext)
7 | ANDROID_DEFAULT(AudioSampleRate)
8 | ANDROID_DEFAULT(CanvasExtractionFromThirdPartiesIsBlocked)
9 | ANDROID_DEFAULT(CanvasRandomization)
10 | ANDROID_DEFAULT(CSSColorInfo)
11 | ANDROID_DEFAULT(CSSDeviceSize)
12 | ANDROID_DEFAULT(CSSInvertedColors)
13 | ANDROID_DEFAULT(CSSPointerCapabilities)
14 | ANDROID_DEFAULT(CSSPrefersContrast)
15 | ANDROID_DEFAULT(CSSPrefersReducedMotion)
16 | ANDROID_DEFAULT(CSSPrefersReducedTransparency)
17 | ANDROID_DEFAULT(CSSResolution)
18 | ANDROID_DEFAULT(CSSVideoDynamicRange)
19 | ANDROID_DEFAULT(DeviceSensors)
20 | ANDROID_DEFAULT(DOMStyleOsxFontSmoothing)
21 | ANDROID_DEFAULT(FontVisibilityBaseSystem)
22 | ANDROID_DEFAULT(FontVisibilityLangPack)
23 | ANDROID_DEFAULT(FontVisibilityRestrictGenerics)
24 | ANDROID_DEFAULT(Gamepad)
25 | ANDROID_DEFAULT(HttpUserAgent)
26 | ANDROID_DEFAULT(JSDateTimeUTC)
27 | ANDROID_DEFAULT(JSLocale)
28 | ANDROID_DEFAULT(JSLocalePrompt)
29 | ANDROID_DEFAULT(JSMathFdlibm)
30 | ANDROID_DEFAULT(KeyboardEvents)
31 | ANDROID_DEFAULT(MediaCapabilities)
32 | ANDROID_DEFAULT(MediaDevices)
33 | ANDROID_DEFAULT(MediaError)
34 | ANDROID_DEFAULT(MouseEventScreenPoint)
35 | ANDROID_DEFAULT(NavigatorAppVersion)
36 | ANDROID_DEFAULT(NavigatorBuildID)
37 | ANDROID_DEFAULT(NavigatorConnection)
38 | ANDROID_DEFAULT(NavigatorHWConcurrency)
39 | ANDROID_DEFAULT(NavigatorOscpu)
40 | ANDROID_DEFAULT(NavigatorPlatform)
41 | ANDROID_DEFAULT(NavigatorUserAgent)
42 | ANDROID_DEFAULT(PointerEvents)
43 | ANDROID_DEFAULT(PointerId)
44 | ANDROID_DEFAULT(ReduceTimerPrecision)
45 | ANDROID_DEFAULT(RoundWindowSize)
46 | ANDROID_DEFAULT(ScreenAvailRect)
47 | ANDROID_DEFAULT(ScreenOrientation)
48 | ANDROID_DEFAULT(ScreenPixelDepth)
49 | ANDROID_DEFAULT(ScreenRect)
50 | ANDROID_DEFAULT(SiteSpecificZoom)
51 | ANDROID_DEFAULT(SpeechSynthesis)
52 | ANDROID_DEFAULT(StreamVideoFacingMode)
53 | ANDROID_DEFAULT(TouchEvents)
54 | ANDROID_DEFAULT(UseStandinsForNativeColors)
55 | ANDROID_DEFAULT(VideoElementMozFrameDelay)
56 | ANDROID_DEFAULT(VideoElementMozFrames)
57 | ANDROID_DEFAULT(VideoElementPlaybackQuality)
58 | ANDROID_DEFAULT(WebGLRenderCapability)
59 | ANDROID_DEFAULT(WebGLRenderInfo)
60 | ANDROID_DEFAULT(WebGPUIsFallbackAdapter)
61 | ANDROID_DEFAULT(WebGPULimits)
62 | ANDROID_DEFAULT(WebGPUSubgroupSizes)
63 | ANDROID_DEFAULT(WebVTT)
64 | ANDROID_DEFAULT(WidgetEvents)
65 | ANDROID_DEFAULT(WindowDevicePixelRatio)
66 | ANDROID_DEFAULT(WindowInnerScreenXY)
67 | ANDROID_DEFAULT(WindowOuterSize)
68 | ANDROID_DEFAULT(WindowScreenXY)
69 |
--------------------------------------------------------------------------------
/patches/global-privacy-control.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/res/xml/tracking_protection_preferences.xml b/mobile/android/fenix/app/src/main/res/xml/tracking_protection_preferences.xml
2 | index 2760c9c367..8b8902e0c2 100644
3 | --- a/mobile/android/fenix/app/src/main/res/xml/tracking_protection_preferences.xml
4 | +++ b/mobile/android/fenix/app/src/main/res/xml/tracking_protection_preferences.xml
5 | @@ -93,7 +93,8 @@
6 |
10 | + android:title="@string/preference_enhanced_tracking_protection_custom_global_privacy_control"
11 | + app:isPreferenceVisible="false" />
12 |
15 |
--------------------------------------------------------------------------------
/patches/harden-pdfjs.patch:
--------------------------------------------------------------------------------
1 | diff --git a/toolkit/components/pdfjs/content/build/pdf.mjs b/toolkit/components/pdfjs/content/build/pdf.mjs
2 | index d2af6ba929..335f8cfd5c 100644
3 | --- a/toolkit/components/pdfjs/content/build/pdf.mjs
4 | +++ b/toolkit/components/pdfjs/content/build/pdf.mjs
5 | @@ -456,19 +456,14 @@ function isLittleEndian() {
6 | return view32[0] === 1;
7 | }
8 | function isEvalSupported() {
9 | - try {
10 | - new Function("");
11 | - return true;
12 | - } catch {
13 | - return false;
14 | - }
15 | + return false;
16 | }
17 | class util_FeatureTest {
18 | static get isLittleEndian() {
19 | return shadow(this, "isLittleEndian", isLittleEndian());
20 | }
21 | static get isEvalSupported() {
22 | - return shadow(this, "isEvalSupported", isEvalSupported());
23 | + return false;
24 | }
25 | static get isOffscreenCanvasSupported() {
26 | return shadow(this, "isOffscreenCanvasSupported", typeof OffscreenCanvas !== "undefined");
27 | @@ -10010,7 +10005,7 @@ function getDocument(src = {}) {
28 | const {
29 | docId
30 | } = task;
31 | - const url = src.url ? getUrlProp(src.url) : null;
32 | + const url = "resource://placeholder.pdf";
33 | const data = src.data ? getDataProp(src.data) : null;
34 | const httpHeaders = src.httpHeaders || null;
35 | const withCredentials = src.withCredentials === true;
36 | @@ -10020,17 +10015,17 @@ function getDocument(src = {}) {
37 | let worker = src.worker instanceof PDFWorker ? src.worker : null;
38 | const verbosity = src.verbosity;
39 | const docBaseUrl = typeof src.docBaseUrl === "string" && !isDataScheme(src.docBaseUrl) ? src.docBaseUrl : null;
40 | - const cMapUrl = getFactoryUrlProp(src.cMapUrl);
41 | - const cMapPacked = src.cMapPacked !== false;
42 | + const cMapUrl = "resource://pdf.js/web/cmaps/";
43 | + const cMapPacked = true;
44 | const CMapReaderFactory = src.CMapReaderFactory || DOMCMapReaderFactory;
45 | const iccUrl = getFactoryUrlProp(src.iccUrl);
46 | - const standardFontDataUrl = getFactoryUrlProp(src.standardFontDataUrl);
47 | + const standardFontDataUrl = "resource://pdf.js/web/standard_fonts/";
48 | const StandardFontDataFactory = src.StandardFontDataFactory || DOMStandardFontDataFactory;
49 | - const wasmUrl = getFactoryUrlProp(src.wasmUrl);
50 | + const wasmUrl = "resource://pdf.js/web/wasm/";
51 | const WasmFactory = src.WasmFactory || DOMWasmFactory;
52 | const ignoreErrors = src.stopAtErrors !== true;
53 | const maxImageSize = Number.isInteger(src.maxImageSize) && src.maxImageSize > -1 ? src.maxImageSize : -1;
54 | - const isEvalSupported = src.isEvalSupported !== false;
55 | + const isEvalSupported = false;
56 | const isOffscreenCanvasSupported = typeof src.isOffscreenCanvasSupported === "boolean" ? src.isOffscreenCanvasSupported : !isNodeJS;
57 | const isImageDecoderSupported = typeof src.isImageDecoderSupported === "boolean" ? src.isImageDecoderSupported : true;
58 | const canvasMaxAreaInBytes = Number.isInteger(src.canvasMaxAreaInBytes) ? src.canvasMaxAreaInBytes : -1;
59 | @@ -10047,7 +10042,7 @@ function getDocument(src = {}) {
60 | const enableHWA = src.enableHWA === true;
61 | const useWasm = src.useWasm !== false;
62 | const length = rangeTransport ? rangeTransport.length : src.length ?? NaN;
63 | - const useSystemFonts = typeof src.useSystemFonts === "boolean" ? src.useSystemFonts : !isNodeJS && !disableFontFace;
64 | + const useSystemFonts = false;
65 | const useWorkerFetch = typeof src.useWorkerFetch === "boolean" ? src.useWorkerFetch : true;
66 | const styleElement = null;
67 | setVerbosityLevel(verbosity);
68 | diff --git a/toolkit/components/pdfjs/content/build/pdf.worker.mjs b/toolkit/components/pdfjs/content/build/pdf.worker.mjs
69 | index 28157acd51..bee8773aec 100644
70 | --- a/toolkit/components/pdfjs/content/build/pdf.worker.mjs
71 | +++ b/toolkit/components/pdfjs/content/build/pdf.worker.mjs
72 | @@ -456,19 +456,14 @@ function isLittleEndian() {
73 | return view32[0] === 1;
74 | }
75 | function isEvalSupported() {
76 | - try {
77 | - new Function("");
78 | - return true;
79 | - } catch {
80 | - return false;
81 | - }
82 | + return false;
83 | }
84 | class FeatureTest {
85 | static get isLittleEndian() {
86 | return shadow(this, "isLittleEndian", isLittleEndian());
87 | }
88 | static get isEvalSupported() {
89 | - return shadow(this, "isEvalSupported", isEvalSupported());
90 | + return false;
91 | }
92 | static get isOffscreenCanvasSupported() {
93 | return shadow(this, "isOffscreenCanvasSupported", typeof OffscreenCanvas !== "undefined");
94 | @@ -28637,10 +28632,10 @@ class GlobalImageCache {
95 | class PDFFunctionFactory {
96 | constructor({
97 | xref,
98 | - isEvalSupported = true
99 | + isEvalSupported = false
100 | }) {
101 | this.xref = xref;
102 | - this.isEvalSupported = isEvalSupported !== false;
103 | + this.isEvalSupported = false;
104 | }
105 | create(fn, parseArray = false) {
106 | let fnRef, parsedFn;
107 | @@ -30973,18 +30968,18 @@ const DefaultPartialEvaluatorOptions = Object.freeze({
108 | maxImageSize: -1,
109 | disableFontFace: false,
110 | ignoreErrors: false,
111 | - isEvalSupported: true,
112 | + isEvalSupported: false,
113 | isOffscreenCanvasSupported: false,
114 | isImageDecoderSupported: false,
115 | canvasMaxAreaInBytes: -1,
116 | fontExtraProperties: false,
117 | - useSystemFonts: true,
118 | + useSystemFonts: false,
119 | useWasm: true,
120 | useWorkerFetch: true,
121 | - cMapUrl: null,
122 | + cMapUrl: "resource://pdf.js/web/cmaps/",
123 | iccUrl: null,
124 | - standardFontDataUrl: null,
125 | - wasmUrl: null
126 | + standardFontDataUrl: "resource://pdf.js/web/cmaps/",
127 | + wasmUrl: "resource://pdf.js/web/wasm/"
128 | });
129 | const PatternType = {
130 | TILING: 1,
131 | diff --git a/toolkit/components/pdfjs/content/web/viewer-geckoview.html b/toolkit/components/pdfjs/content/web/viewer-geckoview.html
132 | index 5e0a113820..e89114242e 100644
133 | --- a/toolkit/components/pdfjs/content/web/viewer-geckoview.html
134 | +++ b/toolkit/components/pdfjs/content/web/viewer-geckoview.html
135 | @@ -23,6 +23,7 @@ See https://github.com/adobe-type-tools/cmap-resources
136 |
137 |
138 |
139 | +
140 |
141 | PDF.js viewer
142 |
143 | diff --git a/toolkit/components/pdfjs/content/web/viewer-geckoview.mjs b/toolkit/components/pdfjs/content/web/viewer-geckoview.mjs
144 | index 167c6472f4..553ab04b37 100644
145 | --- a/toolkit/components/pdfjs/content/web/viewer-geckoview.mjs
146 | +++ b/toolkit/components/pdfjs/content/web/viewer-geckoview.mjs
147 | @@ -824,7 +824,7 @@ const defaultOptions = {
148 | kind: OptionKind.API
149 | },
150 | isEvalSupported: {
151 | - value: true,
152 | + value: false,
153 | kind: OptionKind.API
154 | },
155 | isOffscreenCanvasSupported: {
156 |
--------------------------------------------------------------------------------
/patches/https_only.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
2 | index 72493a2c21..cff0c52e9d 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
5 | @@ -734,7 +734,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
6 |
7 | var shouldUseHttpsOnly by booleanPreference(
8 | appContext.getPreferenceKey(R.string.pref_key_https_only),
9 | - default = false,
10 | + default = true,
11 | )
12 |
13 | var shouldUseHttpsOnlyInAllTabs by booleanPreference(
14 |
--------------------------------------------------------------------------------
/patches/include-fonts.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/moz.configure b/mobile/android/moz.configure
2 | index c900501ee6..99a3b38bdd 100644
3 | --- a/mobile/android/moz.configure
4 | +++ b/mobile/android/moz.configure
5 | @@ -7,7 +7,7 @@
6 | project_flag(
7 | "MOZ_ANDROID_EXCLUDE_FONTS",
8 | help="Whether to exclude font files from the build",
9 | - default=True,
10 | + default=False,
11 | )
12 |
13 | project_flag(
14 |
--------------------------------------------------------------------------------
/patches/install-ublock.patch:
--------------------------------------------------------------------------------
1 | From 51f108b2abb8808bc7196d6b7e7b4d46aaeb9013 Mon Sep 17 00:00:00 2001
2 | From: Akash Yadav
3 | Date: Mon, 28 Apr 2025 11:33:58 +0530
4 | Subject: [PATCH] fix(patches): update 'install-ublock.patch' for
5 | 'FIREFOX_138_0_BUILD1'
6 |
7 | Signed-off-by: Akash Yadav
8 | ---
9 | .../extension/WebExtensionPromptFeature.kt | 21 ++++++++++++
10 | .../fenix/onboarding/OnboardingFragment.kt | 7 ++++
11 | .../org/mozilla/fenix/utils/AddonUtils.kt | 34 +++++++++++++++++++
12 | 3 files changed, 62 insertions(+)
13 | create mode 100644 mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/AddonUtils.kt
14 |
15 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/extension/WebExtensionPromptFeature.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/extension/WebExtensionPromptFeature.kt
16 | index 82e44d1abc..fe2c0dd3e3 100644
17 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/extension/WebExtensionPromptFeature.kt
18 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/extension/WebExtensionPromptFeature.kt
19 | @@ -121,6 +121,9 @@ class WebExtensionPromptFeature(
20 | private fun handlePostInstallationRequest(
21 | addon: Addon,
22 | ) {
23 | + if (org.mozilla.fenix.utils.isUBlock(addon)) {
24 | + return
25 | + }
26 | showPostInstallationDialog(addon)
27 | }
28 |
29 | @@ -128,6 +131,15 @@ class WebExtensionPromptFeature(
30 | addon: Addon,
31 | promptRequest: WebExtensionPromptRequest.AfterInstallation.Permissions.Required,
32 | ) {
33 | + if (org.mozilla.fenix.utils.isUBlock(addon)) {
34 | + handlePermissions(
35 | + promptRequest = promptRequest,
36 | + granted = true,
37 | + privateBrowsingAllowed = true
38 | + )
39 | + return
40 | + }
41 | +
42 | showPermissionDialog(
43 | addon = addon,
44 | promptRequest = promptRequest,
45 | @@ -141,6 +153,15 @@ class WebExtensionPromptFeature(
46 | addon: Addon,
47 | promptRequest: WebExtensionPromptRequest.AfterInstallation.Permissions.Optional,
48 | ) {
49 | + if (org.mozilla.fenix.utils.isUBlock(addon)) {
50 | + handlePermissions(
51 | + promptRequest = promptRequest,
52 | + granted = true,
53 | + privateBrowsingAllowed = true
54 | + )
55 | + return
56 | + }
57 | +
58 | val shouldGrantWithoutPrompt = Addon.localizePermissions(
59 | promptRequest.permissions,
60 | context,
61 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/onboarding/OnboardingFragment.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/onboarding/OnboardingFragment.kt
62 | index 64d09acb1a..61599172ec 100644
63 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/onboarding/OnboardingFragment.kt
64 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/onboarding/OnboardingFragment.kt
65 | @@ -19,8 +19,10 @@ import androidx.annotation.RequiresApi
66 | import androidx.compose.runtime.Composable
67 | import androidx.compose.ui.platform.ComposeView
68 | import androidx.fragment.app.Fragment
69 | +import androidx.lifecycle.lifecycleScope
70 | import androidx.localbroadcastmanager.content.LocalBroadcastManager
71 | import androidx.navigation.fragment.findNavController
72 | +import kotlinx.coroutines.launch
73 | import mozilla.components.concept.engine.webextension.InstallationMethod
74 | import mozilla.components.service.nimbus.evalJexlSafe
75 | import mozilla.components.service.nimbus.messaging.use
76 | @@ -118,6 +120,11 @@ class OnboardingFragment : Fragment() {
77 | override fun onCreate(savedInstanceState: Bundle?) {
78 | super.onCreate(savedInstanceState)
79 | val context = requireContext()
80 | +
81 | + lifecycleScope.launch {
82 | + org.mozilla.fenix.utils.installIFAddons(requireComponents)
83 | + }
84 | +
85 | if (pagesToDisplay.isEmpty()) {
86 | /* do not continue if there's no onboarding pages to display */
87 | onFinish(null)
88 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/AddonUtils.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/AddonUtils.kt
89 | new file mode 100644
90 | index 0000000000..da5f74b77f
91 | --- /dev/null
92 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/AddonUtils.kt
93 | @@ -0,0 +1,34 @@
94 | +package org.mozilla.fenix.utils
95 | +
96 | +import kotlinx.coroutines.Dispatchers
97 | +import kotlinx.coroutines.withContext
98 | +import mozilla.components.concept.engine.webextension.InstallationMethod
99 | +import mozilla.components.feature.addons.Addon
100 | +import mozilla.components.feature.addons.logger
101 | +import org.mozilla.fenix.components.Components
102 | +
103 | +private val UBLOCK = Addon(
104 | + id = "uBlock0@raymondhill.net",
105 | + downloadUrl = "https://addons.mozilla.org/firefox/downloads/latest/uBlock0@raymondhill.net/latest.xpi"
106 | +)
107 | +
108 | +fun isUBlock(addon: Addon) = addon.id == UBLOCK.id
109 | +
110 | +suspend fun installIFAddons(components: Components) = withContext(Dispatchers.IO) {
111 | + val addonManager = components.addonManager
112 | + val addons = addonManager.getAddons(waitForPendingActions = true)
113 | + if (addons.none { it.id == UBLOCK.id && it.isInstalled() }) {
114 | + withContext(Dispatchers.Main) {
115 | + addonManager.installAddon(
116 | + url = UBLOCK.downloadUrl,
117 | + installationMethod = InstallationMethod.MANAGER,
118 | + onSuccess = {
119 | + logger.info("uBlock Origin installed.")
120 | + },
121 | + onError = { err ->
122 | + logger.error("uBlock Origin install failed.", err)
123 | + }
124 | + )
125 | + }
126 | + }
127 | +}
128 | --
129 | 2.49.0
130 |
131 |
--------------------------------------------------------------------------------
/patches/ironfox-content-settings.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/sitepermissions/SiteSettingsFragment.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/sitepermissions/SiteSettingsFragment.kt
2 | index 3885a06691..0adf0acee1 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/sitepermissions/SiteSettingsFragment.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/sitepermissions/SiteSettingsFragment.kt
5 | @@ -23,6 +23,10 @@ import org.mozilla.fenix.ext.settings
6 | import org.mozilla.fenix.ext.showToolbar
7 | import org.mozilla.fenix.settings.PhoneFeature
8 | import org.mozilla.fenix.settings.requirePreference
9 | +import android.os.Handler
10 | +import android.os.Looper
11 | +import android.widget.Toast
12 | +import kotlin.system.exitProcess
13 |
14 | /**
15 | * Screen for managing settings related to site permissions and content defaults.
16 | @@ -40,6 +44,67 @@ class SiteSettingsFragment : PreferenceFragmentCompat() {
17 | override fun onResume() {
18 | super.onResume()
19 | showToolbar(getString(R.string.preferences_site_settings))
20 | +
21 | + val javascriptEnabledPreference = requirePreference(
22 | + R.string.pref_key_javascript_enabled,
23 | + )
24 | +
25 | + javascriptEnabledPreference.setOnPreferenceChangeListener { preference, javascriptEnabled ->
26 | + val settings = preference.context.settings()
27 | + val components = preference.context.components
28 | +
29 | + settings.javascriptEnabled = javascriptEnabled as Boolean
30 | + components.core.engine.settings.javascriptEnabled = javascriptEnabled
31 | +
32 | + true
33 | + }
34 | +
35 | + val javascriptJitEnabledPreference = requirePreference(
36 | + R.string.pref_key_jit_enabled,
37 | + )
38 | +
39 | + javascriptJitEnabledPreference.setOnPreferenceChangeListener { preference, javascriptJitEnabled ->
40 | + val settings = preference.context.settings()
41 | + val components = preference.context.components
42 | +
43 | + settings.javascriptJitEnabled = javascriptJitEnabled as Boolean
44 | +
45 | + components.core.engine.settings.javascriptJitBaselineEnabled = javascriptJitEnabled
46 | + components.core.engine.settings.javascriptJitBaselineWasmEnabled = javascriptJitEnabled
47 | + components.core.engine.settings.javascriptJitHintsEnabled = javascriptJitEnabled
48 | + components.core.engine.settings.javascriptJitIonEnabled = javascriptJitEnabled
49 | + components.core.engine.settings.javascriptJitMainProcessEnabled = javascriptJitEnabled
50 | + components.core.engine.settings.javascriptJitNativeRegexpEnabled = javascriptJitEnabled
51 | + components.core.engine.settings.javascriptJitTrustedPrincipalsEnabled = javascriptJitEnabled
52 | +
53 | + Toast.makeText(
54 | + context,
55 | + getString(R.string.quit_application),
56 | + Toast.LENGTH_LONG,
57 | + ).show()
58 | + Handler(Looper.getMainLooper()).postDelayed(
59 | + {
60 | + exitProcess(0)
61 | + },
62 | + JIT_OVERRIDE_EXIT_DELAY,
63 | + )
64 | + true
65 | + }
66 | +
67 | + val wasmEnabledPreference = requirePreference(
68 | + R.string.pref_key_wasm_enabled,
69 | + )
70 | +
71 | + wasmEnabledPreference.setOnPreferenceChangeListener { preference, wasmEnabled ->
72 | + val settings = preference.context.settings()
73 | + val components = preference.context.components
74 | +
75 | + settings.wasmEnabled = wasmEnabled as Boolean
76 | + components.core.engine.settings.wasmEnabled = wasmEnabled
77 | +
78 | + true
79 | + }
80 | +
81 | setupPreferences()
82 | }
83 |
84 | @@ -109,4 +174,8 @@ class SiteSettingsFragment : PreferenceFragmentCompat() {
85 | )
86 | }
87 | }
88 | +
89 | + companion object {
90 | + private const val JIT_OVERRIDE_EXIT_DELAY = 2000L
91 | + }
92 | }
93 | diff --git a/mobile/android/fenix/app/src/main/res/values/preference_keys.xml b/mobile/android/fenix/app/src/main/res/values/preference_keys.xml
94 | index 4faefc7999..fa13b4420a 100644
95 | --- a/mobile/android/fenix/app/src/main/res/values/preference_keys.xml
96 | +++ b/mobile/android/fenix/app/src/main/res/values/preference_keys.xml
97 | @@ -444,6 +444,10 @@
98 | pref_key_app_cold_start_count
99 | pref_key_app_is_onboarding_set_as_default_displayed
100 |
101 | +
102 | + pref_key_javascript_enabled
103 | + pref_key_jit_enabled
104 | + pref_key_wasm_enabled
105 | pref_key_desktop_browsing
106 |
107 |
108 | diff --git a/mobile/android/fenix/app/src/main/res/xml/site_permissions_preferences.xml b/mobile/android/fenix/app/src/main/res/xml/site_permissions_preferences.xml
109 | index ef1dcb4e6e..25e429567d 100644
110 | --- a/mobile/android/fenix/app/src/main/res/xml/site_permissions_preferences.xml
111 | +++ b/mobile/android/fenix/app/src/main/res/xml/site_permissions_preferences.xml
112 | @@ -25,6 +25,28 @@
113 | android:title="@string/preference_feature_desktop_mode_default"
114 | app:iconSpaceReserved="false" />
115 |
116 | +
122 | +
123 | +
130 | +
131 | +
137 | +
138 |
139 |
140 | Send Ping
7 |
8 | Sent %1$s ping
9 | +
10 | + Request English versions of web pages for enhanced privacy
11 | +
12 | + Changing this setting will restart your browser
13 | +
14 | + Enable Accessibility Services
15 | + Enable to allow communication with Accessibility Services on your device.
16 | +
17 | + Enable Safe Browsing
18 | +
19 | + Enable JavaScript
20 | + Enable JavaScript Just-in-time Compilation (JIT)
21 | + Enable WebAssembly (WASM)
22 |
23 |
--------------------------------------------------------------------------------
/patches/locales:
--------------------------------------------------------------------------------
1 | ace ach af ak an ar as ast az be bg bn bn-BD bn-IN bo br brx bs ca ca-valencia cak ckb crh cs csb cy da de dsb el en-CA en-GB en-ZA eo es-AR es-CL es-ES es-MX et eu fa ff fi fr frp fur fy-NL ga-IE gd gl gn gu-IN gv he hi-IN hr hsb hto hu hy-AM hye ia id ilo is it ixl ja ja-JP-mac ka kab kk km kn ko kok ks ku lb lg lij lo lt ltg lv mai meh mix mk ml mn mr ms my nb-NO ne-NP nl nn-NO nr nso ny oc or pa-IN pai pbb pl ppl pt-BR pt-PT quy qvi rm ro ru rw sah sat sc scn sco si sk skr sl son sq sr ss st sv-SE sw szl ta ta-LK te tg th tl tn tr trs ts tsz uk ur uz ve vi wo xcl xh zam zh-CN zh-TW zu
2 |
--------------------------------------------------------------------------------
/patches/preferences/ironfox.js:
--------------------------------------------------------------------------------
1 |
2 | // Melding the Phoenix into a fox, with a strong coat of Iron…
3 |
4 | // This is home to IronFox-specific preferences. This will primarily be used for overriding undesired preferences from Phoenix; but it can also be used for ex. branding.
5 |
6 | /// Clear FPP global overrides
7 | // We're hardening FPP internally with our own `RFPTargetsDefault.inc` file instead of setting them here, which makes it far easier for users to add their own overrides if desired (by using this preference).
8 | pref("privacy.fingerprintingProtection.overrides", ""); // [DEFAULT]
9 |
10 | /// Clear FPP granular overrides
11 | // We're including these internally with a custom Remote Settings dump instead of setting them here, which makes it far easier for users to add their own overrides if desired (by using this preference).
12 | pref("privacy.fingerprintingProtection.granularOverrides", ''); // [DEFAULT]
13 |
14 | /// Re-enable the use of Cookie Banner Reduction rules from Remote Settings
15 | // We disable this functionality in Phoenix and instead set the rules locally via the "cookiebanners.listService.testRules" pref
16 | // We include the Cookie Banner Reduction rules local dump though, so we can just leave this on, but block remotely fetching the rules with the "browser.ironfox.services.settings.allowedCollections" pref instead
17 | pref("cookiebanners.listService.testRules", ''); // [DEFAULT]
18 | pref("cookiebanners.listService.testSkipRemoteSettings", false); // [DEFAULT]
19 |
20 | /// Re-enable our/Mozilla's fingerprinting protection overrides
21 | // We disable this functionality in Phoenix to re-enable Canvas randomization for Google domains by default - that isn't a problem for us here though, since we just use our custom Remote Settings dump to re-enable Canvas randomization for Google domains instead
22 | // This pref is also required for our custom Remote Settings dump/overrides to work anyways...
23 | pref("privacy.fingerprintingProtection.remoteOverrides.enabled", true); // [DEFAULT]
24 |
25 | /// Re-enable Password Manager & Autofill in GeckoView
26 | // We still disable these by default, just via a patch for Fenix's UI settings instead
27 | // https://gitlab.com/ironfox-oss/IronFox/-/issues/11
28 | pref("extensions.formautofill.addresses.enabled", true); // [DEFAULT]
29 | pref("extensions.formautofill.creditCards.enabled", true); // [DEFAULT]
30 | pref("signon.rememberSignons", true); // [DEFAULT]
31 |
32 | /// Re-enable WebGL
33 | // We're now blocking this by default with uBlock Origin
34 | pref("webgl.disabled", false); // [DEFAULT]
35 |
36 | /// Restrict Remote Settings
37 | pref("browser.ironfox.services.settings.allowedCollections", "blocklists/addons,blocklists/addons-bloomfilters,blocklists/gfx,main/addons-manager-settings,main/anti-tracking-url-decoration,main/bounce-tracking-protection-exceptions,main/fingerprinting-protection-overrides,main/partitioning-exempt-urls,main/password-recipes,main/query-stripping,main/remote-permissions,main/tracking-protection-lists,main/third-party-cookie-blocking-exempt-urls,main/translations-models,main/translations-wasm,main/url-classifier-exceptions,main/url-classifier-skip-urls,main/url-parser-default-unknown-schemes-interventions,security-state/cert-revocations,security-state/ct-logs,security-state/intermediates,security-state/onecrl");
38 | pref("browser.ironfox.services.settings.allowedCollectionsFromDump", "main/ironfox-fingerprinting-protection-overrides,blocklists/addons,blocklists/addons-bloomfilters,blocklists/gfx,main/anti-tracking-url-decoration,main/cookie-banner-rules-list,main/moz-essential-domain-fallbacks,main/password-recipes,main/remote-permissions,main/translations-models,main/translations-wasm,main/url-classifier-skip-urls,main/url-parser-default-unknown-schemes-interventions,security-state/intermediates,security-state/onecrl");
39 |
40 | /// Set default process count
41 | // This is the same as the default value - but we need to set here since Mozilla only defines it in GeckoRuntimeSettings, which we override to allow users to change the value if desired
42 | pref("dom.ipc.processCount", 2); // [DEFAULT]
43 |
44 | /// Set light/dark mode to match system
45 | // We still enable light mode by default, just via a patch for Fenix's UI settings instead
46 | pref("layout.css.prefers-color-scheme.content-override", 2); // [DEFAULT]
47 |
48 | pref("browser.ironfox.applied", true, locked);
49 |
--------------------------------------------------------------------------------
/patches/preferences/pdf.js:
--------------------------------------------------------------------------------
1 | //
2 | // See '019 PDF.js' in Phoenix for more details
3 |
4 | pref("pdfjs.enablePermissions", false);
5 | pref("pdfjs.enableScripting", false);
6 | pref("pdfjs.enableSignatureEditor", true);
7 | pref("pdfjs.enableXfa", false);
8 | pref("pdfjs.externalLinkTarget", 2);
9 | pref("pdfjs.sidebarViewOnLoad", 2);
10 |
--------------------------------------------------------------------------------
/patches/preferences/phoenix-extended.js:
--------------------------------------------------------------------------------
1 |
2 | //
3 |
4 | //
5 | // Copyright (C) 2024-2025 celenity
6 | //
7 | // This file is part of Phoenix.
8 | //
9 | // Phoenix is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
10 | //
11 | // Phoenix is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
12 | //
13 | // You should have received a copy of the GNU General Public License along with Phoenix. If not, see https://www.gnu.org/licenses/.
14 | //
15 |
16 | // This file contains preferences shared across Phoenix 'Extended' configs.
17 |
18 | /* INDEX
19 |
20 | 001: FINGERPRINTING PROTECTION
21 | 002: WEBRTC
22 | 003: ATTACK SURFACE REDUCTION
23 | 004: MISC. PRIVACY + SECURITY (ANDROID ONLY)
24 | 005: MISC. PRIVACY
25 |
26 | */
27 |
28 | /* KEY
29 |
30 | Unspecified = This preference should be set EVERYWHERE
31 |
32 | [ANDROID-ONLY] = This preference should ONLY be set for Android
33 |
34 | [NO-LINUX] = This preference should be set everywhere, EXCEPT for GNU/Linux
35 | [NO-MAIL] = This preference should be set everywhere, EXCEPT for Thunderbird (Used for ex. Dove)
36 | [NO-OSX] = This preference should be set everywhere, EXCEPT for macOS
37 | [NO-WINDOWS] = This preference should be set everywhere, EXCEPT for Windows
38 |
39 | */
40 |
41 |
42 | /*** 001 FINGERPRINTING PROTECTION ***/
43 |
44 |
45 | /// Further harden FPP...
46 | // As explained here: https://codeberg.org/celenity/Phoenix/wiki/Extended#fingerprinting
47 | // Compared to standard, this just removes '-JSDateTimeUTC' - meaning timezone is spoofed to UTC-0
48 | pref("privacy.fingerprintingProtection.overrides", "+AllTargets,-CanvasExtractionBeforeUserInputIsBlocked,-CSSPrefersColorScheme,-FrameRate,-CanvasImageExtractionPrompt"); // [ANDROID-ONLY]
49 | pref("browser.phoenix.status.extended", "001");
50 |
51 | /*** 002 WEBRTC ***/
52 | // This will likely break WebRTC...
53 |
54 | /// Always exclude local IP addresses, even in trusted scenarios
55 | pref("media.peerconnection.ice.no_host", true);
56 |
57 | /// Force a single candidate for ICE generation
58 | pref("media.peerconnection.ice.default_address_only", true);
59 |
60 | /// Only use TURN servers/relays
61 | // No P2P
62 | // https://gitlab.torproject.org/tpo/applications/mullvad-browser/-/issues/40#note_2884663
63 | pref("media.peerconnection.ice.relay_only", true);
64 |
65 | pref("browser.phoenix.status.extended", "002");
66 |
67 | /*** 003 ATTACK SURFACE REDUCTION ***/
68 |
69 | /// Disable WebAssembly (WASM)
70 | // https://spectrum.ieee.org/more-worries-over-the-security-of-web-assembly
71 | pref("javascript.options.wasm", false);
72 |
73 | pref("browser.phoenix.status.extended", "003");
74 |
75 | /*** 004 MISC. PRIVACY + SECURITY ***/
76 |
77 | /// Disable WebGL [ANDROID-ONLY]
78 | // PRIVACY: Fingerprinting concerns [ANDROID-ONLY]
79 | // SECURITY: Attack Surface Reduction [ANDROID-ONLY]
80 | // https://blog.browserscan.net/docs/webgl-fingerprinting [ANDROID-ONLY]
81 | // https://security.stackexchange.com/questions/13799/is-webgl-a-security-concern [ANDROID-ONLY]
82 | // On desktop we're no longer setting/recommending this in favor of the built-in `Block WebGL` filterlist in uBlock Origin, but on Android, we can't necessarily control uBlock Origin/set policies, so let's just make sure this is disabled. [ANDROID-ONLY]
83 | pref("webgl.disabled", true); // [ANDROID-ONLY]
84 |
85 | pref("browser.phoenix.status.extended", "004");
86 |
87 | /*** 005 MISC. PRIVACY ***/
88 |
89 | /// Only send cross-origin referers if hosts match
90 | // https://wiki.mozilla.org/Security/Referrer
91 | pref("network.http.referer.XOriginPolicy", 2);
92 |
93 | pref("browser.phoenix.status.extended", "005");
94 |
95 | pref("browser.phoenix.status.extended", "successfully applied :D", locked);
96 |
--------------------------------------------------------------------------------
/patches/remote-debugging.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
2 | index 72493a2c21..e655406cde 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
5 | @@ -387,10 +387,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
6 | true,
7 | )
8 |
9 | - val isRemoteDebuggingEnabled by booleanPreference(
10 | - appContext.getPreferenceKey(R.string.pref_key_remote_debugging),
11 | - default = false,
12 | - )
13 | + val isRemoteDebuggingEnabled = false
14 |
15 | var isTelemetryEnabled by booleanPreference(
16 | appContext.getPreferenceKey(R.string.pref_key_telemetry),
17 | diff --git a/mobile/android/fenix/app/src/main/res/xml/preferences.xml b/mobile/android/fenix/app/src/main/res/xml/preferences.xml
18 | index 4c6b14bf87..47bb65c164 100644
19 | --- a/mobile/android/fenix/app/src/main/res/xml/preferences.xml
20 | +++ b/mobile/android/fenix/app/src/main/res/xml/preferences.xml
21 | @@ -190,12 +190,6 @@
22 | app:iconSpaceReserved="false"
23 | app:isPreferenceVisible="@bool/IS_DEBUG" />
24 |
25 | -
30 | -
31 | handler("onEnabling", addon.id),
10 | - onEnabled: addon => handler("onEnabled", addon.id),
11 | - onDisabling: addon => handler("onDisabling", addon.id),
12 | - onDisabled: addon => handler("onDisabled", addon.id),
13 | - onInstalling: addon => handler("onInstalling", addon.id),
14 | - onInstalled: addon => handler("onInstalled", addon.id),
15 | - onUninstalling: addon => handler("onUninstalling", addon.id),
16 | - onUninstalled: addon => handler("onUninstalled", addon.id),
17 | - onOperationCancelled: addon =>
18 | - handler("onOperationCancelled", addon.id),
19 | };
20 | this.addonListeners.set(target, listener);
21 | AddonManager.addAddonListener(listener);
22 | diff --git a/toolkit/mozapps/extensions/amWebAPI.sys.mjs b/toolkit/mozapps/extensions/amWebAPI.sys.mjs
23 | index 59d093603a..0c9d9c6176 100644
24 | --- a/toolkit/mozapps/extensions/amWebAPI.sys.mjs
25 | +++ b/toolkit/mozapps/extensions/amWebAPI.sys.mjs
26 | @@ -154,11 +154,9 @@ class Addon extends APIObject {
27 | }
28 |
29 | uninstall() {
30 | - return this._apiTask("addonUninstall", [this.id]);
31 | }
32 |
33 | setEnabled(value) {
34 | - return this._apiTask("addonSetEnabled", [this.id, value]);
35 | }
36 | }
37 |
38 | @@ -210,7 +208,7 @@ export class WebAPI extends APIObject {
39 |
40 | getAddonByID(id) {
41 | return this._apiTask("getAddonByID", [id], addonInfo => {
42 | - if (!addonInfo) {
43 | + if (!addonInfo || addonInfo) {
44 | return null;
45 | }
46 | let addon = new Addon(this.window, this.broker, addonInfo);
47 |
--------------------------------------------------------------------------------
/patches/rs-dumps.patch:
--------------------------------------------------------------------------------
1 | diff --git a/services/settings/dumps/blocklists/moz.build b/services/settings/dumps/blocklists/moz.build
2 | index 485e888f6a..27ca6589d6 100644
3 | --- a/services/settings/dumps/blocklists/moz.build
4 | +++ b/services/settings/dumps/blocklists/moz.build
5 | @@ -16,14 +16,13 @@ FINAL_TARGET_FILES.defaults.settings.blocklists += [
6 | # after install.
7 | # See https://bugzilla.mozilla.org/show_bug.cgi?id=1639050#c5
8 |
9 | -if not CONFIG["MOZ_BUILD_APP"].startswith("mobile/"):
10 | - FINAL_TARGET_FILES.defaults.settings.blocklists += [
11 | - "addons-bloomfilters.json",
12 | - ]
13 | +FINAL_TARGET_FILES.defaults.settings.blocklists += [
14 | + "addons-bloomfilters.json",
15 | +]
16 |
17 | - FINAL_TARGET_FILES.defaults.settings.blocklists["addons-bloomfilters"] += [
18 | - "addons-bloomfilters/addons-mlbf.bin",
19 | - "addons-bloomfilters/addons-mlbf.bin.meta.json",
20 | - "addons-bloomfilters/softblocks-addons-mlbf.bin",
21 | - "addons-bloomfilters/softblocks-addons-mlbf.bin.meta.json",
22 | - ]
23 | +FINAL_TARGET_FILES.defaults.settings.blocklists["addons-bloomfilters"] += [
24 | + "addons-bloomfilters/addons-mlbf.bin",
25 | + "addons-bloomfilters/addons-mlbf.bin.meta.json",
26 | + "addons-bloomfilters/softblocks-addons-mlbf.bin",
27 | + "addons-bloomfilters/softblocks-addons-mlbf.bin.meta.json",
28 | +]
29 | diff --git a/services/settings/dumps/main/moz.build b/services/settings/dumps/main/moz.build
30 | index 7f89890eb3..e94d348edf 100644
31 | --- a/services/settings/dumps/main/moz.build
32 | +++ b/services/settings/dumps/main/moz.build
33 | @@ -37,7 +37,16 @@ if not CONFIG["MOZ_BUILD_APP"].startswith("mobile/"):
34 |
35 | # These collections are referenced in toolkit/ or other core code.
36 | FINAL_TARGET_FILES.defaults.settings.main += [
37 | + "anti-tracking-url-decoration.json",
38 | + "cookie-banner-rules-list.json",
39 | + "ironfox-fingerprinting-protection-overrides.json",
40 | + "moz-essential-domain-fallbacks.json",
41 | "password-recipes.json",
42 | + "remote-permissions.json",
43 | + "translations-models.json",
44 | + "translations-wasm.json",
45 | + "url-classifier-skip-urls.json",
46 | + "url-parser-default-unknown-schemes-interventions.json",
47 | ]
48 |
49 | # These search config icons only apply to desktop.
50 | diff --git a/services/settings/dumps/security-state/moz.build b/services/settings/dumps/security-state/moz.build
51 | index 6e92217dcb..d6c81e5643 100644
52 | --- a/services/settings/dumps/security-state/moz.build
53 | +++ b/services/settings/dumps/security-state/moz.build
54 | @@ -8,7 +8,6 @@ FINAL_TARGET_FILES.defaults.settings["security-state"] += [
55 | ]
56 |
57 | # Not packaged on android/ios currently - not crucial data for first load.
58 | -if not CONFIG["MOZ_BUILD_APP"].startswith("mobile/"):
59 | - FINAL_TARGET_FILES.defaults.settings["security-state"] += [
60 | - "intermediates.json",
61 | - ]
62 | +FINAL_TARGET_FILES.defaults.settings["security-state"] += [
63 | + "intermediates.json",
64 | +]
65 |
--------------------------------------------------------------------------------
/patches/sanitize-on-exit.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
2 | index 72493a2c21..df9ba5d1f4 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
5 | @@ -1033,7 +1033,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
6 |
7 | var shouldDeleteBrowsingDataOnQuit by booleanPreference(
8 | appContext.getPreferenceKey(R.string.pref_key_delete_browsing_data_on_quit),
9 | - default = false,
10 | + default = true,
11 | )
12 |
13 | var deleteOpenTabs by booleanPreference(
14 | @@ -1113,8 +1113,17 @@ class Settings(private val appContext: Context) : PreferencesHolder {
15 | return touchExplorationIsEnabled || switchServiceIsEnabled
16 | }
17 |
18 | - fun getDeleteDataOnQuit(type: DeleteBrowsingDataOnQuitType): Boolean =
19 | - preferences.getBoolean(type.getPreferenceKey(appContext), false)
20 | + fun getDeleteDataOnQuit(type: DeleteBrowsingDataOnQuitType): Boolean {
21 | + val defaultValue = when(type) {
22 | + DeleteBrowsingDataOnQuitType.CACHE -> true
23 | + DeleteBrowsingDataOnQuitType.DOWNLOADS -> true
24 | + DeleteBrowsingDataOnQuitType.HISTORY -> true
25 | + DeleteBrowsingDataOnQuitType.TABS -> true
26 | + else -> false
27 | + }
28 | +
29 | + return preferences.getBoolean(type.getPreferenceKey(appContext), defaultValue)
30 | + }
31 |
32 | fun setDeleteDataOnQuit(type: DeleteBrowsingDataOnQuitType, value: Boolean) {
33 | preferences.edit { putBoolean(type.getPreferenceKey(appContext), value) }
34 | diff --git a/mobile/android/fenix/app/src/main/res/xml/delete_browsing_data_quit_preferences.xml b/mobile/android/fenix/app/src/main/res/xml/delete_browsing_data_quit_preferences.xml
35 | index a5cc8cabb6..ea74ef7ee4 100644
36 | --- a/mobile/android/fenix/app/src/main/res/xml/delete_browsing_data_quit_preferences.xml
37 | +++ b/mobile/android/fenix/app/src/main/res/xml/delete_browsing_data_quit_preferences.xml
38 | @@ -5,7 +5,7 @@
39 |
41 |
47 | @@ -16,29 +16,35 @@
48 | app:iconSpaceReserved="false"
49 | android:layout="@layout/preference_category_empty">
50 |
55 |
60 |
66 |
72 |
77 |
78 |
83 | diff --git a/mobile/android/fenix/app/src/main/res/xml/preferences.xml b/mobile/android/fenix/app/src/main/res/xml/preferences.xml
84 | index 4c6b14bf87..4f08a5612c 100644
85 | --- a/mobile/android/fenix/app/src/main/res/xml/preferences.xml
86 | +++ b/mobile/android/fenix/app/src/main/res/xml/preferences.xml
87 | @@ -199,6 +199,7 @@
88 |
94 |
95 |
--------------------------------------------------------------------------------
/patches/search-engines.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/android-components/components/feature/search/src/main/java/mozilla/components/feature/search/storage/SearchEngineReader.kt b/mobile/android/android-components/components/feature/search/src/main/java/mozilla/components/feature/search/storage/SearchEngineReader.kt
2 | index 22cb809c62..bca3c3198f 100644
3 | --- a/mobile/android/android-components/components/feature/search/src/main/java/mozilla/components/feature/search/storage/SearchEngineReader.kt
4 | +++ b/mobile/android/android-components/components/feature/search/src/main/java/mozilla/components/feature/search/storage/SearchEngineReader.kt
5 | @@ -36,21 +36,19 @@ internal const val IMAGE_URI_PREFIX = "data:image/png;base64,"
6 | internal const val GOOGLE_ID = "google"
7 | private const val TARGET_SIZE = 16
8 | private const val MAX_SIZE = 32
9 | -private const val URL_PREFIX = "https://firefox-settings-attachments.cdn.mozilla.net/"
10 | +private const val URL_PREFIX = ""
11 |
12 | // List of general search engine ids, taken from
13 | // https://searchfox.org/mozilla-central/rev/ef0aa879e94534ffd067a3748d034540a9fc10b0/toolkit/components/search/SearchUtils.sys.mjs#200
14 | internal val GENERAL_SEARCH_ENGINE_IDS = setOf(
15 | - GOOGLE_ID,
16 | "ddg",
17 | - "bing",
18 | - "baidu",
19 | - "ecosia",
20 | - "qwant",
21 | - "yahoo-jp",
22 | - "seznam-cz",
23 | - "coccoc",
24 | - "baidu",
25 | + "ddghtml",
26 | + "ddglite",
27 | + "mojeek",
28 | + "leta-brave",
29 | + "leta-google",
30 | + "no-search",
31 | + "startpage",
32 | )
33 |
34 | /**
35 |
--------------------------------------------------------------------------------
/patches/strict_etp.patch:
--------------------------------------------------------------------------------
1 | diff --git a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
2 | index 72493a2c21..79c545543d 100644
3 | --- a/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
4 | +++ b/mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
5 | @@ -747,10 +747,7 @@ class Settings(private val appContext: Context) : PreferencesHolder {
6 | default = false,
7 | )
8 |
9 | - var shouldUseTrackingProtection by booleanPreference(
10 | - appContext.getPreferenceKey(R.string.pref_key_tracking_protection),
11 | - default = true,
12 | - )
13 | + var shouldUseTrackingProtection = true
14 |
15 | var shouldEnableGlobalPrivacyControl by booleanPreference(
16 | appContext.getPreferenceKey(R.string.pref_key_privacy_enable_global_privacy_control),
17 | @@ -857,20 +854,11 @@ class Settings(private val appContext: Context) : PreferencesHolder {
18 | default = false,
19 | )
20 |
21 | - val useStandardTrackingProtection by booleanPreference(
22 | - appContext.getPreferenceKey(R.string.pref_key_tracking_protection_standard_option),
23 | - true,
24 | - )
25 | + val useStandardTrackingProtection = false
26 |
27 | - val useStrictTrackingProtection by booleanPreference(
28 | - appContext.getPreferenceKey(R.string.pref_key_tracking_protection_strict_default),
29 | - false,
30 | - )
31 | + val useStrictTrackingProtection = true
32 |
33 | - val useCustomTrackingProtection by booleanPreference(
34 | - appContext.getPreferenceKey(R.string.pref_key_tracking_protection_custom_option),
35 | - false,
36 | - )
37 | + val useCustomTrackingProtection = false
38 |
39 | @VisibleForTesting(otherwise = PRIVATE)
40 | fun setStrictETP() {
41 | diff --git a/mobile/android/fenix/app/src/main/res/xml/tracking_protection_preferences.xml b/mobile/android/fenix/app/src/main/res/xml/tracking_protection_preferences.xml
42 | index 2760c9c367..10835b79e3 100644
43 | --- a/mobile/android/fenix/app/src/main/res/xml/tracking_protection_preferences.xml
44 | +++ b/mobile/android/fenix/app/src/main/res/xml/tracking_protection_preferences.xml
45 | @@ -14,25 +14,29 @@
46 | android:key="@string/pref_key_tracking_protection"
47 | android:summary="@string/preference_enhanced_tracking_protection_summary"
48 | android:title="@string/preference_enhanced_tracking_protection"
49 | - app:iconSpaceReserved="false" />
50 | + app:iconSpaceReserved="false"
51 | + app:isPreferenceVisible="false" />
52 |
59 | + android:title="@string/preference_enhanced_tracking_protection_standard_default_1"
60 | + app:isPreferenceVisible="false" />
61 |
68 | + android:title="@string/preference_enhanced_tracking_protection_strict"
69 | + app:isPreferenceVisible="false" />
70 |
76 | + android:title="@string/preference_enhanced_tracking_protection_custom"
77 | + app:isPreferenceVisible="false" />
78 | .
18 | #
19 |
20 | if [ -z "$1" ]; then
21 | echo "Usage: $0 apk|bundle" >&1
22 | exit 1
23 | fi
24 |
25 | set -euo pipefail
26 |
27 | build_type="$1"
28 |
29 | if [ "$build_type" != "apk" ] && [ "$build_type" != "bundle" ]; then
30 | echo "Unknown build type: '$build_type'" >&1
31 | echo "Usage: $0 apk|bundle" >&1
32 | exit 1
33 | fi
34 |
35 | if [[ -n ${FDROID_BUILD+x} ]]; then
36 | source "$(dirname "$0")/env_fdroid.sh"
37 | fi
38 |
39 | # shellcheck disable=SC2154
40 | if [[ "$env_source" != "true" ]]; then
41 | echo "Use 'source scripts/env_local.sh' before calling prebuild or build"
42 | exit 1
43 | fi
44 |
45 | source "$CARGO_HOME/env"
46 |
47 | # We publish the artifacts into a local Maven repository instead of using the
48 | # auto-publication workflow because the latter does not work for Gradle
49 | # plugins (Glean).
50 |
51 | if [[ -n ${FDROID_BUILD+x} ]]; then
52 | # Build LLVM
53 | # shellcheck disable=SC2154
54 | pushd "$llvm"
55 |
56 | # shellcheck disable=SC2154
57 | llvmtarget=$(cat "$builddir/targets_to_build")
58 | echo "building llvm for $llvmtarget"
59 | cmake -S llvm -B build -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=out -DCMAKE_C_COMPILER=clang-16 \
60 | -DCMAKE_CXX_COMPILER=clang++-16 -DLLVM_ENABLE_PROJECTS="clang" -DLLVM_TARGETS_TO_BUILD="$llvmtarget" \
61 | -DLLVM_USE_LINKER=lld -DLLVM_BINUTILS_INCDIR=/usr/include -DLLVM_ENABLE_PLUGINS=FORCE_ON \
62 | -DLLVM_DEFAULT_TARGET_TRIPLE="x86_64-unknown-linux-gnu"
63 | cmake --build build -j"$(nproc)"
64 | cmake --build build --target install -j"$(nproc)"
65 | popd
66 | fi
67 |
68 | if [[ -n ${FDROID_BUILD+x} ]]; then
69 | # Build WASI SDK
70 | # shellcheck disable=SC2154
71 | pushd "$wasi"
72 |
73 | mkdir -p build/install/wasi
74 | touch build/compiler-rt.BUILT # fool the build system
75 | make \
76 | PREFIX=/wasi \
77 | build/wasi-libc.BUILT \
78 | build/libcxx.BUILT \
79 | -j"$(nproc)"
80 | popd
81 | fi
82 |
83 | # Build microG libraries
84 | # shellcheck disable=SC2154
85 | pushd "$gmscore"
86 | if ! [[ -n ${FDROID_BUILD+x} ]]; then
87 | export GRADLE_MICROG_VERSION_WITHOUT_GIT=1
88 | fi
89 | gradle -x javaDocReleaseGeneration \
90 | :play-services-ads-identifier:publishToMavenLocal \
91 | :play-services-base:publishToMavenLocal \
92 | :play-services-basement:publishToMavenLocal \
93 | :play-services-fido:publishToMavenLocal \
94 | :play-services-tasks:publishToMavenLocal
95 | popd
96 |
97 | # shellcheck disable=SC2154
98 | pushd "$glean"
99 | export TARGET_CFLAGS=-DNDEBUG
100 | gradle publishToMavenLocal
101 | popd
102 |
103 | # shellcheck disable=SC2154
104 | pushd "$application_services"
105 |
106 | # When 'CI' environment variable is set to a non-zero value, the 'libs/verify-ci-android-environment.sh' script
107 | # skips building the libraries as they are expected to be already downloaded in a CI environment
108 | # However, we want build those libraries always, so we set CI='' before invoking the script
109 | CI='' bash -c './libs/verify-android-environment.sh && gradle :tooling-nimbus-gradle:publishToMavenLocal'
110 | popd
111 |
112 | # shellcheck disable=SC2154
113 | pushd "$mozilla_release"
114 |
115 | # shellcheck disable=SC2086
116 | ./mach build
117 | ./mach package
118 | ./mach package-multi-locale --locales ${IRONFOX_LOCALES}
119 |
120 | MOZ_CHROME_MULTILOCALE="${IRONFOX_LOCALES}"
121 | export MOZ_CHROME_MULTILOCALE
122 |
123 | gradle :geckoview:publishReleasePublicationToMavenLocal
124 | gradle :exoplayer2:publishReleasePublicationToMavenLocal
125 | popd
126 |
127 | # shellcheck disable=SC2154
128 | pushd "$android_components"
129 | # Publish concept-fetch (required by A-S) with auto-publication disabled,
130 | # otherwise automatically triggered publication of A-S will fail
131 | gradle :concept-fetch:publishToMavenLocal
132 | # Enable the auto-publication workflow now that concept-fetch is published
133 | echo "autoPublish.application-services.dir=$application_services" >>local.properties
134 | gradle publishToMavenLocal
135 | popd
136 |
137 | # shellcheck disable=SC2154
138 | pushd "$fenix"
139 | if [[ "$build_type" == "apk" ]]; then
140 | gradle :app:assembleRelease
141 | elif [[ "$build_type" == "bundle" ]]; then
142 | gradle :app:bundleRelease -Paab
143 | fi
144 | popd
145 |
--------------------------------------------------------------------------------
/scripts/ci-build.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 |
3 | ## This script is expected to be executed in a CI environment, or possibly in our Docker image instance
4 | ## DO NOT execute this manually!
5 |
6 | set -eu
7 | set -o pipefail
8 | set -o xtrace
9 |
10 | source "$(realpath $(dirname "$0"))/versions.sh"
11 |
12 | case "${BUILD_VARIANT}" in
13 | arm)
14 | BUILD_TYPE='apk'
15 | BUILD_ABI='armeabi-v7a'
16 | ;;
17 | x86_64)
18 | BUILD_TYPE='apk'
19 | BUILD_ABI='x86_64'
20 | ;;
21 | arm64)
22 | BUILD_TYPE='apk'
23 | BUILD_ABI='arm64-v8a'
24 | ;;
25 | bundle)
26 | BUILD_TYPE='bundle'
27 | ;;
28 | *)
29 | echo "Unknown build variant: '$BUILD_VARIANT'." >&2
30 | exit 1
31 | ;;
32 | esac
33 |
34 | if [[ "${CI_COMMIT_REF_NAME}" == "${PRODUCTION_BRANCH}" ]]; then
35 | # Set uBO assets to production variant
36 | # shellcheck disable=2183
37 | IRONFOX_UBO_ASSETS_URL="https://gitlab.com/ironfox-oss/IronFox/-/raw/${PRODUCTION_BRANCH}/uBlock/assets.${PRODUCTION_BRANCH}.json"
38 | export IRONFOX_UBO_ASSETS_URL
39 |
40 | echo "Using uBO Assets: ${IRONFOX_UBO_ASSETS_URL}"
41 | fi
42 |
43 | # Setup environment variables. See Dockerfile.
44 | source "/opt/env_docker.sh"
45 |
46 | # Setup Android SDK
47 | source "./scripts/setup-android-sdk.sh"
48 |
49 | # Get sources
50 | bash -x ./scripts/get_sources.sh
51 |
52 | # Update environment variables for this build
53 | source "scripts/env_local.sh"
54 |
55 | # Prepare sources
56 | bash -x ./scripts/prebuild.sh "$BUILD_VARIANT"
57 |
58 | # If we're building an APK set, the following environment variables are required
59 | if [[ "$BUILD_TYPE" == "bundle" ]]; then
60 | export MOZ_ANDROID_FAT_AAR_ARMEABI_V7A="$AAR_ARTIFACTS/geckoview-armeabi-v7a.aar"
61 | export MOZ_ANDROID_FAT_AAR_ARM64_V8A="$AAR_ARTIFACTS/geckoview-arm64-v8a.aar"
62 | export MOZ_ANDROID_FAT_AAR_X86_64="$AAR_ARTIFACTS/geckoview-x86_64.aar"
63 | export MOZ_ANDROID_FAT_AAR_ARCHITECTURES="armeabi-v7a,arm64-v8a,x86_64"
64 | fi
65 |
66 | # Set the build date to the date of commmit to ensure that the
67 | # MOZ_BUILDID is consistent across CI build jobs
68 | export MOZ_BUILD_DATE="$(date -d "$CI_PIPELINE_CREATED_AT" "+%Y%m%d%H%M%S")"
69 | export IF_BUILD_DATE="$CI_PIPELINE_CREATED_AT"
70 |
71 | # Build
72 | bash -x scripts/build.sh "$BUILD_TYPE"
73 |
74 | if [[ "$BUILD_TYPE" == "apk" ]]; then
75 | # Copy geckoview AAR
76 | cp -v "$mozilla_release"/obj/gradle/build/mobile/android/geckoview/outputs/aar/geckoview-release.aar \
77 | "$AAR_ARTIFACTS/geckoview-${BUILD_ABI}.aar"
78 |
79 | # Sign APK
80 | APK_IN="$(ls "$mozilla_release"/obj/gradle/build/mobile/android/fenix/app/outputs/apk/fenix/release/*.apk)"
81 | APK_OUT="$APK_ARTIFACTS/IronFox-v${FIREFOX_VERSION}-${BUILD_ABI}.apk"
82 | "$ANDROID_HOME/build-tools/35.0.0/apksigner" sign \
83 | --ks="$KEYSTORE" \
84 | --ks-pass="pass:$KEYSTORE_PASS" \
85 | --ks-key-alias="$KEYSTORE_KEY_ALIAS" \
86 | --key-pass="pass:$KEYSTORE_KEY_PASS" \
87 | --out="$APK_OUT" \
88 | "$APK_IN"
89 | fi
90 |
91 | if [[ "$BUILD_TYPE" == "bundle" ]]; then
92 | # Build signed APK set
93 | AAB_IN="$(ls "$mozilla_release"/obj/gradle/build/mobile/android/fenix/app/outputs/bundle/fenixRelease/*.aab)"
94 | APKS_OUT="$APKS_ARTIFACTS/IronFox-v${FIREFOX_VERSION}.apks"
95 | "$builddir"/bundletool build-apks \
96 | --bundle="$AAB_IN" \
97 | --output="$APKS_OUT" \
98 | --ks="$KEYSTORE" \
99 | --ks-pass="pass:$KEYSTORE_PASS" \
100 | --ks-key-alias="$KEYSTORE_KEY_ALIAS" \
101 | --key-pass="pass:$KEYSTORE_KEY_PASS"
102 | fi
103 |
--------------------------------------------------------------------------------
/scripts/ci-publish-packages.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 |
3 | # This file is expected to be executed in GitLab CI
4 | # DO NOT executed this manually!
5 |
6 | set -eu
7 |
8 | source "$(realpath $(dirname "$0"))/versions.sh"
9 |
10 | export GENERIC_PACKAGES_URL="${CI_API_V4_URL}/projects/${CI_PROJECT_ID}/packages/generic"
11 |
12 | upload_to_package_registry() {
13 | local file="$1"
14 | local package_name="$2"
15 | # shellcheck disable=SC2155
16 | local file_name="$(basename "$file")"
17 | curl --header "PRIVATE-TOKEN: $GITLAB_CI_API_TOKEN" \
18 | --upload-file "$file" \
19 | "$GENERIC_PACKAGES_URL/${package_name}/${FIREFOX_VERSION}/${file_name}"
20 | }
21 |
22 | export ARTIFACTS=$CI_PROJECT_DIR/artifacts
23 | export APK_ARTIFACTS=$ARTIFACTS/apk
24 | export APKS_ARTIFACTS=$ARTIFACTS/apks
25 | export BUILD_DIR="$CI_PROJECT_DIR/build"
26 |
27 | mkdir -p "$BUILD_DIR"
28 |
29 | RELEASE_NOTES_FILE="$BUILD_DIR/release-notes.md"
30 | CHECKSUMS_FILE="$BUILD_DIR/asset-checksums.txt"
31 | RELEASE_FILE="$BUILD_DIR/release.yml"
32 |
33 | echo -n "" > "$RELEASE_NOTES_FILE"
34 | echo -n "" > "$CHECKSUMS_FILE"
35 |
36 | declare -a assets
37 | upload_asset() {
38 | package_name="$1"
39 | file="$2"
40 | file_name="$(basename "$file")"
41 |
42 | echo "$(sha256sum -b "$file" | cut -d ' ' -f 1) ${file_name}" >> "$CHECKSUMS_FILE"
43 | upload_to_package_registry "$file" "$package_name"
44 | assets+=("{\"name\": \"$file_name\",\"url\": \"$GENERIC_PACKAGES_URL/${package_name}/${FIREFOX_VERSION}/${file_name}\",\"link_type\": \"package\",\"direct_asset_path\": \"/${file_name}\"}")
45 | }
46 |
47 | # Upload packages to package registry
48 | for apk in "$APK_ARTIFACTS"/*.apk; do
49 | package_name="apk"
50 | upload_asset "$package_name" "$apk"
51 |
52 | done
53 | for apks in "$APKS_ARTIFACTS"/*.apks; do
54 | package_name="apkset"
55 | upload_asset "$package_name" "$apks"
56 | done
57 |
58 | {
59 | changelog_file="$CI_PROJECT_DIR/changelogs/${FIREFOX_VERSION}.md"
60 | if [[ -f "$changelog_file" ]]; then
61 | cat "$changelog_file"
62 | fi
63 |
64 | echo "## Checksums"
65 | echo ""
66 | echo "\`\`\`"
67 | cat $CHECKSUMS_FILE
68 | echo "\`\`\`"
69 | echo ""
70 |
71 | echo "---"
72 | echo "_This release was automatically generated by the CI/CD pipeline ([view pipeline]($CI_JOB_URL)) and is guaranteed to be generated from commit [${CI_COMMIT_SHORT_SHA}](${CI_PROJECT_URL}/-/tree/${CI_COMMIT_SHA})._"
73 | echo ""
74 | } >> "$RELEASE_NOTES_FILE"
75 |
76 | {
77 | echo "---"
78 | echo "name: IronFox v${FIREFOX_VERSION}"
79 | echo "tag-name: v${FIREFOX_VERSION}"
80 | echo "description: |"
81 | awk '{print " " $0}' < "$RELEASE_NOTES_FILE"
82 | echo "assets-link:"
83 | for asset in "${assets[@]}"; do
84 | echo " - '$asset'"
85 | done
86 | } > "$RELEASE_FILE"
87 |
--------------------------------------------------------------------------------
/scripts/ci-update-fdroid.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 |
3 | # Script is used to update the F-Droid
4 | # This script is expected to be run in a CI environment
5 | # DO NOT execute this manually!
6 |
7 | set -eu
8 |
9 | git clone "https://oauth2:$GITLAB_CI_PUSH_TOKEN@gitlab.com/$TARGET_REPO_PATH.git" target-repo
10 | cd target-repo || { echo "Unable to cd into target-repo"; exit 1; };
11 | mkdir -p "$REPO_DIR"
12 |
13 | # Download all assets from the release
14 | curl --header "PRIVATE-TOKEN: $GITLAB_CI_API_TOKEN" \
15 | "${CI_API_V4_URL}/projects/${CI_PROJECT_ID}/releases/${CI_COMMIT_TAG}/assets/links" \
16 | | jq -c '.[] | select(.name | endswith(".apk"))' \
17 | | while read -r asset; do
18 | name=$(echo "$asset" | jq -r '.name')
19 | url=$(echo "$asset" | jq -r '.direct_asset_url')
20 | echo "Downloading $name from $url"
21 | curl -L --header "PRIVATE-TOKEN: $GITLAB_CI_API_TOKEN" "$url" -o "$REPO_DIR/$name"
22 | done
23 |
24 | # shellcheck disable=SC2046
25 | IFS=":" read -r vercode vername <<< "$("$CI_PROJECT_DIR"/scripts/get_latest_version.py $(ls "$REPO_DIR"/*.apk))"
26 |
27 | sed -i \
28 | -e "s/CurrentVersion: .*/CurrentVersion: \"v$vername\"/" \
29 | -e "s/CurrentVersionCode: .*/CurrentVersionCode: $vercode/" "$META_FILE"
30 |
31 | git add "$REPO_DIR" "$META_FILE"
32 | git commit -m "feat: update for release ${CI_COMMIT_TAG}"
33 | git push origin "HEAD:$TARGET_REPO_BRANCH"
--------------------------------------------------------------------------------
/scripts/ci-update-site.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 |
3 | # Script is used to update the ironfoxoss.org website repository.
4 | # This script is not intended to be executed manually!
5 |
6 | set -eu
7 |
8 | source "$(realpath $(dirname "$0"))/versions.sh"
9 |
10 | git clone "https://oauth2:$GITLAB_CI_PUSH_TOKEN@gitlab.com/$TARGET_REPO_PATH.git" target-repo
11 | cd target-repo || { echo "Unable to cd into target-repo"; exit 1; };
12 |
13 | # Generate documentation for patches
14 | ./scripts/gen_patch_pages.py ../scripts/patches.yaml
15 |
16 | # Update version name
17 | sed -i "s/IRONFOX_VERSION = .*/IRONFOX_VERSION = \"${FIREFOX_VERSION}\";/g" \
18 | ./src/version.ts
19 |
20 | # Commit changes
21 | git add src
22 | git commit -m "feat: update patch docs to reflect ironfox-oss/IronFox@$CI_COMMIT_SHA"
23 | git push origin "HEAD:$TARGET_REPO_BRANCH"
24 |
--------------------------------------------------------------------------------
/scripts/env_common.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 |
3 | # Caution: Should not be sourced directly!
4 | # Use 'env_local.sh' or 'env_fdroid.sh' instead.
5 |
6 | IRONFOX_LOCALES=$(<"$patches/locales")
7 | export IRONFOX_LOCALES
8 |
9 | export NSS_DIR="$application_services/libs/desktop/linux-x86-64/nss"
10 | export NSS_STATIC=1
11 |
12 | export ARTIFACTS="$rootdir/artifacts"
13 | export APK_ARTIFACTS=$ARTIFACTS/apk
14 | export APKS_ARTIFACTS=$ARTIFACTS/apks
15 | export AAR_ARTIFACTS=$ARTIFACTS/aar
16 |
17 | mkdir -p "$APK_ARTIFACTS"
18 | mkdir -p "$APKS_ARTIFACTS"
19 | mkdir -p "$AAR_ARTIFACTS"
20 |
21 | export env_source="true"
22 |
23 | if [[ -z ${CARGO_HOME+x} ]]; then
24 | export CARGO_HOME=$HOME/.cargo
25 | fi
26 |
27 | if [[ -z ${GRADLE_USER_HOME+x} ]]; then
28 | export GRADLE_USER_HOME=$HOME/.gradle
29 | fi
30 |
31 | if [[ -z ${IRONFOX_UBO_ASSETS_URL+x} ]]; then
32 | # Default to development assets
33 | # shellcheck disable=SC2059
34 | IRONFOX_UBO_ASSETS_URL="https://gitlab.com/ironfox-oss/IronFox/-/raw/dev/uBlock/assets.dev.json"
35 | export IRONFOX_UBO_ASSETS_URL
36 |
37 | echo "Using uBO Assets: ${IRONFOX_UBO_ASSETS_URL}"
38 | fi
39 |
--------------------------------------------------------------------------------
/scripts/env_fdroid.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 | #
3 | # Fennec build scripts
4 | # Copyright (C) 2020-2024 Andrew Nayenko, Tavi
5 | #
6 | # This program is free software: you can redistribute it and/or modify
7 | # it under the terms of the GNU Affero General Public License as
8 | # published by the Free Software Foundation, either version 3 of the
9 | # License, or (at your option) any later version.
10 | #
11 | # This program is distributed in the hope that it will be useful,
12 | # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 | # GNU Affero General Public License for more details.
15 | #
16 | # You should have received a copy of the GNU Affero General Public License
17 | # along with this program. If not, see .
18 | #
19 |
20 | export rootdir=$(dirname $(dirname "$(realpath "$0")"))
21 | export builddir="$rootdir/build"
22 | export patches="$rootdir/patches"
23 |
24 | export FDROID_SRCLIB=$(realpath "$rootdir/../srclib")
25 |
26 | export android_components="$FDROID_SRCLIB/MozFennec/mobile/android/android-components"
27 | export application_services="$FDROID_SRCLIB/MozAppServices"
28 | export glean="$FDROID_SRCLIB/MozGlean"
29 | export fenix="$FDROID_SRCLIB/MozFennec/mobile/android/fenix"
30 | export mozilla_release="$FDROID_SRCLIB/MozFennec"
31 | export rustup="$FDROID_SRCLIB/rustup"
32 | export wasi="$FDROID_SRCLIB/wasi-sdk"
33 | export gmscore="$FDROID_SRCLIB/gmscore"
34 | export llvm="$FDROID_SRCLIB/llvm"
35 | export llvm_android="$FDROID_SRCLIB/llvm_android"
36 | export toolchain_utils="$FDROID_SRCLIB/toolchain-utils"
37 |
38 | source "\$rootdir/scripts/env_common.sh"
39 |
--------------------------------------------------------------------------------
/scripts/gen_wordmark.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 | #License: AGPL-3.0
3 |
4 | drawable="../patches/fenix-overlay/res/drawable"
5 | font="Fira-Sans-Bold"
6 | wordmark="IronFox"
7 |
8 | convert -background transparent -fill black -font $font -gravity center -size x80 label:$wordmark $drawable-mdpi/ic_logo_wordmark_normal.webp
9 | convert -background transparent -fill white -font $font -gravity center -size x80 label:$wordmark $drawable-mdpi/ic_logo_wordmark_private.webp
10 | convert -background transparent -fill black -font $font -gravity center -size x80 label:$wordmark $drawable-mdpi/ic_wordmark_text_normal.webp
11 | convert -background transparent -fill white -font $font -gravity center -size x80 label:$wordmark $drawable-mdpi/ic_wordmark_text_private.webp
12 |
13 | convert -background transparent -fill black -font $font -gravity center -size x120 label:$wordmark $drawable-hdpi/ic_logo_wordmark_normal.webp
14 | convert -background transparent -fill white -font $font -gravity center -size x120 label:$wordmark $drawable-hdpi/ic_logo_wordmark_private.webp
15 | convert -background transparent -fill black -font $font -gravity center -size x120 label:$wordmark $drawable-hdpi/ic_wordmark_text_normal.webp
16 | convert -background transparent -fill white -font $font -gravity center -size x120 label:$wordmark $drawable-hdpi/ic_wordmark_text_private.webp
17 |
18 | convert -background transparent -fill black -font $font -gravity center -size x160 label:$wordmark $drawable-xhdpi/ic_logo_wordmark_normal.webp
19 | convert -background transparent -fill white -font $font -gravity center -size x160 label:$wordmark $drawable-xhdpi/ic_logo_wordmark_private.webp
20 | convert -background transparent -fill black -font $font -gravity center -size x160 label:$wordmark $drawable-xhdpi/ic_wordmark_text_normal.webp
21 | convert -background transparent -fill white -font $font -gravity center -size x160 label:$wordmark $drawable-xhdpi/ic_wordmark_text_private.webp
22 |
23 | convert -background transparent -fill black -font $font -gravity center -size x240 label:$wordmark $drawable-xxhdpi/ic_logo_wordmark_normal.webp
24 | convert -background transparent -fill white -font $font -gravity center -size x240 label:$wordmark $drawable-xxhdpi/ic_logo_wordmark_private.webp
25 | convert -background transparent -fill black -font $font -gravity center -size x240 label:$wordmark $drawable-xxhdpi/ic_wordmark_text_normal.webp
26 | convert -background transparent -fill white -font $font -gravity center -size x240 label:$wordmark $drawable-xxhdpi/ic_wordmark_text_private.webp
27 |
28 | convert -background transparent -fill black -font $font -gravity center -size x320 label:$wordmark $drawable-xxxhdpi/ic_logo_wordmark_normal.webp
29 | convert -background transparent -fill white -font $font -gravity center -size x320 label:$wordmark $drawable-xxxhdpi/ic_logo_wordmark_private.webp
30 | convert -background transparent -fill black -font $font -gravity center -size x320 label:$wordmark $drawable-xxxhdpi/ic_wordmark_text_normal.webp
31 | convert -background transparent -fill white -font $font -gravity center -size x320 label:$wordmark $drawable-xxxhdpi/ic_wordmark_text_private.webp
32 |
--------------------------------------------------------------------------------
/scripts/get_latest_version.py:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env python3
2 | #
3 | # common.py - part of the FDroid server tools
4 | #
5 | # Copyright (C) 2010-2016, Ciaran Gultnieks, ciaran@ciarang.com
6 | # Copyright (C) 2013-2017, Daniel Martí
7 | # Copyright (C) 2013-2021, Hans-Christoph Steiner
8 | # Copyright (C) 2017-2018, Torsten Grote
9 | # Copyright (C) 2017, tobiasKaminsky
10 | # Copyright (C) 2017-2021, Michael Pöhn
11 | # Copyright (C) 2017,2021, mimi89999
12 | # Copyright (C) 2019-2021, Jochen Sprickerhof
13 | # Copyright (C) 2021, Felix C. Stegerman
14 | #
15 | # This program is free software: you can redistribute it and/or modify
16 | # it under the terms of the GNU Affero General Public License as published by
17 | # the Free Software Foundation, either version 3 of the License, or
18 | # (at your option) any later version.
19 | #
20 | # This program is distributed in the hope that it will be useful,
21 | # but WITHOUT ANY WARRANTY; without even the implied warranty of
22 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23 | # GNU Affero General Public License for more details.
24 | #
25 | # You should have received a copy of the GNU Affero General Public License
26 | # along with this program. If not, see .
27 |
28 | import logging
29 | import os
30 | import sys
31 | import zipfile
32 | import androguard
33 | from androguard.core.apk import APK
34 | from androguard.core.axml import AXMLParser, format_value, START_TAG, END_TAG, TEXT, END_DOCUMENT
35 | import androguard.util
36 |
37 | def get_androguard_APK(apkfile, skip_analysis=False):
38 | return APK(apkfile, skip_analysis=skip_analysis)
39 |
40 | def ensure_final_value(packageName, arsc, value):
41 | """Ensure incoming value is always the value, not the resid.
42 |
43 | androguard will sometimes return the Android "resId" aka
44 | Resource ID instead of the actual value. This checks whether
45 | the value is actually a resId, then performs the Android
46 | Resource lookup as needed.
47 | """
48 | if value:
49 | returnValue = value
50 | if value[0] == '@':
51 | try: # can be a literal value or a resId
52 | res_id = int('0x' + value[1:], 16)
53 | res_id = arsc.get_id(packageName, res_id)[1]
54 | returnValue = arsc.get_string(packageName, res_id)[1]
55 | except (ValueError, TypeError):
56 | pass
57 | return returnValue
58 | return ''
59 |
60 |
61 | def get_apk_id_androguard(apkfile):
62 | """Read (appid, versionCode, versionName) from an APK.
63 |
64 | This first tries to do quick binary XML parsing to just get the
65 | values that are needed. It will fallback to full androguard
66 | parsing, which is slow, if it can't find the versionName value or
67 | versionName is set to a Android String Resource (e.g. an integer
68 | hex value that starts with @).
69 |
70 | This function is part of androguard as get_apkid(), so this
71 | vendored and modified to return versionCode as an integer.
72 |
73 | """
74 | if not os.path.exists(apkfile):
75 | raise Exception("Reading packageName/versionCode/versionName failed, APK invalid: '{apkfilename}'"
76 | .format(apkfilename=apkfile))
77 |
78 | appid = None
79 | versionCode = None
80 | versionName = None
81 | with zipfile.ZipFile(apkfile) as apk:
82 | with apk.open('AndroidManifest.xml') as manifest:
83 | axml = AXMLParser(manifest.read())
84 | count = 0
85 | while axml.is_valid():
86 | _type = next(axml)
87 | count += 1
88 | if _type == START_TAG:
89 | for i in range(0, axml.getAttributeCount()):
90 | name = axml.getAttributeName(i)
91 | _type = axml.getAttributeValueType(i)
92 | _data = axml.getAttributeValueData(i)
93 | value = format_value(_type, _data, lambda _: axml.getAttributeValue(i))
94 | if appid is None and name == 'package':
95 | appid = value
96 | elif versionCode is None and name == 'versionCode':
97 | if value.startswith('0x'):
98 | versionCode = int(value, 16)
99 | else:
100 | versionCode = int(value)
101 | elif versionName is None and name == 'versionName':
102 | versionName = value
103 |
104 | if axml.getName() == 'manifest':
105 | break
106 | elif _type in (END_TAG, TEXT, END_DOCUMENT):
107 | raise RuntimeError('{path}: must be the first element in AndroidManifest.xml'
108 | .format(path=apkfile))
109 |
110 | if not versionName or versionName[0] == '@':
111 | a = get_androguard_APK(apkfile)
112 | versionName = ensure_final_value(a.package, a.get_android_resources(), a.get_androidversion_name())
113 | if not versionName:
114 | versionName = '' # versionName is expected to always be a str
115 |
116 | return appid, versionCode, versionName.strip('\0')
117 |
118 | def main(params):
119 | # Disable logging since the output of this script is parsed
120 | androguard.util.set_log('ERROR')
121 |
122 | latest_vercode, latest_vername = None, None
123 | for apk in params:
124 | if not os.path.exists(apk) or not os.path.isfile(apk):
125 | raise RuntimeError(f"APK file {apk} does not exist or is not a file")
126 |
127 | appid, vercode, vername = get_apk_id_androguard(apk)
128 | # print("APK:", apk)
129 | # print(" ID:", appid)
130 | # print(" Version code:", vercode)
131 | # print(" Version name:", vername)
132 |
133 | if not latest_vercode or latest_vercode < vercode: # type: ignore
134 | latest_vercode = vercode
135 | latest_vername = vername
136 |
137 | if not latest_vercode:
138 | raise RuntimeError("Failed to find latest version code")
139 |
140 | if not latest_vername:
141 | raise RuntimeError("Failed to find latest version name")
142 |
143 | print("{}:{}".format(latest_vercode, latest_vername))
144 |
145 | if __name__ == "__main__":
146 | main(sys.argv[1:])
147 |
--------------------------------------------------------------------------------
/scripts/get_sources.sh:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env bash
2 |
3 | set -euo pipefail
4 |
5 | source "$(dirname $0)/versions.sh"
6 |
7 | clone_repo() {
8 | url="$1"
9 | path="$2"
10 | tag="$3"
11 |
12 | if [[ "$url" == "" ]]; then
13 | echo "URL missing for clone"
14 | exit 1
15 | fi
16 |
17 | if [[ "$path" == "" ]]; then
18 | echo "Path is required for cloning '$url'"
19 | exit 1
20 | fi
21 |
22 | if [[ "$tag" == "" ]]; then
23 | echo "Tag name is required for cloning '$url'"
24 | exit 1
25 | fi
26 |
27 | if [[ -f "$path" ]]; then
28 | echo "'$path' exists and is not a directory"
29 | exit 1
30 | fi
31 |
32 | if [[ -d "$path" ]]; then
33 | echo "'$path' already exists"
34 | read -p "Do you want to re-clone this repository? [y/N] " -n 1 -r
35 | echo
36 | if [[ $REPLY =~ ^[Nn]$ ]]; then
37 | return 0
38 | fi
39 | fi
40 |
41 | echo "Cloning $url::$tag"
42 | git clone --branch "$tag" --depth=1 "$url" "$path"
43 | }
44 |
45 | download() {
46 | local url="$1"
47 | local filepath="$2"
48 |
49 | if [[ "$url" == "" ]]; then
50 | echo "URL is required (file: '$filepath')"
51 | exit 1
52 | fi
53 |
54 | if [ -f "$filepath" ]; then
55 | echo "$filepath already exists."
56 | read -p "Do you want to re-download? [y/N] " -n 1 -r
57 | echo
58 | if [[ $REPLY =~ ^[Yy]$ ]]; then
59 | echo "Removing $filepath..."
60 | rm -f "$filepath"
61 | else
62 | return 0
63 | fi
64 | fi
65 |
66 | mkdir -p "$(dirname "$filepath")"
67 |
68 | echo "Downloading $url"
69 | wget "$url" -O "$filepath"
70 | }
71 |
72 | # Extract zip removing top level directory
73 | extract_rmtoplevel() {
74 | local archive_path="$1"
75 | local to_name="$2"
76 | local extract_to="${ROOTDIR}/$to_name"
77 |
78 | if ! [[ -f "$archive_path" ]]; then
79 | echo "Archive '$archive_path' does not exist!"
80 | fi
81 |
82 | # Create temporary directory for extraction
83 | local temp_dir=$(mktemp -d)
84 |
85 | # Extract based on file extension
86 | case "$archive_path" in
87 | *.zip)
88 | unzip -q "$archive_path" -d "$temp_dir"
89 | ;;
90 | *.tar.gz)
91 | tar xzf "$archive_path" -C "$temp_dir"
92 | ;;
93 | *.tar.xz)
94 | tar xJf "$archive_path" -C "$temp_dir"
95 | ;;
96 | *)
97 | echo "Unsupported archive format: $archive_path"
98 | rm -rf "$temp_dir"
99 | exit 1
100 | ;;
101 | esac
102 |
103 | local top_dir=$(ls "$temp_dir")
104 | local to_parent=$(dirname "$extract_to")
105 |
106 | rm -rf "$extract_to"
107 | mkdir -p "$to_parent"
108 | mv "$temp_dir/$top_dir" "$to_parent/$to_name"
109 |
110 | rm -rf "$temp_dir"
111 | }
112 |
113 | download_and_extract() {
114 | local repo_name="$1"
115 | local url="$2"
116 |
117 | local extension
118 | if [[ "$url" =~ \.tar\.xz$ ]]; then
119 | extension=".tar.xz"
120 | elif [[ "$url" =~ \.tar\.gz$ ]]; then
121 | extension=".tar.gz"
122 | else
123 | extension=".zip"
124 | fi
125 |
126 | local repo_archive="${BUILDDIR}/${repo_name}${extension}"
127 |
128 | download "$url" "$repo_archive"
129 |
130 | if [ ! -f "$repo_archive" ]; then
131 | echo "Source archive for $repo_name does not exist."
132 | exit 1
133 | fi
134 |
135 | echo "Extracting $repo_archive"
136 | extract_rmtoplevel "$repo_archive" "$repo_name"
137 | echo
138 | }
139 |
140 | mkdir -p "$BUILDDIR"
141 |
142 | if ! [[ -f "$BUILDDIR/bundletool.jar" ]]; then
143 | echo "Downloading bundletool..."
144 | wget https://github.com/google/bundletool/releases/download/${BUNDLETOOL_TAG}/bundletool-all-${BUNDLETOOL_TAG}.jar \
145 | -O "$BUILDDIR/bundletool.jar"
146 | fi
147 |
148 | if ! [[ -f "$BUILDDIR/bundletool" ]]; then
149 | echo "Creating bundletool script..."
150 | {
151 | echo '#!/bin/bash'
152 | echo "exec java -jar ${BUILDDIR}/bundletool.jar \"\$@\""
153 | } > "$BUILDDIR/bundletool"
154 | chmod +x "$BUILDDIR/bundletool"
155 | fi
156 |
157 | echo "'bundletool' is set up at $BUILDDIR/bundletool"
158 |
159 | # Clone Glean
160 | clone_repo "https://github.com/mozilla/glean" "$GLEANDIR" "$GLEAN_TAG"
161 |
162 | # Clone MicroG
163 | clone_repo "https://github.com/microg/GmsCore" "$GMSCOREDIR" "$GMSCORE_TAG"
164 |
165 | # Get WebAssembly SDK
166 | if [[ -z ${FDROID_BUILD+x} ]]; then
167 | echo "Downloading prebuilt wasi-sdk..."
168 | download_and_extract "wasi-sdk" "https://github.com/itsaky/ironfox/releases/download/$WASI_TAG/$WASI_TAG-firefox.tar.xz"
169 | else
170 | echo "Cloning wasi-sdk..."
171 | clone_repo "https://github.com/WebAssembly/wasi-sdk" "$WASISDKDIR" "$WASI_TAG"
172 | (cd "$WASISDKDIR" && git submodule update --init --depth=1)
173 | fi
174 |
175 | # Clone application-services
176 | echo "Cloning appservices..."
177 | clone_repo "https://github.com/mozilla/application-services" "$APPSERVICESDIR" "$APPSERVICES_TAG"
178 | (cd "$APPSERVICESDIR" && git submodule update --init --depth=1)
179 |
180 | # Download Firefox Source
181 | download_and_extract "gecko" "https://archive.mozilla.org/pub/firefox/${FIREFOX_RELEASE_PATH}/source/firefox-${FIREFOX_VERSION}.source.tar.xz"
182 | #download_and_extract "gecko" "https://github.com/mozilla-firefox/firefox/archive/refs/tags/${FIREFOX_RELEASE_TAG}.tar.gz"
183 |
184 | # Write env_local.sh
185 | echo "Writing ${ENV_SH}..."
186 | cat > "$ENV_SH" << EOF
187 | export patches=${PATCHDIR}
188 | export rootdir=${ROOTDIR}
189 | export builddir="${BUILDDIR}"
190 | export android_components=${ANDROID_COMPONENTS}
191 | export application_services=${APPSERVICESDIR}
192 | export glean=${GLEANDIR}
193 | export fenix=${FENIX}
194 | export mozilla_release=${GECKODIR}
195 | export gmscore=${GMSCOREDIR}
196 | export wasi=${WASISDKDIR}
197 |
198 | source "\$rootdir/scripts/env_common.sh"
199 | EOF
200 |
--------------------------------------------------------------------------------
/scripts/localize_maven.py:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env python3
2 | import re
3 | import argparse
4 |
5 | def localize_maven(file_path):
6 | """
7 | Localize Maven repositories, replacing non-plugin repositories with mavenLocal().
8 |
9 | Handles:
10 | - Nested braces
11 | - Single and multi-line comments
12 | - Both Groovy and Kotlin DSL syntax
13 | """
14 | with open(file_path, "r") as f:
15 | lines = f.readlines()
16 |
17 | processed_lines = []
18 | maven_block_content = []
19 | in_maven_block = False
20 | in_comment = False
21 | ignore = False
22 | brace_depth = 0
23 |
24 | for line in lines:
25 | # Handle single-line comments
26 | if not in_maven_block and re.match(r'^\s*//.*$', line):
27 | processed_lines.append(line)
28 | continue
29 |
30 | # Handle multi-line comments
31 | if not in_comment and "/*" in line:
32 | if "*/" not in line:
33 | in_comment = True
34 | if in_maven_block:
35 | maven_block_content.append(line)
36 | else:
37 | processed_lines.append(line)
38 | continue
39 |
40 | if in_comment:
41 | if "*/" in line:
42 | in_comment = False
43 | if in_maven_block:
44 | maven_block_content.append(line)
45 | else:
46 | processed_lines.append(line)
47 | continue
48 |
49 | # Track maven blocks
50 | if not in_maven_block and len(re.findall(r'maven\s*\{', line)) > 0:
51 | in_maven_block = True
52 | brace_depth = 1
53 | maven_block_content = [line]
54 | ignore = False
55 | continue
56 |
57 | if in_maven_block:
58 | brace_depth += line.count("{") - line.count("}")
59 | maven_block_content.append(line)
60 |
61 | if "plugins.gradle.org" in line:
62 | ignore = True
63 |
64 | if brace_depth == 0:
65 | if ignore:
66 | processed_lines.extend(maven_block_content)
67 | else:
68 | processed_lines.append(" mavenLocal()\n")
69 |
70 | # Reset state
71 | in_maven_block = False
72 | maven_block_content = []
73 | ignore = False
74 | continue
75 |
76 | if not in_maven_block:
77 | processed_lines.append(line)
78 |
79 | with open(file_path, "w") as f:
80 | f.writelines(processed_lines)
81 |
82 | print(f"Processed file: {file_path}")
83 |
84 |
85 | def main():
86 | parser = argparse.ArgumentParser(
87 | description="Localize Maven repositories in Gradle build files."
88 | )
89 | parser.add_argument("file", help="Path to the Gradle build file")
90 | args = parser.parse_args()
91 |
92 | localize_maven(args.file)
93 |
94 |
95 | if __name__ == "__main__":
96 | main()
97 |
--------------------------------------------------------------------------------
/scripts/setup-android-sdk.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 |
3 | SDK_REVISION=13114758
4 | ANDROID_SDK_FILE=commandlinetools-linux-${SDK_REVISION}_latest.zip
5 |
6 | if [[ "${ANDROID_HOME+x}" == "" ]]; then
7 | export ANDROID_HOME=$HOME/android-sdk
8 | fi
9 |
10 | export ANDROID_SDK_ROOT="$ANDROID_HOME"
11 |
12 | if [ ! -d "$ANDROID_HOME" ]; then
13 | mkdir -p "$ANDROID_HOME"
14 | cd "$ANDROID_HOME/.." || exit 1
15 | rm -Rf "$(basename "$ANDROID_HOME")"
16 |
17 | # https://developer.android.com/studio/index.html#command-tools
18 | echo "Downloading Android SDK..."
19 | wget https://dl.google.com/android/repository/${ANDROID_SDK_FILE} -O tools-$SDK_REVISION.zip
20 | rm -Rf "$ANDROID_HOME"
21 | mkdir -p "$ANDROID_HOME/cmdline-tools"
22 | unzip -q tools-$SDK_REVISION.zip -d "$ANDROID_HOME/cmdline-tools"
23 | mv "$ANDROID_HOME/cmdline-tools/cmdline-tools" "$ANDROID_HOME/cmdline-tools/latest"
24 | rm -vf tools-$SDK_REVISION.zip
25 | fi
26 |
27 | if [ -x "$ANDROID_HOME/cmdline-tools/latest/bin/sdkmanager" ]; then
28 | SDK_MANAGER="$ANDROID_HOME/cmdline-tools/latest/bin/sdkmanager"
29 | elif [ -x "$ANDROID_HOME/cmdline-tools/bin/sdkmanager" ]; then
30 | SDK_MANAGER="$ANDROID_HOME/cmdline-tools/bin/sdkmanager"
31 | else
32 | echo "ERROR: no usable sdkmanager found in $ANDROID_HOME" >&2
33 | echo "Checking other possible paths: (empty if not found)" >&2
34 | find "$ANDROID_HOME" -type f -name sdkmanager >&2
35 | return
36 | fi
37 |
38 | PATH=$PATH:$(dirname "$SDK_MANAGER")
39 | export PATH
40 |
41 | # Accept licenses
42 | { yes || true; } | sdkmanager --sdk_root="$ANDROID_HOME" --licenses
43 |
44 | $SDK_MANAGER 'build-tools;36.0.0' # for GeckoView
45 | $SDK_MANAGER 'ndk;28.0.13004108' # for GleanAS
46 | $SDK_MANAGER 'ndk;28.1.13356709' # for mozbuild; application-services
47 |
48 | export ANDROID_NDK="$ANDROID_HOME/ndk/28.1.13356709"
49 | [ -d "$ANDROID_NDK" ] || {
50 | echo "$ANDROID_NDK does not exist."
51 | return
52 | }
53 |
54 | echo "INFO: Using sdkmanager ... $SDK_MANAGER"
55 | echo "INFO: Using NDK ... $ANDROID_NDK"
56 |
--------------------------------------------------------------------------------
/scripts/versions.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 | # shellcheck disable=SC2034
3 |
4 | # Sources
5 | FIREFOX_VERSION="139.0"
6 | FIREFOX_RELEASE_TAG="FIREFOX-ANDROID_${FIREFOX_VERSION//./_}_RELEASE"
7 | FIREFOX_RELEASE_PATH="releases/${FIREFOX_VERSION}"
8 | #FIREFOX_RC_BUILD_NAME="build1"
9 | #FIREFOX_RELEASE_TAG="FIREFOX_${FIREFOX_VERSION//./_}_${FIREFOX_RC_BUILD_NAME^^}"
10 | #FIREFOX_RELEASE_PATH="candidates/${FIREFOX_VERSION}-candidates/${FIREFOX_RC_BUILD_NAME}"
11 | WASI_TAG="wasi-sdk-20"
12 | GLEAN_TAG="v64.1.1"
13 | GMSCORE_TAG="v0.3.7.250932"
14 | APPSERVICES_TAG="v139.0"
15 |
16 | # Tools
17 | BUNDLETOOL_TAG="1.18.0"
18 | RUST_VERSION="1.83.0"
19 | CBINDGEN_VERSION="0.28.0"
20 |
21 | # Configuration
22 | ROOTDIR="$(cd "$(dirname "${BASH_SOURCE[0]}")/.." && pwd)"
23 | ENV_SH="${ROOTDIR}/scripts/env_local.sh"
24 | BUILDDIR="${ROOTDIR}/build"
25 | PATCHDIR="${ROOTDIR}/patches"
26 | GECKODIR="${ROOTDIR}/gecko"
27 | GLEANDIR="${ROOTDIR}/glean"
28 | APPSERVICESDIR="${ROOTDIR}/appservices"
29 | GMSCOREDIR="${ROOTDIR}/gmscore"
30 | WASISDKDIR="${ROOTDIR}/wasi-sdk"
31 | ANDROID_COMPONENTS="${GECKODIR}/mobile/android/android-components"
32 | FENIX="${GECKODIR}/mobile/android/fenix"
33 |
--------------------------------------------------------------------------------