blob: 459da341365fd3973de0c85abe433fdc9d30bf1c [file] [log] [blame] [raw]
#!/bin/bash
# Copyright (C) 2000-2008, Parallels, Inc. All rights reserved.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
#
# Adds an IP address in a container running Slackware 9.
# Slackware does not support IP aliases so multiple IP addresses not allowed
VENET_DEV=venet0
IFCFG_DIR=/etc/rc.d
IFCFG=${IFCFG_DIR}/rc.inet1
HOSTFILE=/etc/hosts
function fix_rcinet1()
{
[ -f "${IFCFG}" ] || return 0
cp -fp ${IFCFG} ${IFCFG}.$$ || error "Can't copy file ${IFCFG}" ${VZ_FS_NO_DISK_SPACE}
sed -e "s/^GATEWAY=.*/GATEWAY=\"${FAKEGATEWAY}\"/" -e 's/^USE_DHCP=.*/#USE_DHCP=""/' -e 's/eth0/venet0/g' -e 's#^[\ \t]*/sbin/route add default gw .*#\t/sbin/route add -net '"${FAKEGATEWAYNET}"'/24 dev venet0; /sbin/route add default gw \${GATEWAY} dev venet0#' < ${IFCFG} > ${IFCFG}.$$ && mv -f ${IFCFG}.$$ ${IFCFG}
rm -f ${IFCFG}.$$ >/dev/null 2>&1
}
function setup_network()
{
mkdir -p ${IFCFG_DIR}
# Set up /etc/hosts
if [ ! -f ${HOSTFILE} ]; then
echo "127.0.0.1 localhost.localdomain localhost" > $HOSTFILE
fi
fix_rcinet1
}
function create_config()
{
local address=${1}
local netmask=${2}
put_param ${IFCFG} "IPADDR" ${address}
put_param ${IFCFG} "NETMASK" ${netmask}
}
function add_address()
{
# In case we are starting CT
if [ "x${VE_STATE}" = "xstarting" ]; then
setup_network
fi
local ipm
for ipm in ${IP_ADDR}; do
ip_conv $ipm
if [ "${IPDELALL}" != "yes" ]; then
if grep -qw "${_IP}" ${IFCFG} 2>/dev/null; then
break
fi
fi
${IFCFG_DIR}/rc.inet1 stop >/dev/null 2>&1
create_config ${_IP} ${_NETMASK}
${IFCFG_DIR}/rc.inet1 start >/dev/null 2>&1
break
done
}
add_address
exit 0
# end of script