gen-ec-cert: reuse the private key if it exists
This commit is contained in:
parent
ea435f67d5
commit
f0505b1d11
@ -27,13 +27,21 @@ shift $((OPTIND - 1))
|
|||||||
[ $# -eq 1 ] && [ -n "$1" ] || usage
|
[ $# -eq 1 ] && [ -n "$1" ] || usage
|
||||||
domain=$1
|
domain=$1
|
||||||
|
|
||||||
(umask 077 && openssl genpkey -aes256 \
|
if [ -f "$domain.key" ]; then
|
||||||
-algorithm ec -pkeyopt ec_paramgen_curve:"$curve" -out "$domain.key")
|
printf "%s: key for %s already exists; reusing it.\n" \
|
||||||
if [ $? -ne 0 ] || [ ! -s "$domain.key" ]; then
|
"${0##*/}" "$domain" >&2
|
||||||
# openssl doesn't return an error code if there is a password mismatch
|
else
|
||||||
# or a password too short, and it creates the output file anyways
|
(umask 077 && openssl genpkey -aes256 \
|
||||||
|
-algorithm ec -pkeyopt ec_paramgen_curve:"$curve" \
|
||||||
|
-out "$domain.key")
|
||||||
|
if [ $? -ne 0 ] || [ ! -s "$domain.key" ]; then
|
||||||
|
# openssl doesn't return an error code if there is a password
|
||||||
|
# mismatch or a password too short, and it creates the output
|
||||||
|
# file anyways
|
||||||
rm -f "$domain.key"
|
rm -f "$domain.key"
|
||||||
exit 1
|
exit 1
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
openssl req -new -x509 -days "$days" -subj "/CN=$domain" \
|
openssl req -new -x509 -days "$days" -subj "/CN=$domain" \
|
||||||
-key "$domain.key" -out "$domain.pem"
|
-key "$domain.key" -out "$domain.pem"
|
||||||
|
Loading…
Reference in New Issue
Block a user