X-Git-Url: https://git.stderr.nl/gitweb?a=blobdiff_plain;f=usr%2Flocal%2Fbin%2Fvserver-create;h=10f6d3985a6744d26959da1fd9b528f8d4766394;hb=refs%2Fheads%2Fds-host;hp=cd621d53fb6c65ce51b6d6946de72d5e8c384043;hpb=a87df1f478d85c1e69aa3d56e961500084aeab40;p=matthijs%2Fservers%2Fdrsnuggles.git diff --git a/usr/local/bin/vserver-create b/usr/local/bin/vserver-create index cd621d5..10f6d39 100755 --- a/usr/local/bin/vserver-create +++ b/usr/local/bin/vserver-create @@ -14,10 +14,8 @@ IP_RANGE=10.42.0. INTERFACE=dummy0 # The netmask for the address NETMASK=24 -HOSTS_VSERVER=dns -# The hosts file to which an entry for the new vserver should be added. Can be -# left empty to not record the new vserver anywhere. -HOSTS_FILE=$VSERVERS_CONF/$HOSTS_VSERVER/vdir/etc/hosts +# The DNS vserver gets a new entry in its /etc/hosts +DNS_VSERVER=dns function usage() { @@ -38,6 +36,11 @@ function find_ip() return 1 } +if [ "`id -u`" -eq 0 ]; then + echo "$0 should not be run as root, it will use sudo where appropriate" + exit 1 +fi + # Check arguments if [ ! "$#" -eq 1 ]; then usage @@ -51,7 +54,7 @@ if ! echo $NAME | grep "^[a-zA-Z0-9-]*$" &>/dev/null; then exit 1 fi -HOST="$NAME/`hostname --fqdn`" +HOST="$NAME.`hostname --fqdn`" # Set the IP var if ! find_ip; then @@ -84,6 +87,10 @@ CONF_FOR_GIT=`echo $VSERVERS_CONF/$NAME | sed "s#^/*##"` (cd /; git add $CONF_FOR_GIT) (cd /; git commit $CONF_FOR_GIT --edit --message "vserver: Add $NAME vserver configuration.") -if [ -n "$HOSTS_FILE" ]; then - sudo sh -c "echo '$IP $NAME' >> '$HOSTS_FILE'" -fi +# Add this new vserver to the hosts file in the dns vserver and in the host +for file in /etc/hosts "$VSERVERS_CONF/$DNS_VSERVER/vdir/etc/hosts"; do + sudo sh -c "echo '$IP $NAME' >> '$file'" +done + +# Restart dnsmasq in the dns vserver +sudo vserver $DNS_VSERVER exec /usr/bin/killall -HUP dnsmasq"