]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
mkosi: trim verity.sig json files to remove NUL padding before passing to jq
authorLuca Boccassi <luca.boccassi@gmail.com>
Wed, 22 Apr 2026 12:55:37 +0000 (13:55 +0100)
committerLuca Boccassi <luca.boccassi@gmail.com>
Wed, 22 Apr 2026 12:56:13 +0000 (13:56 +0100)
jq started rejecting input that has NUL bytes to fix some security issues,
so we need to trim the verity.sig json files, which are spat out with
the NUL bytes padding from the GPT partition content.

‣  Running postinstall script /home/runner/work/systemd/systemd/mkosi/mkosi.postinst.chroot…
jq: parse error: Invalid numeric literal at EOF at line 1, column 16384
‣ "/work/postinst final" returned non-zero exit code 5.

https://github.com/jqlang/jq/commit/6374ae0bcdfe33a18eb0ae6db28493b1f34a0a5b

mkosi/mkosi.postinst.chroot

index eb6d9170252a304f723d92d45c0f99ddcc57cbbc..de67ddfdc85b44bb572fbe01f80b24ce0508c147 100755 (executable)
@@ -27,8 +27,9 @@ mountpoint -q /etc/resolv.conf && umount /etc/resolv.conf
 rm -f /etc/resolv.conf
 
 for f in "$BUILDROOT"/usr/share/*.verity.sig; do
-    jq --join-output '.rootHash' "$f" >"${f%.verity.sig}.roothash"
-    jq --join-output '.signature' "$f" | base64 --decode >"${f%.verity.sig}.roothash.p7s"
+    # jq started refusing input with NUL bytes padding
+    strings "$f" | jq --join-output '.rootHash' >"${f%.verity.sig}.roothash"
+    strings "$f" | jq --join-output '.signature' | base64 --decode >"${f%.verity.sig}.roothash.p7s"
 done
 
 # We want /var/log/journal to be created on first boot so it can be created with the right chattr settings by