X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=client-cert-helper;h=40078aad9562c5a84ac0f6e6f422e2fcca7dee5d;hb=dacf50e689875098352985acadc8210d845b358d;hp=aedc4cd124f50f1e296147b8946addf94a9d3be2;hpb=50a29b33506900a8bc5d87e67ea0d3fd9bd69369;p=vpn-setup diff --git a/client-cert-helper b/client-cert-helper index aedc4cd..40078aa 100755 --- a/client-cert-helper +++ b/client-cert-helper @@ -1,9 +1,13 @@ #!/bin/bash set -eE -o pipefail +# Outputs the keyfiles to stdout as tar.gz + rm -f /tmp/vpn-mk-client-cert.log exec 2>/tmp/vpn-mk-client-cert.log +date >&2 + name=$1 common_name=$2 @@ -14,17 +18,26 @@ if [[ -e /etc/openvpn/server ]]; then server_dir=/etc/openvpn/server fi -cafile=$server_dir/ca.crt +cafile=$server_dir/ca-$name.crt +### begin section roughly copied from vpn-server-setup +rsadir=/etc/openvpn/easy-rsa-$name new=true -keyfiles=(/etc/openvpn/easy-rsa/pki/{issued/$common_name.crt,private/$common_name.key}) -if [[ -e /etc/openvpn/easy-rsa/build-ca ]]; then +keyfiles=( + $rsadir/pki/private/$common_name.key + $rsadir/pki/issued/$common_name.crt +) +if [[ -e /etc/openvpn/easy-rsa-$name/build-ca ]]; then new=false - keyfiles=(/etc/openvpn/easy-rsa/keys/$name.{crt,key}) + keyfiles=( + $rsadir/keys/$common_name.key + $rsadir/keys/$common_name.crt + ) fi +### end section roughly copied from vpn-server-setup if [[ ! -e $cafile ]]; then - echo: error no cafile found at $cafile >/tmp/errors + echo error: no cafile found at $cafile >/tmp/errors exit 1 fi @@ -38,7 +51,7 @@ done if ! $exists; then - cd /etc/openvpn/easy-rsa + cd /etc/openvpn/easy-rsa-$name if $new; then ./easyrsa build-client-full $common_name nopass >/dev/null else @@ -49,10 +62,10 @@ if ! $exists; then fi d=$(mktemp -d) -cp $cafile $d/$name-ca.crt -cp ${keyfiles[@]} $d - -cp $server_dir/ta.key $d/$name-ta.key +cp $server_dir/ta-$name.key $cafile $d +for f in ${keyfiles[@]}; do + cp $f $d/$name.${f##*.} +done tar cz -C $d . rm -rf $d