Sanitize our PATH a bit better, and terminate it correctly in start-stop-daemon.
This commit is contained in:
parent
8ea741d699
commit
d651155b61
87
init.d.misc/openvpn
Executable file
87
init.d.misc/openvpn
Executable file
@ -0,0 +1,87 @@
|
|||||||
|
#!/sbin/runscript
|
||||||
|
# Copyright 2007 Roy Marples
|
||||||
|
# All rights reserved
|
||||||
|
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions
|
||||||
|
# are met:
|
||||||
|
# 1. Redistributions of source code must retain the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer.
|
||||||
|
# 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer in the
|
||||||
|
# documentation and/or other materials provided with the distribution.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||||||
|
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
# SUCH DAMAGE.
|
||||||
|
|
||||||
|
if [ -z "${openvpn_dir}" ]; then
|
||||||
|
if [ -d /usr/local/etc/openvpn ]; then
|
||||||
|
openvpn_dir=/usr/local/etc/openvpn
|
||||||
|
else
|
||||||
|
openvpn_dir=/etc/openvpn
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
vpn=${SVCNAME#*.}
|
||||||
|
name="OpenVPN"
|
||||||
|
[ "${vpn}" != "openvpn" ] && name="${name} (${vpn})"
|
||||||
|
command=/usr/sbin/openvpn
|
||||||
|
[ -x ${command} ] || command=/usr/local/sbin/openvpn
|
||||||
|
|
||||||
|
pidfile="/var/run/${SVCNAME}.pid"
|
||||||
|
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
|
||||||
|
|
||||||
|
depend() {
|
||||||
|
need net
|
||||||
|
use dns
|
||||||
|
}
|
||||||
|
|
||||||
|
start_pre() {
|
||||||
|
# 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
|
||||||
|
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
|
||||||
|
}
|
@ -137,6 +137,16 @@ KV_to_int() {
|
|||||||
echo "${KV_int}"
|
echo "${KV_int}"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_sanitize_path() {
|
||||||
|
local IFS=":" p=
|
||||||
|
for p in ${PATH}; do
|
||||||
|
case "${p}" in
|
||||||
|
/lib/rc/sbin|/bin|/sbin|/usr/bin|/usr/sbin|/usr/local/bin|/usr/local/sbin) ;;
|
||||||
|
*) printf "%s" ":${p}";;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
# Allow our scripts to support zsh
|
# Allow our scripts to support zsh
|
||||||
if [ -n "${ZSH_VERSION}" ] ; then
|
if [ -n "${ZSH_VERSION}" ] ; then
|
||||||
emulate sh
|
emulate sh
|
||||||
@ -147,14 +157,9 @@ if [ -n "${ZSH_VERSION}" ] ; then
|
|||||||
setopt NO_GLOB_SUBST
|
setopt NO_GLOB_SUBST
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Setup a basic $PATH. Just add system default to existing.
|
# Add our bin to $PATH
|
||||||
# This should solve both /sbin and /usr/sbin not present when
|
export PATH="/lib/rc/bin:/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin$(_sanitize_path "${PATH}")"
|
||||||
# doing 'su -c foo', or for something like: PATH= rcscript start
|
unset _sanitize_path
|
||||||
case "${PATH}" in
|
|
||||||
/lib/rc/bin:/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin) ;;
|
|
||||||
/lib/rc/bin:/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:*) ;;
|
|
||||||
*) export PATH="/lib/rc/bin:/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:${PATH}" ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
for arg in "$@" ; do
|
for arg in "$@" ; do
|
||||||
case "${arg}" in
|
case "${arg}" in
|
||||||
|
@ -916,6 +916,7 @@ int start_stop_daemon (int argc, char **argv)
|
|||||||
char *token;
|
char *token;
|
||||||
char *np;
|
char *np;
|
||||||
int l;
|
int l;
|
||||||
|
int t;
|
||||||
|
|
||||||
p += 5;
|
p += 5;
|
||||||
while ((token = strsep (&p, ":"))) {
|
while ((token = strsep (&p, ":"))) {
|
||||||
@ -923,15 +924,17 @@ int start_stop_daemon (int argc, char **argv)
|
|||||||
strcmp (token, RC_LIBDIR "/sbin") == 0)
|
strcmp (token, RC_LIBDIR "/sbin") == 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
t = strlen (token);
|
||||||
if (newpath) {
|
if (newpath) {
|
||||||
l = strlen (newpath);
|
l = strlen (newpath);
|
||||||
newpath = xrealloc (newpath, sizeof (char) *
|
newpath = xrealloc (newpath, sizeof (char) * (l + t + 2));
|
||||||
(l + strlen (token) + 2));
|
|
||||||
np = newpath + l;
|
np = newpath + l;
|
||||||
*np++ = ':';
|
*np++ = ':';
|
||||||
memcpy (np, token, sizeof (char) * strlen (token));
|
memcpy (np, token, sizeof (char) * strlen (token));
|
||||||
|
np += t;
|
||||||
|
*np = '\0';
|
||||||
} else {
|
} else {
|
||||||
l = strlen ("PATH=") + strlen (token) + 1;
|
l = strlen ("PATH=") + t + 1;
|
||||||
newpath = xmalloc (sizeof (char) * l);
|
newpath = xmalloc (sizeof (char) * l);
|
||||||
snprintf (newpath, l, "PATH=%s", token);
|
snprintf (newpath, l, "PATH=%s", token);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user