/etc/vz/dists/scripts/funtoo-add_ip.sh is in vzctl 4.9.4-5.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 | #!/bin/bash
# Copyright (C) 2010-2011, 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
#
# This script configures IP alias(es) inside Funtoo-based CT with
# OpenRC used as services/startup/shutdown system.
#
# Note that modern versions of vzctl runs this script even if there
# are not venet IPs to add to the CT, which resulted in netif.venet0
# being created even when venet wasn't enabled for this container.
# This could indicate an upstream bug.
VENET_DEV=venet0
IFCFG=/etc/conf.d/netif.${VENET_DEV}
SCRIPT=/etc/runlevels/default/netif.${VENET_DEV}
HOSTFILE=/etc/hosts
function comment_line_regex()
{
cp -pf ${IFCFG} ${IFCFG}.$$ ||
error "Failed to comment ${1}: unable to copy ${IFCFG}" ${VZ_FS_NO_DISK_SPACE}
sed -e "s/${1}/#${1}/" < ${IFCFG} > ${IFCFG}.$$ &&
mv -f ${IFCFG}.$$ ${IFCFG} 2>/dev/null
if [ $? -ne 0 ]; then
rm -f ${IFCFG}.$$ 2>/dev/null
error "Failed to comment ${1}: unable to create ${IFCFG}" ${VZ_FS_NO_DISK_SPACE}
fi
}
function set_rc()
{
[ -f "${SCRIPT}" ] && return 0
ln -sf netif.tmpl /etc/init.d/netif.${VENET_DEV}
rc-update add netif.${VENET_DEV} default &>/dev/null
}
unset_rc()
{
# used for disabling venet if we are using veth and no IPs are specified
rc-update del netif.${VENET_DEV} default &>/dev/null
rm -f /etc/init.d/netif.${VENET_DEV}
rm -f /etc/conf.d/netif.${VENET_DEV}
ip link set ${VENET_DEV} down > /dev/null 2>&1
}
function init_netconfig()
{
if [ "$IP_ADDR" != "" ]
then
set_rc
else
unset_rc
fi
# Set up /etc/hosts
if [ ! -f ${HOSTFILE} ]; then
echo "127.0.0.1 localhost.localdomain localhost" > $HOSTFILE
fi
}
function add_ip()
{
local ipm
if [ "x${VE_STATE}" = "xstarting" -o "x${IPDELALL}" = "xyes" ]; then
init_netconfig
if [ "x${IPDELALL}" = "xyes" ]; then
/etc/init.d/netif.${VENET_DEV} stop >/dev/null 2>&1
return 0
fi
fi
local ips=""
if [ "${VENET_DEV}" = "venet0" ]
then
ips="127.0.0.1/32"
put_param "${IFCFG}" "route" "default dev venet0"
fi
for ipm in ${IP_ADDR}; do
ip_conv $ipm
ips="$ips $_IP/$_MASK"
done
put_param "${IFCFG}" "template" "interface"
put_param "${IFCFG}" "ipaddrs" "$ips"
if [ "x${VE_STATE}" = "xrunning" ]; then
# synchronize config files & interfaces
/etc/init.d/netif.${VENET_DEV} restart >/dev/null 2>&1
fi
}
add_ip
exit 0
# end of script
|