2007-11-28 13:40:15 +00:00
|
|
|
#!/sbin/runscript
|
2008-01-11 15:31:10 +00:00
|
|
|
# Copyright 2007-2008 Roy Marples <roy@marples.name>
|
|
|
|
# All rights reserved. Released under the 2-clause BSD license.
|
2007-11-28 13:40:15 +00:00
|
|
|
|
|
|
|
vpn=${SVCNAME#*.}
|
|
|
|
name="OpenVPN"
|
|
|
|
[ "${vpn}" != "openvpn" ] && name="${name} (${vpn})"
|
2008-01-11 21:54:33 +00:00
|
|
|
command=@PREFIX@/sbin/openvpn
|
2007-11-28 13:40:15 +00:00
|
|
|
|
2008-01-11 10:55:36 +00:00
|
|
|
pidfile=@VARBASE@/run/"${SVCNAME}".pid
|
|
|
|
openvpn_dir=${openvpn_dir:-@PREFIX@/etc/openvpn}
|
2007-11-28 13:40:15 +00:00
|
|
|
openvpn_config=${openvpn_config:-${openvpn_dir}/${vpn}.conf}
|
|
|
|
command_args="${openvpn_args} --daemon --config ${openvpn_config} --writepid ${pidfile}"
|
|
|
|
required_dirs="${openvpn_dir}"
|
|
|
|
required_files="${openvpn_config}"
|
|
|
|
|
|
|
|
# If we're an openvpn client, then supply a nice default config
|
|
|
|
# You can find sample up/down scripts in the OpenRC support/openvpn dir
|
|
|
|
if yesno "${openvpn_client}"; then
|
|
|
|
openvpn_up=${openvpn_up:-${openvpn_dir}/up.sh}
|
|
|
|
openvpn_down=${openvpn_down:-${openvpn_dir}/down.sh}
|
|
|
|
command_args="${command_args} --nobind --up-delay --up-restart --down-pre"
|
|
|
|
command_args="${command_args} --up ${openvpn_up}"
|
|
|
|
command_args="${command_args} --down ${openvpn_down}"
|
|
|
|
required_files="${required_files} ${openvpn_up} ${openvpn_down}"
|
|
|
|
|
|
|
|
in_background_fake="start stop"
|
|
|
|
start_inactive="YES"
|
|
|
|
fi
|
|
|
|
|
2008-01-11 12:18:05 +00:00
|
|
|
depend()
|
|
|
|
{
|
2007-11-28 13:40:15 +00:00
|
|
|
need net
|
|
|
|
use dns
|
|
|
|
}
|
|
|
|
|
2008-01-11 12:18:05 +00:00
|
|
|
start_pre()
|
|
|
|
{
|
2007-11-28 13:40:15 +00:00
|
|
|
# Linux has good dynamic tun/tap creation
|
|
|
|
if [ "${RC_UNAME}" = "Linux" ]; then
|
|
|
|
if [ ! -e /dev/net/tun ]; then
|
|
|
|
if ! modprobe tun; then
|
|
|
|
eerror "TUN/TAP support is not available in this kernel"
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
if [ -h /dev/net/tun -a -c /dev/misc/net/tun ]; then
|
|
|
|
ebegin "Detected broken /dev/net/tun symlink, fixing..."
|
|
|
|
rm -f /dev/net/tun
|
|
|
|
ln -s /dev/misc/net/tun /dev/net/tun
|
|
|
|
eend $?
|
|
|
|
fi
|
2007-11-28 16:12:45 +00:00
|
|
|
else
|
2008-01-11 10:55:36 +00:00
|
|
|
if type kldload >/dev/null 2>&1; then
|
|
|
|
# Hammer the modules home by default
|
|
|
|
sysctl -a | grep -q '\.tun\.' || kldload if_tun
|
|
|
|
sysctl -a | grep -q '\.tap\.' || kldload if_tap
|
|
|
|
fi
|
2007-11-28 13:40:15 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
# If the config file does not specify the cd option, we do
|
|
|
|
# But if we specify it, we override the config option which we do not want
|
|
|
|
if ! grep -q "^[ \t]*cd[ \t].*" "${openvpn_config}"; then
|
|
|
|
command_args="${command_args} --cd ${openvpn_dir}"
|
|
|
|
fi
|
|
|
|
}
|