diff options
author | Ian Eure <ian@retrospec.tv> | 2024-11-06 06:26:00 -0800 |
---|---|---|
committer | Ludovic Courtès <ludo@gnu.org> | 2024-11-06 17:23:35 +0100 |
commit | 280aa6b57d7b741a7d8b076e1afa3dff23569332 (patch) | |
tree | 394db3dcebdbeaf522f59b0514fab41584bfdcdc /gnu | |
parent | 0ad0f8a1fa9c711f4df5908ebf800a9400f5bbc9 (diff) | |
download | guix-280aa6b57d7b741a7d8b076e1afa3dff23569332.tar.gz guix-280aa6b57d7b741a7d8b076e1afa3dff23569332.zip |
gnu: librewolf: Update to 132.0-1 [security fixes].
New upstream version. The 132.0-2-1 release switches to the firefox-l10n
repository, necessitating rework of locale handling.
131.0.3-1 fixes CVEs:
CVE-2024-9936: Undefined behavior in selection node cache
132.0-1 fixes CVEs:
CVE-2024-10458: Permission leak via embed or object elements
CVE-2024-10459: Use-after-free in layout with accessibility
CVE-2024-10460: Confusing display of origin for external protocol
handler prompt
CVE-2024-10461: XSS due to Content-Disposition being ignored in
multipart/x-mixed-replace response
CVE-2024-10462: Origin of permission prompt could be spoofed by long
URL
CVE-2024-10463: Cross origin video frame leak
CVE-2024-10468: Race conditions in IndexedDB
CVE-2024-10464: History interface could have been used to cause a
Denial of Service condition in the browser
CVE-2024-10465: Clipboard "paste" button persisted across tabs
CVE-2024-10466: DOM push subscription message could hang Firefox
CVE-2024-10467: Memory safety bugs fixed in Firefox 132, Thunderbird
132, Firefox ESR 128.4, and Thunderbird 128.4
* gnu/packages/librewolf.scm (librewolf): Update to 132.0-1.
Change-Id: I4afbcb496a8b0a329254762259cd1598d574761e
Signed-off-by: Ludovic Courtès <ludo@gnu.org>
Diffstat (limited to 'gnu')
-rw-r--r-- | gnu/packages/librewolf.scm | 68 | ||||
-rw-r--r-- | gnu/packages/patches/librewolf-neuter-locale-download.patch | 17 |
2 files changed, 41 insertions, 44 deletions
diff --git a/gnu/packages/librewolf.scm b/gnu/packages/librewolf.scm index d696a3058f..6517c1953d 100644 --- a/gnu/packages/librewolf.scm +++ b/gnu/packages/librewolf.scm @@ -111,10 +111,21 @@ (commit version) (recursive? #t))) (file-name (git-file-name "librewolf-source" version)) + (patches (search-patches "librewolf-neuter-locale-download.patch")) (sha256 (base32 hash)))) (define computed-origin-method (@@ (guix packages) computed-origin-method)) +(define firefox-l10n + (let ((commit "bdfd4e10606204450a3e88d219ecf2b252349c2b")) + (origin + (method git-fetch) + (uri (git-reference + (url "https://github.com/mozilla-l10n/firefox-l10n.git") + (commit commit))) + (file-name (git-file-name "firefox-l10n" commit)) + (sha256 (base32 "0i31b1024jck6467j9phcqvac32psl4nkyb0nm4h9zzyj8zw31xp"))))) + (define* (make-librewolf-source #:key version firefox-hash librewolf-hash) (let* ((ff-src (firefox-source-origin (car (string-split version #\-)) @@ -168,34 +179,10 @@ ;; Stage locales. (begin - (format #t "Staging locales...~%") - (force-output) - (mkdir "l10n-staging") - (with-directory-excursion "l10n-staging" - (for-each - (lambda (locale-dir) - (let ((locale - (string-drop - (basename locale-dir) - (+ 32 ; length of hash - (string-length "-mozilla-locale-"))))) - (format #t " ~a~%" locale) - (force-output) - (copy-recursively locale-dir locale - #:log (%make-void-port "w")) - (for-each make-file-writable (find-files locale)) - (with-directory-excursion locale - (when (file-exists? ".hgtags") - (delete-file ".hgtags"))))) - '#+all-mozilla-locales))) - - ;; Patch build script to use staged locales. - (begin - (substitute* '("scripts/generate-locales.sh") - (("wget") "# wget") - (("unzip") "# unzip") - (("mv browser/locales/l10n/\\$1-\\*/") - "mv ../l10n-staging/$1/"))) + (substitute* "scripts/librewolf-patches.py" + (("l10n_dir = Path(\"..\", \"l10n\")") + (string-append + "l10n_dir = \"" #+firefox-l10n "\"")))) ;; Run the build script (invoke "make" "all") @@ -212,18 +199,17 @@ ;; Update this id with every update to its release date. ;; It's used for cache validation and therefore can lead to strange bugs. ;; ex: date '+%Y%m%d%H%M%S' -(define %librewolf-build-id "20241010143544") +(define %librewolf-build-id "20241105185710") (define-public librewolf (package (name "librewolf") - (version "131.0.2-1") + (version "132.0-1") (source - (origin - (inherit (make-librewolf-source - #:version version - #:firefox-hash "05knnwfxqd3mb6a5y2yh73sn4g648dxnz9kpkmpj9madr55863h4" - #:librewolf-hash "1knx485kdjv8d0rn5ai1x1jp0403dvxz9m7lpim1y2d2ilyi26x7")))) + (make-librewolf-source + #:version version + #:firefox-hash "0zjwqn13rbzyxa3f63mvz5xv0158bsvr2llpqrh48davi52b2249" + #:librewolf-hash "1kfpcv89kh2521f3c296asjizb1swb15mfkkkrlis9ncm1gp6fw6")) (build-system gnu-build-system) (arguments (list @@ -325,14 +311,7 @@ ;; Lock the preferences so they can't be enabled. (substitute* "lw/librewolf.cfg" (("defaultPref\\(\"browser\\.ml\\.") - "lockPref(\"browser.ml.")) - ;; Correct a preference typo - ;; see https://codeberg.org/librewolf/issues/issues/1919#issuecomment-2325954 - ;; Remove this in the next update. - (substitute* "lw/librewolf.cfg" - (("browser\\.ml\\.enabled") - "browser.ml.enable")) - )) + "lockPref(\"browser.ml.")))) (add-after 'patch-source-shebangs 'patch-cargo-checksums (lambda _ (use-modules (guix build cargo-utils)) @@ -417,6 +396,7 @@ (which "bash")) (setenv "MACH_BUILD_PYTHON_NATIVE_PACKAGE_SOURCE" "system") + (setenv "LANG" "en_US.utf8") ;; This should use the host info probably (does it ;; build on non-x86_64 though?) (setenv "GUIX_PYTHONPATH" @@ -625,7 +605,7 @@ (substitute* desktop-file (("^Exec=@MOZ_APP_NAME@") (string-append "Exec=" - #$output "/bin/librewolf %u")) + #$output "/bin/librewolf")) (("@MOZ_APP_DISPLAYNAME@") "LibreWolf") (("@MOZ_APP_REMOTINGNAME@") diff --git a/gnu/packages/patches/librewolf-neuter-locale-download.patch b/gnu/packages/patches/librewolf-neuter-locale-download.patch new file mode 100644 index 0000000000..da300542f5 --- /dev/null +++ b/gnu/packages/patches/librewolf-neuter-locale-download.patch @@ -0,0 +1,17 @@ +diff --git a/scripts/librewolf-patches.py b/scripts/librewolf-patches.py +index 48dc6bc..01a6c58 100755 +--- a/scripts/librewolf-patches.py ++++ b/scripts/librewolf-patches.py +@@ -147,12 +147,6 @@ def librewolf_patches(): + with open(file, "w") as f: + f.write("{}-{}".format(version,release)) + +- print("-> Downloading locales from https://github.com/mozilla-l10n/firefox-l10n") +- with TemporaryDirectory() as tmpdir: +- exec(f"wget -qO {tmpdir}/l10n.zip 'https://codeload.github.com/mozilla-l10n/firefox-l10n/zip/refs/heads/main'") +- exec(f"unzip -qo {tmpdir}/l10n.zip -d {tmpdir}/l10n") +- exec(f"mv {tmpdir}/l10n/firefox-l10n-main lw/l10n") +- + print("-> Patching appstrings.properties") + # Why is "Firefox" hardcoded there??? + exec("find . -path '*/appstrings.properties' -exec sed -i s/Firefox/LibreWolf/ {} \;") |