summaryrefslogtreecommitdiff
path: root/data
diff options
context:
space:
mode:
authordd <dd@wx.tnyzeq.icu>2024-06-24 07:24:54 +0200
committerdd <dd@wx.tnyzeq.icu>2024-06-24 07:24:54 +0200
commit30a0a045e81bc74ed2b5aca55a21a9b29a983708 (patch)
treef32594d8c918144c99fde2e7a8c5523e285f878d /data
parent7abcd9763b52211dadb623aef9af9430b8bc94ae (diff)
downloadvyos-build-30a0a045e81bc74ed2b5aca55a21a9b29a983708.tar.gz
vyos-build-30a0a045e81bc74ed2b5aca55a21a9b29a983708.zip
build: added APT KEYEXPIRED workaround
Diffstat (limited to 'data')
-rw-r--r--data/live-build-config/includes.chroot/etc/apt/apt.conf.d/01gpgvnoexpkeysig1
-rwxr-xr-xdata/live-build-config/includes.chroot/usr/libexec/gpgvnoexpkeysig51
2 files changed, 52 insertions, 0 deletions
diff --git a/data/live-build-config/includes.chroot/etc/apt/apt.conf.d/01gpgvnoexpkeysig b/data/live-build-config/includes.chroot/etc/apt/apt.conf.d/01gpgvnoexpkeysig
new file mode 100644
index 00000000..8bb07cd2
--- /dev/null
+++ b/data/live-build-config/includes.chroot/etc/apt/apt.conf.d/01gpgvnoexpkeysig
@@ -0,0 +1 @@
+Apt::Key::gpgvcommand "/usr/libexec/gpgvnoexpkeysig";
diff --git a/data/live-build-config/includes.chroot/usr/libexec/gpgvnoexpkeysig b/data/live-build-config/includes.chroot/usr/libexec/gpgvnoexpkeysig
new file mode 100755
index 00000000..f528ee4b
--- /dev/null
+++ b/data/live-build-config/includes.chroot/usr/libexec/gpgvnoexpkeysig
@@ -0,0 +1,51 @@
+#!/bin/sh
+#
+# No copyright is claimed. This code is in the public domain; do with
+# it what you wish.
+#
+# Author: Johannes Schauer Marin Rodrigues <josch@mister-muffin.de>
+#
+# This is a wrapper around gpgv as invoked by apt. It turns EXPKEYSIG results
+# from gpgv into GOODSIG results. This is necessary for apt to access very old
+# timestamps from snapshot.debian.org for which the GPG key is already expired:
+#
+# Get:1 http://snapshot.debian.org/archive/debian/20150106T000000Z unstable InRelease [242 kB]
+# Err:1 http://snapshot.debian.org/archive/debian/20150106T000000Z unstable InRelease
+# The following signatures were invalid: EXPKEYSIG 8B48AD6246925553 Debian Archive Automatic Signing Key (7.0/wheezy) <ftpmaster@debian.org>
+# Reading package lists...
+# W: GPG error: http://snapshot.debian.org/archive/debian/20150106T000000Z unstable InRelease: The following signatures were invalid: EXPKEYSIG 8B48AD6246925553 Debian Archive Automatic Signing Key (7.0/wheezy) <ftpmaster@debian.org>
+# E: The repository 'http://snapshot.debian.org/archive/debian/20150106T000000Z unstable InRelease' is not signed.
+#
+# To use this script, call apt with
+#
+# -o Apt::Key::gpgvcommand=/usr/libexec/mmdebstrap/gpgvnoexpkeysig
+#
+# Scripts doing similar things can be found here:
+#
+# * debuerreotype as /usr/share/debuerreotype/scripts/.gpgv-ignore-expiration.sh
+# * derivative census: salsa.d.o/deriv-team/census/-/blob/master/bin/fakegpgv
+
+set -eu
+
+find_gpgv_status_fd() {
+ while [ "$#" -gt 0 ]; do
+ if [ "$1" = '--status-fd' ]; then
+ echo "$2"
+ return 0
+ fi
+ shift
+ done
+ # default fd is stdout
+ echo 1
+}
+GPGSTATUSFD="$(find_gpgv_status_fd "$@")"
+
+case $GPGSTATUSFD in
+ ''|*[!0-9]*)
+ echo "invalid --status-fd argument" >&2
+ exit 1
+ ;;
+esac
+
+# we need eval because we cannot redirect a variable fd
+eval 'exec gpgv "$@" '"$GPGSTATUSFD"'>&1 | sed "s/^\[GNUPG:\] EXPKEYSIG /[GNUPG:] GOODSIG /" >&'"$GPGSTATUSFD"