Add configuration for keepalive

* Add parameter to disable the push of block-outside-dns
* -d should really do what it was supposed to do
* Fix problem where comp-lzo would always be set regardless of the parameter
This commit is contained in:
Sylvain Lamontagne 2017-03-09 18:04:21 -05:00
parent d454a20e80
commit 22fcaf9477
3 changed files with 38 additions and 11 deletions

View File

@ -95,10 +95,12 @@ usage() {
echo "optional arguments:" echo "optional arguments:"
echo " -2 Enable two factor authentication using Google Authenticator." echo " -2 Enable two factor authentication using Google Authenticator."
echo " -a Authenticate packets with HMAC using the given message digest algorithm (auth)." echo " -a Authenticate packets with HMAC using the given message digest algorithm (auth)."
echo " -b Disable 'push block-outside-dns'"
echo " -c Enable client-to-client option" echo " -c Enable client-to-client option"
echo " -C A list of allowable TLS ciphers delimited by a colon (cipher)." echo " -C A list of allowable TLS ciphers delimited by a colon (cipher)."
echo " -d Disable NAT routing and default route" echo " -d Disable default route"
echo " -D Do not push dns servers" echo " -D Do not push dns servers"
echo " -k Set keepalive. Default: '10 60'"
echo " -m Set client MTU" echo " -m Set client MTU"
echo " -N Configure NAT to access external server network" echo " -N Configure NAT to access external server network"
echo " -t Use TAP device (instead of TUN device)" echo " -t Use TAP device (instead of TUN device)"
@ -157,6 +159,7 @@ OVPN_NAT=0
OVPN_DNS=1 OVPN_DNS=1
OVPN_DEVICE="tun" OVPN_DEVICE="tun"
OVPN_DEVICEN=0 OVPN_DEVICEN=0
OVPN_KEEPALIVE="10 60"
OVPN_DNS_SERVERS=("8.8.8.8" "8.8.4.4") OVPN_DNS_SERVERS=("8.8.8.8" "8.8.4.4")
TMP_DNS_SERVERS=() TMP_DNS_SERVERS=()
OVPN_TLS_CIPHER='' OVPN_TLS_CIPHER=''
@ -164,12 +167,14 @@ OVPN_CIPHER=''
OVPN_AUTH='' OVPN_AUTH=''
OVPN_EXTRA_CONFIG='' OVPN_EXTRA_CONFIG=''
CUSTOM_ROUTE_CONFIG='' CUSTOM_ROUTE_CONFIG=''
OVPN_COMP_LZO=0
OVPN_DISABLE_PUSH_BLOCK_DNS=0
# Import defaults if present # Import defaults if present
[ -r "$OVPN_ENV" ] && source "$OVPN_ENV" [ -r "$OVPN_ENV" ] && source "$OVPN_ENV"
# Parse arguments # Parse arguments
while getopts ":a:e:E:C:T:r:s:du:cp:n:DNmf:tz2" opt; do while getopts ":a:e:E:C:T:r:s:du:bcp:n:k:DNmf:tz2" opt; do
case $opt in case $opt in
a) a)
OVPN_AUTH="$OPTARG" OVPN_AUTH="$OPTARG"
@ -195,10 +200,14 @@ while getopts ":a:e:E:C:T:r:s:du:cp:n:DNmf:tz2" opt; do
;; ;;
d) d)
OVPN_DEFROUTE=0 OVPN_DEFROUTE=0
OVPN_DISABLE_PUSH_BLOCK_DNS=1
;; ;;
u) u)
OVPN_SERVER_URL=$OPTARG OVPN_SERVER_URL=$OPTARG
;; ;;
b)
OVPN_DISABLE_PUSH_BLOCK_DNS=1
;;
c) c)
OVPN_CLIENT_TO_CLIENT=1 OVPN_CLIENT_TO_CLIENT=1
;; ;;
@ -214,6 +223,9 @@ while getopts ":a:e:E:C:T:r:s:du:cp:n:DNmf:tz2" opt; do
N) N)
OVPN_NAT=1 OVPN_NAT=1
;; ;;
k)
OVPN_KEEPALIVE="$OPTARG"
;;
m) m)
OVPN_MTU=$OPTARG OVPN_MTU=$OPTARG
;; ;;
@ -265,7 +277,7 @@ fi
# Apply defaults # Apply defaults
[ -z "$OVPN_PROTO" ] && OVPN_PROTO=udp [ -z "$OVPN_PROTO" ] && OVPN_PROTO=udp
[ -z "$OVPN_PORT" ] && OVPN_PORT=1194 [ -z "$OVPN_PORT" ] && OVPN_PORT=1194
[ -z "$CUSTOM_ROUTE_CONFIG" ] && process_route_config "192.168.254.0/24" [ -z "$CUSTOM_ROUTE_CONFIG" ] && [ "$OVPN_DEFROUTE" == "1" ] && process_route_config "192.168.254.0/24"
# Save extra client config from temp file only if temp file is not empty # Save extra client config from temp file only if temp file is not empty
if [ -s "$TMP_EXTRA_CLIENT_CONFIGFILE" ]; then if [ -s "$TMP_EXTRA_CLIENT_CONFIGFILE" ]; then
@ -277,6 +289,7 @@ export OVPN_SERVER_URL OVPN_ENV OVPN_PROTO OVPN_CN OVPN_PORT
export OVPN_CLIENT_TO_CLIENT OVPN_PUSH OVPN_NAT OVPN_DNS OVPN_MTU OVPN_DEVICE export OVPN_CLIENT_TO_CLIENT OVPN_PUSH OVPN_NAT OVPN_DNS OVPN_MTU OVPN_DEVICE
export OVPN_TLS_CIPHER OVPN_CIPHER OVPN_AUTH export OVPN_TLS_CIPHER OVPN_CIPHER OVPN_AUTH
export OVPN_COMP_LZO export OVPN_COMP_LZO
export OVPN_DISABLE_PUSH_BLOCK_DNS
export OVPN_OTP_AUTH export OVPN_OTP_AUTH
export OVPN_FRAGMENT export OVPN_FRAGMENT
export OVPN_ADDITIONAL_CLIENT_CONFIG export OVPN_ADDITIONAL_CLIENT_CONFIG
@ -316,7 +329,7 @@ cert $EASYRSA_PKI/issued/${OVPN_CN}.crt
dh $EASYRSA_PKI/dh.pem dh $EASYRSA_PKI/dh.pem
tls-auth $EASYRSA_PKI/ta.key tls-auth $EASYRSA_PKI/ta.key
key-direction 0 key-direction 0
keepalive 10 60 keepalive $OVPN_KEEPALIVE
persist-key persist-key
persist-tun persist-tun
@ -330,15 +343,18 @@ user nobody
group nogroup group nogroup
EOF EOF
# only block outside dns when we take the default route if [ "${OVPN_DISABLE_PUSH_BLOCK_DNS}" == "1" ]; then
[ "$OVPN_DEFROUTE" == "1" ] && process_push_config "block-outside-dns" echo "Disable default push of 'block-outside-dns'"
else
process_push_config "block-outside-dns"
fi
[ -n "$OVPN_TLS_CIPHER" ] && echo "tls-cipher $OVPN_TLS_CIPHER" >> "$conf" [ -n "$OVPN_TLS_CIPHER" ] && echo "tls-cipher $OVPN_TLS_CIPHER" >> "$conf"
[ -n "$OVPN_CIPHER" ] && echo "cipher $OVPN_CIPHER" >> "$conf" [ -n "$OVPN_CIPHER" ] && echo "cipher $OVPN_CIPHER" >> "$conf"
[ -n "$OVPN_AUTH" ] && echo "auth $OVPN_AUTH" >> "$conf" [ -n "$OVPN_AUTH" ] && echo "auth $OVPN_AUTH" >> "$conf"
[ -n "${OVPN_CLIENT_TO_CLIENT:-}" ] && echo "client-to-client" >> "$conf" [ -n "${OVPN_CLIENT_TO_CLIENT:-}" ] && echo "client-to-client" >> "$conf"
[ -n "${OVPN_COMP_LZO:-}" ] && echo "comp-lzo" >> "$conf" [ "$OVPN_COMP_LZO" == "1" ] && echo "comp-lzo" >> "$conf"
[ -n "${OVPN_FRAGMENT:-}" ] && echo "fragment $OVPN_FRAGMENT" >> "$conf" [ -n "${OVPN_FRAGMENT:-}" ] && echo "fragment $OVPN_FRAGMENT" >> "$conf"

