Sanitize our PATH a bit better, and terminate it correctly in start-stop-daemon.

This commit is contained in:
Roy Marples 2007-11-28 13:40:15 +00:00
parent 8ea741d699
commit d651155b61
3 changed files with 106 additions and 11 deletions

87
init.d.misc/openvpn Executable file
View 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
}

View File

@ -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

View File

@ -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);
} }