makepkg: Emit early error if signature verification fails
Emit an early error message if tag or commit verification with git or detached signature verification with gpg fails. Make `verify_file_signature()` and `verify_git_signature()` return non-zero in this case and set errors to `1`, so that later checks in `check_pgpsigs()`, although still run, can not lead to a positive result. Signed-off-by: David Runge <dvzrv@archlinux.org>
This commit is contained in:
parent
bf76b5e89f
commit
3aa096a74f
1 changed files with 14 additions and 2 deletions
|
@ -157,7 +157,13 @@ verify_file_signature() {
|
||||||
"") decompress="cat" ;;
|
"") decompress="cat" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
$decompress < "$sourcefile" | gpg --quiet --batch --status-file "$statusfile" --verify "$file" - 2> /dev/null
|
# verify the signature and write metadata to a status file
|
||||||
|
if ! $decompress < "$sourcefile" | gpg --quiet --batch --status-file "$statusfile" --verify "$file" - 2> /dev/null; then
|
||||||
|
printf '%s\n' "$(gettext "%s is unable to verify the signature.")" "gpg" >&2
|
||||||
|
errors=1
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -189,7 +195,13 @@ verify_git_signature() {
|
||||||
|
|
||||||
printf " %s git repo ... " "${dir##*/}" >&2
|
printf " %s git repo ... " "${dir##*/}" >&2
|
||||||
|
|
||||||
git -C "$dir" verify-$fragtype --raw "$fragval" > "$statusfile" 2>&1
|
# verify the signature and write metadata to a status file
|
||||||
|
if ! git -C "$dir" verify-$fragtype --raw "$fragval" > "$statusfile" 2>&1; then
|
||||||
|
printf '%s\n' "$(gettext "%s is unable to verify the signature.")" "git" >&2
|
||||||
|
errors=1
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
if ! grep -qs NEWSIG "$statusfile"; then
|
if ! grep -qs NEWSIG "$statusfile"; then
|
||||||
printf '%s\n' "$(gettext "SIGNATURE NOT FOUND")" >&2
|
printf '%s\n' "$(gettext "SIGNATURE NOT FOUND")" >&2
|
||||||
errors=1
|
errors=1
|
||||||
|
|
Loading…
Add table
Reference in a new issue