From 1675d6af19244edda34049bceefd0d9e1c680a9d Mon Sep 17 00:00:00 2001 From: kre Date: Fri, 18 Nov 2016 23:10:05 +0000 Subject: [PATCH] The config file is not required to exist (unless specified via -d). (reported by rhialto@falu.nl) Don't fail to start if it doesn't. Make sure the directory for the config file exists inside the chroot before attempting to copy into it ("confdir" was calculated, but never used...) While here, fix getopts usage (obviously only ever previously tested when the -c arg was the first option...) and don't use test(1)'s -o operator (especially not when one of the other args is an unknown string). If -c is given (and we will chroot), require filename to be full path. Misc minor style cleanups. --- etc/rc.d/rtadvd | 45 ++++++++++++++++++++++++++++++++------------- 1 file changed, 32 insertions(+), 13 deletions(-) diff --git a/etc/rc.d/rtadvd b/etc/rc.d/rtadvd index 5fe67720fda3..3e7b744ff33c 100755 --- a/etc/rc.d/rtadvd +++ b/etc/rc.d/rtadvd @@ -1,6 +1,6 @@ #!/bin/sh # -# $NetBSD: rtadvd,v 1.8 2013/07/09 09:34:58 roy Exp $ +# $NetBSD: rtadvd,v 1.9 2016/11/18 23:10:05 kre Exp $ # # PROVIDE: rtadvd @@ -21,28 +21,47 @@ rtadvd_prereload() { local chdir="$(getent passwd _rtadvd | cut -d: -f6)" local conf=/etc/rtadvd.conf myflags o confdir + local cflag=false - [ -z "$chdir" -o "$chdir" = / ] && return 0 + [ -z "${chdir}" ] || [ "/${chdir}" = // ] && return 0 - if [ -n "$flags" ]; then - myflags=$flags + if [ -n "${flags}" ]; then + myflags=${flags} else eval myflags=\$${name}_flags fi set -- ${myflags} while getopts c:dDfM:Rs o; do - case "$1" in - -c) conf="$OPTARG";; + # ignore other args, they are processed by rtadvd itself + case "${o}" in + c) conf="${OPTARG}" + case "${conf}" in + /*) ;; + *) echo "${name}: config file (${conf}) must be" \ + "full pathname" + return 1 + ;; + esac + cflag=true;; esac - shift done - confdir=$(dirname "$conf") - - echo "$name: copying $conf to $chdir$conf" - cp "$conf" "$chdir$conf" - # Provide a link to the chrooted dump file - ln -snf "$chdir/var/run/$name.dump" /var/run + ${cflag} || test -f "${conf}" && { + confdir=$(dirname "${conf}") + echo "${name}: copying ${conf} to ${chdir}${conf}" + mkdir -p "${chdir}${confdir}" + cp "${conf}" "${chdir}${conf}" || return 1 + } + + # Make sure /var/run exists in the chroot + mkdir -p "${chdir}/var/run" + + # Provide links to the chrooted dump & pid files + ln -snf "${chdir}/var/run/${name}.dump" /var/run + + # Note: actual chroot is done by rtadvd itself + + return 0 } rtadvd_prestart()