rm -f $tmp
}
-vserver=$1
-
-## Do some magic to set the vserver into a defined state
-$_VSERVER "$vserver" stop &>/dev/null || :
-$_VSERVER "$vserver" start --rescue --rescue-init bash -c '
- exec >/dev/null
- exec 2>/dev/null
-
- set -x
- f=/tmp/startwait
- trap "rm -f $f" EXIT
- mkfifo $f
- ( sleep 15; kill -s 9 -- -1 ) &
- cat "$f" >/dev/null
- kill -s 9 -- -1
- wait
-'
-
pushd "$vdir"/etc/init.d &>/dev/null ||
pushd "$vdir"/etc/rc.d/init.d &>/dev/null || exit 1
functions|halt|killall|single) ;;
syslog) ;;
*)
- $_VSERVER "$1" chkconfig "$i" off
+ $_VSERVER ----insecure "$1" chkconfig "$i" off
;;
esac
done
+ relink /bin/true halt
popd >/dev/null
pushd "$vdir"/sbin &>/dev/null
popd >/dev/null
pushd "$vdir" &>/dev/null
- cat <<EOF | $_CHROOT_SH truncate /etc/init.d/halt
-#! /bin/bash
-
-exec /sbin/killall5 -15
-EOF
- $_CHROOT_SH chmod 0755 /etc/init.d/halt
-
: | $_CHROOT_SH truncate /etc/sysctl.conf
echo "none / none defaults" | $_CHROOT_SH truncate /etc/fstab
cat "$__DISTRIBDIR"/redhat/rc.sysinit | $_CHROOT_SH truncate /etc/rc.d/rc.sysinit.vserver
- $_CHROOT_SH chmod 0755 /etc/rc.d/rc.sysinit.vserver
+ # TODO: remove race/symlink-attack
+ chmod +x etc/rc.d/rc.sysinit.vserver
subst etc/inittab 's!^\([^#].*:respawn:.* tty\)!#\1!;
s!si::sysinit:/etc/rc.d/rc.sysinit!si::sysinit:/etc/rc.d/rc.sysinit.vserver!'
popd >/dev/null
-
-$_VSERVER "$vserver" exec bash -c ': >/tmp/startwait' &>/dev/null || :
-$_VSERVER "$vserver" stop &>/dev/null || :