git: 8c4094f38c7b - main - certctl: factor out certname resolution
Kyle Evans
kevans at FreeBSD.org
Sat Jan 9 05:26:17 UTC 2021
The branch main has been updated by kevans:
URL: https://cgit.FreeBSD.org/src/commit/?id=8c4094f38c7b0e95af91d92a563bfedc1249950d
commit 8c4094f38c7b0e95af91d92a563bfedc1249950d
Author: Kyle Evans <kevans at FreeBSD.org>
AuthorDate: 2021-01-09 04:34:44 +0000
Commit: Kyle Evans <kevans at FreeBSD.org>
CommitDate: 2021-01-09 04:36:22 +0000
certctl: factor out certname resolution
create_blacklisted() will identify a cert whether it's provided a path to
a cert or the hash.serial format that is shown by `certctl list`.
Factor this logic out into a resolve_certname() so that it may be reused
elsewhere.
---
usr.sbin/certctl/certctl.sh | 19 +++++++++++++++++--
1 file changed, 17 insertions(+), 2 deletions(-)
diff --git a/usr.sbin/certctl/certctl.sh b/usr.sbin/certctl/certctl.sh
index c2f9c7dc8438..1a491cf3a047 100755
--- a/usr.sbin/certctl/certctl.sh
+++ b/usr.sbin/certctl/certctl.sh
@@ -92,7 +92,8 @@ create_trusted_link()
install ${INSTALLFLAGS} -lrs $(realpath "$1") "$CERTDESTDIR/$hash.$suffix"
}
-create_blacklisted()
+# Accepts either dot-hash form from `certctl list` or a path to a valid cert.
+resolve_certname()
{
local hash srcfile filename
local suffix
@@ -103,14 +104,28 @@ create_blacklisted()
srcfile=$(realpath "$1")
suffix=$(get_decimal "$BLACKLISTDESTDIR" "$hash")
filename="$hash.$suffix"
+ echo "$srcfile" "$hash.$suffix"
elif [ -e "${CERTDESTDIR}/$1" ]; then
srcfile=$(realpath "${CERTDESTDIR}/$1")
hash=$(echo "$1" | sed -Ee 's/\.([0-9])+$//')
suffix=$(get_decimal "$BLACKLISTDESTDIR" "$hash")
filename="$hash.$suffix"
- else
+ echo "$srcfile" "$hash.$suffix"
+ fi
+}
+
+create_blacklisted()
+{
+ local srcfile filename
+
+ set -- $(resolve_certname "$1")
+ srcfile=$1
+ filename=$2
+
+ if [ -z "$srcfile" -o -z "$filename" ]; then
return
fi
+
[ $VERBOSE -gt 0 ] && echo "Adding $filename to blacklist"
[ $NOOP -eq 0 ] && install ${INSTALLFLAGS} -lrs "$srcfile" "$BLACKLISTDESTDIR/$filename"
}
More information about the dev-commits-src-main
mailing list