View File

@ -97,7 +97,7 @@ tls-auth ta.key 1
echo "auth-nocache" echo "auth-nocache"
fi fi
if [ -n "$OVPN_COMP_LZO" ]; then if [ "$OVPN_COMP_LZO" == "1" ]; then
echo "comp-lzo" echo "comp-lzo"
fi fi
@ -124,9 +124,9 @@ case "$parm" in
get_client_config "combined" > "$dir/${cn}-combined.ovpn" get_client_config "combined" > "$dir/${cn}-combined.ovpn"
;; ;;
*) *)
echo "This script can produce the client configuration in to formats:" >&2 echo "This script can produce the client configuration in two formats:" >&2
echo " 1. combined (default): All needed configuration and cryptographic material is in one file (Use \"combined-save\" to write the configuration file in the same path as the separated parameter does)." >&2 echo " 1. combined (default): All needed configuration and cryptographic material is in one file (Use \"combined-save\" to write the configuration file in the same path as the separated parameter does)." >&2
echo " 2. separated: Separated files." >&2 echo " 2. separated: Separated files." >&2
echo "Please specific one of those options as second parameter." >&2 echo "Please specify one of those options as second parameter." >&2
;; ;;
esac esac

View File

@ -171,6 +171,17 @@ else
abort "==> Config match not found: $CONFIG_REQUIRED_ROUTE_2 != $CONFIG_MATCH_ROUTE_2" abort "==> Config match not found: $CONFIG_REQUIRED_ROUTE_2 != $CONFIG_MATCH_ROUTE_2"
fi fi
SERV_IP=$(ip -4 -o addr show scope global | awk '{print $4}' | sed -e 's:/.*::' | head -n1)
ovpn_genconfig -u udp://$SERV_IP -b
if busybox grep -v 'block-outside-dns' /etc/openvpn/openvpn.conf
then
echo "==> Config '-b' Succesfully remove the 'block-outside-dns' option"
else
abort "==> Config '-b' given, but 'block-outside-dns' option is still present in configuration"
fi
# Test generated client config # Test generated client config
# gen udp client with tcp fallback # gen udp client with tcp fallback