2020-02-13 03:59:09 +01:00
|
|
|
#!/bin/sh
|
2020-05-03 16:47:27 +02:00
|
|
|
# env
|
|
|
|
# Written in 2020 by Lucas
|
|
|
|
# CC0 1.0 Universal/Public domain - No rights reserved
|
|
|
|
#
|
|
|
|
# To the extent possible under law, the author(s) have dedicated all
|
|
|
|
# copyright and related and neighboring rights to this software to the
|
|
|
|
# public domain worldwide. This software is distributed without any
|
|
|
|
# warranty. You should have received a copy of the CC0 Public Domain
|
|
|
|
# Dedication along with this software. If not, see
|
|
|
|
# <http://creativecommons.org/publicdomain/zero/1.0/>.
|
|
|
|
|
2020-02-13 03:59:09 +01:00
|
|
|
usage()
|
|
|
|
{
|
2020-02-14 04:02:52 +01:00
|
|
|
printf "Usage: %s [-c curve] [-d days] domain\n" "${0##*/}" >&2
|
2020-02-13 03:59:09 +01:00
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
tonumber()
|
|
|
|
{
|
|
|
|
printf "%u\n" "$*"
|
|
|
|
}
|
|
|
|
|
|
|
|
curve=secp384r1
|
|
|
|
days=3650
|
2020-02-14 04:02:52 +01:00
|
|
|
while getopts c:d: flag; do
|
2020-02-13 03:59:09 +01:00
|
|
|
case $flag in
|
|
|
|
c) [ -n "$OPTARG" ] || usage
|
|
|
|
curve=$OPTARG
|
|
|
|
;;
|
|
|
|
d) days=$(tonumber "$OPTARG") || usage
|
|
|
|
;;
|
|
|
|
*) usage
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
shift $((OPTIND - 1))
|
|
|
|
[ $# -eq 1 ] && [ -n "$1" ] || usage
|
|
|
|
domain=$1
|
|
|
|
|
2020-02-13 11:52:55 +01:00
|
|
|
if [ -f "$domain.key" ]; then
|
2020-05-03 16:47:27 +02:00
|
|
|
printf "%s: key for %s already exists; reusing it\n" \
|
2020-02-13 11:52:55 +01:00
|
|
|
"${0##*/}" "$domain" >&2
|
|
|
|
else
|
2020-03-14 14:36:41 +01:00
|
|
|
(umask 0377 &&
|
2020-02-14 04:02:52 +01:00
|
|
|
openssl ecparam -genkey -name "$curve" -out "$domain.key")
|
2020-02-13 11:49:45 +01:00
|
|
|
fi
|
2020-02-13 11:52:55 +01:00
|
|
|
|
2020-03-14 14:36:41 +01:00
|
|
|
umask 0333 && openssl req -new -x509 -days "$days" -subj "/CN=$domain" \
|
2020-02-13 03:59:09 +01:00
|
|
|
-key "$domain.key" -out "$domain.pem"
|