pass shellcheck

This commit is contained in:
Lance Vick 2023-01-25 17:59:18 -08:00
parent 3f732a313f
commit 0301738246
Signed by: lrvick
GPG Key ID: 8E47A1EC35A1551D
1 changed files with 29 additions and 31 deletions

60
sig
View File

@ -5,7 +5,6 @@ readonly MIN_BASH_VERSION=5
readonly MIN_GPG_VERSION=2.2 readonly MIN_GPG_VERSION=2.2
readonly MIN_OPENSSL_VERSION=1.1 readonly MIN_OPENSSL_VERSION=1.1
readonly MIN_GETOPT_VERSION=2.33 readonly MIN_GETOPT_VERSION=2.33
readonly DATE=$(command -v gdate || command -v date)
## Private Functions ## Private Functions
@ -39,7 +38,7 @@ die_pkg() {
*) die "Error: Your operating system is not supported" ;; *) die "Error: Your operating system is not supported" ;;
esac esac
echo "Error: ${package} ${version}+ does not appear to be installed." >&2 echo "Error: ${package} ${version}+ does not appear to be installed." >&2
[ ! -z "$install_cmd" ] && echo "Try: \`${install_cmd}\`" >&2 [ -n "$install_cmd" ] && echo "Try: \`${install_cmd}\`" >&2
exit 1 exit 1
} }
@ -210,19 +209,19 @@ group_check_fp(){
tree_hash() { tree_hash() {
local -r ref="${1:-HEAD}" local -r ref="${1:-HEAD}"
local -r target=$(git rev-parse ${ref}) local -r target=$(git rev-parse "$ref")
local -r current=$(git rev-parse HEAD) local -r current=$(git rev-parse HEAD)
[ "$target" == "$current" ] || git checkout ${target} >/dev/null 2>&1 [ "$target" == "$current" ] || git checkout "$target" >/dev/null 2>&1
mkdir -p ".${PROGRAM}" mkdir -p ".${PROGRAM}"
printf "%s" "$( \ printf "%s" "$( \
find . -type f -not -path "./.git/*" \ find . -type f -not -path "./.git/*" \
| xargs openssl sha256 -r \ -exec openssl sha256 -r {} \;\
)" \ )" \
| sed -e 's/ \*/ /g' -e 's/ \.\// /g' \ | sed -e 's/ \*/ /g' -e 's/ \.\// /g' \
| LC_ALL=C sort -k2 \ | LC_ALL=C sort -k2 \
| openssl sha256 -r \ | openssl sha256 -r \
| sed -e 's/ .*//g' | sed -e 's/ .*//g'
[ "$target" == "$current" ] || git checkout ${current} >/dev/null 2>&1 [ "$target" == "$current" ] || git checkout "$current" >/dev/null 2>&1
} }
sig_generate(){ sig_generate(){
@ -239,14 +238,14 @@ sig_generate(){
--local-user "$key" \ --local-user "$key" \
| openssl base64 -A \ | openssl base64 -A \
) )
printf "$body:$signature" printf "%s" "$body:$signature"
} }
parse_gpg_status() { parse_gpg_status() {
local -r gpg_status="$1" local -r gpg_status="$1"
local -r error="$2" local -r error="$2"
while read -r values; do while read -r values; do
local key array sip_fp sig_date sig_status sig_author sig_body local key array sig_fp sig_date sig_status sig_author sig_body
IFS=" " read -r -a array <<< "$values" IFS=" " read -r -a array <<< "$values"
key=${array[1]} key=${array[1]}
case $key in case $key in
@ -273,17 +272,16 @@ parse_gpg_status() {
;; ;;
esac esac
done <<< "$gpg_status" done <<< "$gpg_status"
sig_fp=$(get_primary_fp $sig_fp) sig_fp=$(get_primary_fp "$sig_fp")
sig_body="pgp:$sig_fp:$sig_status:$sig_trust:$sig_date:$sig_author:$error" sig_body="pgp:$sig_fp:$sig_status:$sig_trust:$sig_date:$sig_author:$error"
printf "$sig_body" printf "%s" "$sig_body"
} }
verify_git_note(){ verify_git_note(){
local -r line="${1}" local -r line="${1}"
local -r ref="${2:-HEAD}" local -r ref="${2:-HEAD}"
local -r commit=$(git rev-parse ${ref}) local -r commit=$(git rev-parse "$ref")
IFS=':' line_parts=($line) IFS=':' read -r -a line_parts <<< "$line"
local -r identifier=${line_parts[0]} local -r identifier=${line_parts[0]}
local -r version=${line_parts[1]} local -r version=${line_parts[1]}
local -r vcs_hash=${line_parts[2]} local -r vcs_hash=${line_parts[2]}
@ -307,7 +305,7 @@ verify_git_note(){
[[ "$vcs_hash" == "$commit" ]] || { [[ "$vcs_hash" == "$commit" ]] || {
error="COMMIT_NOMATCH" error="COMMIT_NOMATCH"
} }
commit_tree_hash="$(tree_hash ${commit})" commit_tree_hash=$(tree_hash "$commit")
[[ "$tree_hash" == "$commit_tree_hash" ]] || { [[ "$tree_hash" == "$commit_tree_hash" ]] || {
error="TREEHASH_NOMATCH;$commit;$tree_hash;$commit_tree_hash"; error="TREEHASH_NOMATCH;$commit;$tree_hash;$commit_tree_hash";
} }
@ -316,10 +314,10 @@ verify_git_note(){
verify_git_notes(){ verify_git_notes(){
local -r ref="${1:-HEAD}" local -r ref="${1:-HEAD}"
local -r commit=$(git rev-parse ${ref}) local -r commit=$(git rev-parse "$ref")
local code=1 local code=1
while IFS='' read -r line; do while IFS='' read -r line; do
printf "$(verify_git_note "$line" "$ref")\n" printf "%s\n" "$(verify_git_note "$line" "$ref")"
code=0 code=0
done < <(git notes --ref signatures show "$commit" 2>&1 | grep "^sig:") done < <(git notes --ref signatures show "$commit" 2>&1 | grep "^sig:")
return $code return $code
@ -328,16 +326,16 @@ verify_git_notes(){
verify_git_commit(){ verify_git_commit(){
local -r ref="${1:-HEAD}" local -r ref="${1:-HEAD}"
local gpg_sig_raw local gpg_sig_raw
gpg_sig_raw=$(git verify-commit ${ref} --raw 2>&1) gpg_sig_raw=$(git verify-commit "$ref" --raw 2>&1)
parse_gpg_status "$gpg_sig_raw" parse_gpg_status "$gpg_sig_raw"
} }
verify_git_tags(){ verify_git_tags(){
local fps="" git_sig_raw code=1 local gpg_sig_raw code=1
for tag in $(git tag --points-at HEAD); do for tag in $(git tag --points-at HEAD); do
git tag --verify "$tag" >/dev/null 2>&1 && { git tag --verify "$tag" >/dev/null 2>&1 && {
gpg_sig_raw=$( git verify-tag --raw "$tag" 2>&1 ) gpg_sig_raw=$( git verify-tag --raw "$tag" 2>&1 )
printf "$(parse_gpg_status "$gpg_sig_raw")\n" printf "%s\n" "$(parse_gpg_status "$gpg_sig_raw")"
code=0 code=0
} }
done done
@ -352,7 +350,7 @@ verify(){
local -r threshold="${1}" local -r threshold="${1}"
local -r group="${2}" local -r group="${2}"
local -r ref=${3:-HEAD} local -r ref=${3:-HEAD}
local sig_count=0 seen_fps="" fp="" tag_fps="" note_fps="" local sig_count=0 seen_fps fp commit_sig tag_sigs note_sigs
[ -d .git ] \ [ -d .git ] \
|| die "Error: This folder is not a git repository" || die "Error: This folder is not a git repository"
if [[ $(git diff --stat) != '' ]]; then if [[ $(git diff --stat) != '' ]]; then
@ -364,12 +362,12 @@ verify(){
IFS=':' read -r -a sig <<< "$commit_sig" IFS=':' read -r -a sig <<< "$commit_sig"
fp="${sig[1]}" fp="${sig[1]}"
uid="${sig[5]}" uid="${sig[5]}"
echo "Verified signed git commit by \"${uid}\"" echo "Verified signed git commit by \"$uid\""
seen_fps="${fp}" seen_fps="${fp}"
fi fi
tag_sigs=$(verify_git_tags "$ref") tag_sigs=$(verify_git_tags "$ref") && \
[[ $? == 0 ]] && while IFS= read -r line; do while IFS= read -r line; do
IFS=':' read -r -a sig <<< "$line" IFS=':' read -r -a sig <<< "$line"
fp="${sig[1]}" fp="${sig[1]}"
uid="${sig[5]}" uid="${sig[5]}"
@ -379,8 +377,8 @@ verify(){
fi fi
done <<< "$tag_sigs" done <<< "$tag_sigs"
note_sigs=$(verify_git_notes "$ref") note_sigs=$(verify_git_notes "$ref") && \
[[ $? == 0 ]] && while IFS= read -r line; do while IFS= read -r line; do
IFS=':' read -r -a sig <<< "$line" IFS=':' read -r -a sig <<< "$line"
fp="${sig[1]}" fp="${sig[1]}"
uid="${sig[5]}" uid="${sig[5]}"
@ -395,10 +393,10 @@ verify(){
fi fi
done <<< "$note_sigs" done <<< "$note_sigs"
for fp in ${seen_fps}; do for seen_fp in ${seen_fps}; do
if [ ! -z "$group" ]; then if [ -n "$group" ]; then
group_check_fp "${seen_fp}" "${group}" || { group_check_fp "${seen_fp}" "${group}" || {
echo "Git signing key not in group \"${group}\": ${fp}"; echo "Git signing key not in group \"${group}\": ${seen_fp}";
return 1; return 1;
} }
fi fi
@ -479,7 +477,7 @@ cmd_verify() {
esac done esac done
local -r head=$(git rev-parse --short HEAD) local -r head=$(git rev-parse --short HEAD)
if [ ! -z "$diff" ] && [ -z "$ref" ]; then if [ -n "$diff" ] && [ -z "$ref" ]; then
while read -r commit; do while read -r commit; do
echo "Checking commit: $commit" echo "Checking commit: $commit"
if verify "$threshold" "$group" "$commit"; then if verify "$threshold" "$group" "$commit"; then
@ -489,7 +487,7 @@ cmd_verify() {
done <<< "$(git log --show-notes=signatures --pretty=format:"%H")" done <<< "$(git log --show-notes=signatures --pretty=format:"%H")"
else else
if verify "$threshold" "$group" "$ref"; then if verify "$threshold" "$group" "$ref"; then
if [ ! -z "$diff" ] && [ ! -z "$ref" ]; then if [ -n "$diff" ] && [ -n "$ref" ]; then
local -r commit=$(git rev-parse --short "${ref}") local -r commit=$(git rev-parse --short "${ref}")
[ "${commit}" != "${head}" ] && \ [ "${commit}" != "${head}" ] && \
git --no-pager diff "${commit}" "${head}" git --no-pager diff "${commit}" "${head}"
@ -512,7 +510,7 @@ cmd_fetch() {
die "Usage: $PROGRAM fetch <fingerprint> [-g,--group=<group>]" die "Usage: $PROGRAM fetch <fingerprint> [-g,--group=<group>]"
local -r fingerprint=${1} local -r fingerprint=${1}
if [ ! -z "$group" ]; then if [ -n "$group" ]; then
group_fps=$(group_get_fps "${group_name}") group_fps=$(group_get_fps "${group_name}")
if [[ "${group_fps}" == *"${fingerprint}"* ]]; then if [[ "${group_fps}" == *"${fingerprint}"* ]]; then
echo "Key \"${fingerprint}\" is already in group \"${group}\"" echo "Key \"${fingerprint}\" is already in group \"${group}\""