Compare commits

...

2 Commits

Author SHA1 Message Date
Patrick Cao Huu Thien 7ce23412c0
add gpg verify with automatic import pub key 2024-10-18 02:24:40 +02:00
Patrick Cao Huu Thien 10a92d2456
use compress with base64|gzip 2024-10-18 00:07:41 +02:00
2 changed files with 57 additions and 13 deletions

1
README
View File

@ -1,6 +1,5 @@
*shasumscript* is a tool to generate a self-checksum-script. *shasumscript* is a tool to generate a self-checksum-script.
Usage Usage
shasumscript script.sh shasumscript script.sh

View File

@ -13,6 +13,8 @@ err() { error "$*"; exit 1; }
usage() { echo "Usage: $(basename "$0") [-V | -h] <file>";echo " -V: Show version"; echo " -h: Show this help"; } usage() { echo "Usage: $(basename "$0") [-V | -h] <file>";echo " -V: Show version"; echo " -h: Show this help"; }
err_usage() { error "$*"; usage; exit 1; } err_usage() { error "$*"; usage; exit 1; }
step () { err="$?"; c=32; t=OK; test "$err" = 0 || { c=31; t=FAILED; }; printf "* %s \e[%dm%s\e[0m\n" "$*" "$c" "$t"; } step () { err="$?"; c=32; t=OK; test "$err" = 0 || { c=31; t=FAILED; }; printf "* %s \e[%dm%s\e[0m\n" "$*" "$c" "$t"; }
compress() { cat | gzip -9 | base64 -w0; }
VERSION="0.0.1" VERSION="0.0.1"
if test "$1" = '-V'; then echo "shasumscript v$VERSION"; exit; fi if test "$1" = '-V'; then echo "shasumscript v$VERSION"; exit; fi
@ -25,6 +27,19 @@ test -e "$file" || err "File not found: $file"
sha="$(shasum -a 256 "$file" | cut -d' ' -f1)" || err "Failed to calculate SHA256 checksum" sha="$(shasum -a 256 "$file" | cut -d' ' -f1)" || err "Failed to calculate SHA256 checksum"
step "Checksum" step "Checksum"
bin=$(compress < "$file")
step "Compress"
defkey=$(gpgconf --list-options gpg | awk -F: '$1 == "default-key" {print $10}' | tr -dc 'A-Z0-9')
step "GPG default key"
if test -n "$defkey"
then
pub=$(gpg --export --output - "$defkey" | compress)
step "Public key"
sig=$(gpg --detach-sig --output - "$file" | compress)
step "Signature"
fi
newfile="${file}_sha256" newfile="${file}_sha256"
cat <<EOT > "$newfile" cat <<EOT > "$newfile"
@ -32,32 +47,62 @@ cat <<EOT > "$newfile"
# script generated by shasumscript at $(date) # script generated by shasumscript at $(date)
# #
# This script self-checkssum it's content and exit on error # This script self-checkssum it's content and exit on error
# The real script can be found after the separator: # The real script can be found after line 37.
# $sha
# #
# License: GNU GPL3 # License: GNU GPL3
# Author: Patrick Cao Huu Thien # Author: Patrick Cao Huu Thien
tmpexe="\$(mktemp)" set -e
trap 'rm -f "\$tmpexe"' EXIT
cat "\$0" | sed -n '/^${sha}/,\$p' | tail -n +2 > "\$tmpexe" sig="$sig"
test "\$(shasum -a 256 "\$tmpexe" | cut -d' ' -f1)" = "$sha" || { pub="$pub"
tmpexe="\$(mktemp)"
tmpsig="\$(mktemp)"
tmppub="\$(mktemp)"
trap 'rm -f "\$tmpexe" "\$tmpsig" "\$tmppub"' EXIT
cat "\$0" | sed '1,36d' | base64 -d 2>/dev/null| gunzip 2>/dev/null > "\$tmpexe"
test "\$(sha256sum "\$tmpexe" | cut -d' ' -f1)" = "$sha" || {
echo "Checksum mismatch!" >&2 echo "Checksum mismatch!" >&2
exit 1 exit 1
} }
txt='Checksum';printf -- "\r- \$txt";sleep 0.1;printf -- "\r/";sleep 0.1;printf -- "\r|";sleep 0.1;printf -- "\r\\\\";sleep 0.1;printf -- "\r \e[32m%s OK\e[0m" "\$txt";sleep 0.3
EOT
step "pre-script"
if test -n "$defkey"
then
cat <<EOT >> "$newfile"
echo "\$sig" | base64 -d 2>/dev/null | gunzip 2>/dev/null > "\$tmpsig"
echo "\$pub" | base64 -d 2>/dev/null | gunzip 2>/dev/null > "\$tmppub"
gpg --verify -q --keyring "\$tmppub" "\$tmpsig" "\$tmpexe" 2>&1 | grep -q 'Good signature' || {
echo "Signature mismatch!" >&2
exit 1
}
txt='Verification';printf -- "\r- \$txt";sleep 0.1;printf -- "\r/";sleep 0.1;printf -- "\r|";sleep 0.1;printf -- "\r\\\\";sleep 0.1;printf -- "\r \e[32m%s OK\e[0m" "\$txt";sleep 0.3
EOT
step "verify-script"
else
cat <<EOT >> "$newfile"
printf "Checksum OK"; sleep 1; printf "\r \r" #
# No public key available
#
# skip GPG verification
#
EOT
step "no-verify-script"
fi
cat <<EOT >> "$newfile"
printf "\r \r"
sh "\$tmpexe" "\$@" sh "\$tmpexe" "\$@"
exit exit
$sha
EOT EOT
step "pre-script"
cat "$file" >> "$newfile" echo "$bin" >> "$newfile"
step "post-script" step "binary"
chmod +x "$newfile" chmod +x "$newfile"
step "make it executable" step "make it executable"