X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=vpn-server-setup;h=5c6f195edb57c195c94de4523d9f12acc948b03d;hb=d749cadc99d6cb517e68afec90a394fb4ae8d1f0;hp=8cfe54576aaeb0d4bd945924553b330661e71b2f;hpb=95755ebea37097aa31a5f8a1acbb5cfb5d4bd06a;p=vpn-setup diff --git a/vpn-server-setup b/vpn-server-setup index 8cfe545..5c6f195 100755 --- a/vpn-server-setup +++ b/vpn-server-setup @@ -21,14 +21,16 @@ trap 'echo "$0:$LINENO:error: \"$BASH_COMMAND\" returned $?" >&2' ERR usage() { cat <<'EOF' -usage: ${0##*/} [OPTIONS] [IPV6_ADDR/BITS IPV6_DEFAULT_ROUTE] - --4 I prefix of range for ipv4, default 10.8.0 --d Do not push dns --n Name. default = server. 2 servers on the same host need different names. --p Port. default 1194 --r Do not push default route --s Do not start openvpn +usage: ${0##*/} [OPTIONS] [IPV6_ADDR/BITS] + +-4 Prefix of range for ipv4, default 10.8.0 +-6 IP6_NETWORK Do ip6 nat for this network. ipv6 will work without nat, + but you may want it in certain circumstances. +-d Do not push dns +-n NAME default = server. 2 servers on the same host need different names. +-p PORT default 1194 +-r Do not push default route +-s Do not start openvpn -h --help print help Sets up a vpn server which pushes gateway route and dns server so all @@ -37,7 +39,7 @@ debian specific paths. For ipv6, we assume ipv6_addr routes to the server. -You can save all the keys by storing /etc/openvpn/easy-rsa/keys, and +You can save all the keys by storing /etc/openvpn/easy-rsa-NAME/keys, and the script will not generate them if it sees they exist already. For future updates to this script, this is a good place to @@ -54,11 +56,12 @@ route=true start=true ip4=10.8.0 name=server -temp=$(getopt -l help 4:dn:p:rsh "$@") || usage 1 +temp=$(getopt -l help 4:6:dn:p:rsh "$@") || usage 1 eval set -- "$temp" while true; do case $1 in -4) ip4=$2; shift 2 ;; + -6) ip6net=$2; shift 2 ;; -d) dns=false; shift ;; -n) name=$2; shift 2 ;; -p) port=$2; shift 2 ;; @@ -74,7 +77,7 @@ read -r ip6 ip6route <<<"$@" source /a/bin/distro-functions/src/package-manager-abstractions -pi-nostart openvpn openssl resolvconf easy-rsa uuid-runtime +pi-nostart openvpn openssl easy-rsa uuid-runtime if [[ -e /lib/systemd/system/openvpn-server@.service ]]; then vpn_service=openvpn-server@$name @@ -220,7 +223,8 @@ fi if [[ $ip6 ]]; then cat >>$conf </etc/systemd/system/vpnnat.service <$f <>$f <