From 84b3217c3d8dfbba8264d164733371674d2895d7 Mon Sep 17 00:00:00 2001 From: Erik Arvstedt Date: Tue, 16 Mar 2021 12:45:19 +0100 Subject: [PATCH] fetch-release: minor improvements This script is potentially fetched from an untrusted source and should be in good shape to be easily auditable. - Create just one TMPDIR - Improve comments - Use `cut` to extract sha256 - Use camelCase var names like in other scripts --- helper/fetch-release | 34 +++++++++++++++++++--------------- 1 file changed, 19 insertions(+), 15 deletions(-) diff --git a/helper/fetch-release b/helper/fetch-release index 6529386..13513d8 100755 --- a/helper/fetch-release +++ b/helper/fetch-release @@ -1,36 +1,40 @@ -#! /usr/bin/env nix-shell -#! nix-shell -i bash -p bash coreutils curl jq gnugrep gnupg +#!/usr/bin/env nix-shell +#!nix-shell -i bash -p bash coreutils curl jq gnupg set -euo pipefail scriptDir=$(cd "${BASH_SOURCE[0]%/*}" && pwd) -REPO=fort-nix/nix-bitcoin -if [[ ! -v VERSION ]]; then - VERSION=$(curl --silent "https://api.github.com/repos/$REPO/releases/latest" | jq -r '.tag_name' | tail -c +2) +repo=fort-nix/nix-bitcoin +if [[ ! -v version ]]; then + version=$(curl --silent "https://api.github.com/repos/$repo/releases/latest" | jq -r '.tag_name' | tail -c +2) fi TMPDIR=$(mktemp -d) -GPG_HOME=$(mktemp -d) -trap "rm -rf $TMPDIR $GPG_HOME" EXIT +trap "rm -rf $TMPDIR" EXIT + +GPG_HOME=$TMPDIR/gpg-home +mkdir -p -m 700 "$GPG_HOME" cd $TMPDIR -BASEURL=https://github.com/$REPO/releases/download/v$VERSION -curl --silent -L -O $BASEURL/SHA256SUMS.txt -curl --silent -L -O $BASEURL/SHA256SUMS.txt.asc +baseUrl=https://github.com/$repo/releases/download/v$version +curl --silent -L -O $baseUrl/SHA256SUMS.txt +curl --silent -L -O $baseUrl/SHA256SUMS.txt.asc -# Import key and verify fingerprint +# Import key gpg --homedir $GPG_HOME --import "$scriptDir/key-jonasnick.bin" &> /dev/null +# Verify key fingerprint gpg --homedir $GPG_HOME --list-keys 36C71A37C9D988BDE82508D9B1A70E4F8DCD0366 > /dev/null +# Verify signature for SHA256SUMS.txt gpg --homedir $GPG_HOME --verify SHA256SUMS.txt.asc &> /dev/null || { - echo "ERROR: Signature verification failed. Please open an issue in the project repository." + echo "Error: Signature verification failed. Please open an issue in the project repository." exit 1 } -SHA256=$(cat SHA256SUMS.txt | grep -Eo '^[^ ]+') +sha256=$(cat SHA256SUMS.txt | cut -d\ -f1) cat <