blob: a94abe362207575d84e2fb11a9dbf0093c28e6dc [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 IP address(es) in a container running Debian-like distro.
VENET_DEV=venet0
LOOPBACK=lo
CFGFILE=/etc/network/interfaces
HOSTFILE=/etc/hosts
function setup_network()
{
echo -e "# This configuration file is auto-generated.
# WARNING: Do not edit this file, your changes will be lost.
# Please create/edit $CFGFILE.head and $CFGFILE.tail instead,
# their contents will be inserted at the beginning and at the end
# of this file, respectively.
" > ${CFGFILE}
if [ -f ${CFGFILE}.head ]; then
cat ${CFGFILE}.head >> ${CFGFILE}
fi
if [ -f ${CFGFILE}.template ]; then
cat ${CFGFILE}.template >> ${CFGFILE}
fi
# Set up loopback
if ! grep -qw lo ${CFGFILE}; then
echo -e "# Auto generated ${LOOPBACK} interface
auto ${LOOPBACK}
iface ${LOOPBACK} inet loopback" >> ${CFGFILE}
fi
# Set up /etc/hosts
if [ ! -f $HOSTFILE ]; then
echo "127.0.0.1 localhost.localdomain localhost" > $HOSTFILE
if [ "${IPV6}" = "yes" ]; then
echo "::1 localhost.localdomain localhost" >> $HOSTFILE
fi
fi
[ -z "${IP_ADDR}" ] && return
# Set up venet0
echo -e "
# Auto generated ${VENET_DEV} interface
auto ${VENET_DEV}
iface ${VENET_DEV} inet static
address 127.0.0.1
netmask 255.255.255.255
broadcast 0.0.0.0
up route add -net ${FAKEGATEWAY} netmask 255.255.255.255 dev ${VENET_DEV}
up route add default gw ${FAKEGATEWAY}" >> ${CFGFILE}
if [ "${IPV6}" = "yes" ]; then
echo -e "
iface venet0 inet6 static
address ::1
netmask 128
" >> ${CFGFILE}
fi
if [ -f ${CFGFILE}.tail ]; then
cat ${CFGFILE}.tail >> ${CFGFILE}
fi
}
function create_config()
{
local ip=$1
local ifnum=$2
if [ "${ip#*:}" = "${ip}" ]; then
echo -e "auto ${VENET_DEV}:${ifnum}
iface ${VENET_DEV}:${ifnum} inet static
address ${ip}
netmask 255.255.255.255
broadcast 0.0.0.0
" >> ${CFGFILE}.bak
else
sed -i -e "s/netmask\ 128/netmask\ 128\n\tup ifconfig venet0 add ${ip}\/0/" ${CFGFILE}.bak
fi
}
function get_all_aliasid()
{
IFNUM=-1
IFNUMLIST=`grep -e "^auto ${VENET_DEV}:.*$" 2> /dev/null ${CFGFILE}.bak | sed "s/.*${VENET_DEV}://"`
}
function get_free_aliasid()
{
local found=
[ -z "${IFNUMLIST}" ] && get_all_aliasid
while test -z ${found}; do
let IFNUM=IFNUM+1
echo "${IFNUMLIST}" | grep -q -E "^${IFNUM}$" 2>/dev/null ||
found=1
done
}
function add_ip()
{
local ip
local found
local add
local iface
if [ "x${VE_STATE}" = "xstarting" ]; then
remove_debian_interface "${VENET_DEV}:[0-9]*" ${CFGFILE}
setup_network
elif ! grep -q -E "^auto ${VENET_DEV}([^:]|$)" ${CFGFILE} 2>/dev/null; then
setup_network
fi
if [ "${IPDELALL}" = "yes" ]; then
ifdown ${VENET_DEV} >/dev/null 2>&1
remove_debian_interface "${VENET_DEV}:[0-9]*" ${CFGFILE}
grep -v "up ifconfig venet0 add" /etc/network/interfaces > ${CFGFILE}.bak
mv ${CFGFILE}.bak ${CFGFILE}
fi
cp -f ${CFGFILE} ${CFGFILE}.bak
for ip in ${IP_ADDR}; do
found=
if grep -e "\\<${ip}\\>" >/dev/null 2>&1 ${CFGFILE}.bak; then
continue
fi
get_free_aliasid
create_config ${ip} ${IFNUM}
done
mv -f ${CFGFILE}.bak ${CFGFILE}
if [ "x${VE_STATE}" = "xrunning" ]; then
if [ "${ip#*:}" = "${ip}" ]; then
/sbin/ifup -a --force 2>/dev/null
else
/etc/init.d/networking restart > /dev/null 2>&1
fi
fi
}
add_ip
exit 0