compass-adapters/cobbler/snippets/post_install_network_config_deb
2013-12-12 01:33:01 +00:00

232 lines
11 KiB
Plaintext

# Start post_install_network_config generated code
#if $getVar("system_name","") != ""
## this is being provisioned by system records, not profile records
## so we can do the more complex stuff
## get the list of interface names
#set ikeys = $interfaces.keys()
#set osversion = $getVar("os_version","")
#import re
#set $vlanpattern = $re.compile("[a-zA-Z0-9]+[\.:][0-9]+")
## Determine if we should use the MAC address to configure the interfaces first
## Only physical interfaces are required to have a MAC address
## Also determine the number of bonding devices we have, so we can set the
## max-bonds option in modprobe.conf accordingly. -- jcapel
#set $configbymac = True
#set $bridge_slaves = {}
#set $numbondingdevs = 0
#set $enableipv6 = False
## =============================================================================
#for $iname in $ikeys
## look at the interface hash data for the specific interface
#set $idata = $interfaces[$iname]
## do not configure by mac address if we don't have one AND it's not for bonding/vlans
## as opposed to a "real" physical interface
#if $idata.get("mac_address", "") == "" and not $vlanpattern.match($iname) and not $idata.get("interface_type", "").lower() in ("master","bond","bridge"):
## we have to globally turn off the config by mac feature as we can't
## use it now
#set $configbymac = False
#end if
## count the number of bonding devices we have.
#if $idata.get("interface_type", "").lower() in ("master","bond","bonded_bridge_slave")
#set $numbondingdevs += 1
#end if
## build a mapping of bridge slaves, since deb/ubuntu bridge slaves do not
## get interface entries of their own
#if $idata.get("interface_type","").lower() == "bridge_slave"
#set $this_master = $idata.get("interface_master", None)
#if $this_master and not $bridge_slaves.has_key($this_master)
#set $bridge_slaves[$this_master] = []
#end if
<% bridge_slaves[this_master].append(iname) %>
#end if
## enable IPv6 networking if we set an ipv6 address or turn on autoconfiguration
#if $idata.get("ipv6_address", "") != "" or $ipv6_autoconfiguration == True
#set $enableipv6 = True
#end if
#end for
## end looping through the interfaces to see which ones we need to configure.
## =============================================================================
## Rewrite the interfaces file and make sure we preserve the loopback device
rm -f /etc/network/interfaces
touch /etc/network/interfaces
echo "auto lo" >> /etc/network/interfaces
echo "iface lo inet loopback" >> /etc/network/interfaces
echo "" >> /etc/network/interfaces
## =============================================================================
## now create the config file for each interface
#for $iname in $ikeys
## create lots of variables to use later
#set $idata = $interfaces[$iname]
#set $mac = $idata.get("mac_address", "").upper()
#set $mtu = $idata.get("mtu", "")
#set $static = $idata.get("static", "")
#set $ip = $idata.get("ip_address", "")
#set $netmask = $idata.get("netmask", "")
#set $if_gateway = $idata.get("if_gateway", "")
#set $static_routes = $idata.get("static_routes", "")
#set $iface_type = $idata.get("interface_type", "").lower()
#set $iface_master = $idata.get("interface_master", "")
#set $bonding_opts = $idata.get("bonding_opts", "")
#set $bridge_opts = $idata.get("bridge_opts", "").split(" ")
#set $ipv6_address = $idata.get("ipv6_address", "")
#set $ipv6_secondaries = $idata.get("ipv6_secondaries", "")
#set $ipv6_mtu = $idata.get("ipv6_mtu", "")
#set $ipv6_default_gateway = $idata.get("ipv6_default_gateway", "")
#set $ipv6_static_routes = $idata.get("ipv6_static_routes", "")
#set $devfile = "/etc/sysconfig/network-scripts/cobbler/ifcfg-" + $iname
#set $routesfile = "/etc/sysconfig/network-scripts/cobbler/route-" + $iname
#set $ipv6_routesfile = "/etc/sysconfig/network-scripts/cobbler/route6-" + $iname
## determine if this interface is for a VLAN
#if $vlanpattern.match($iname)
#set $is_vlan = "true"
#else
#set $is_vlan = "false"
#end if
## slave interfaces are assumed to be static
#if $iface_type in ("slave","bond_slave","bridge_slave","bonded_bridge_slave")
#set $static = 1
#end if
## ===================================================================
## Things every interface get, no matter what
## ===================================================================
echo "auto $iname" >> /etc/network/interfaces
## ===================================================================
## Actions based on interface_type
## ===================================================================
#if $iface_type in ("master","bond","bonded_bridge_slave")
#pass
#elif $iface_type in ("slave","bond_slave") and $iface_master != ""
#pass
#elif $iface_type == "bridge"
#set $slave_ports = " ".join($bridge_slaves.get($iname,[]))
#if $slave_ports != ""
echo " bridge_ports $slave_ports" >> /etc/network/interfaces
#end if
#for $bridge_opt in $bridge_opts
#if $bridge_opt.strip() != ""
echo " $bridge_opt" >> /etc/network/interfaces
#end if
#end for
#end if
## ===================================================================
## Actions based on static configuration
## ===================================================================
#if $static
#if $ip != "" and $iface_type not in ("slave","bond_slave","bridge_slave","bonded_bridge_slave")
echo "iface $iname inet static" >> /etc/network/interfaces
echo " hwaddress $mac" >> /etc/network/interfaces
echo " address $ip" >> /etc/network/interfaces
#if $netmask != ""
echo " netmask $netmask" >> /etc/network/interfaces
#end if
#if $iface_type in ("master","bond")
#set $bondslaves = ""
#for $bondiname in $ikeys
#set $bondidata = $interfaces[$bondiname]
#set $bondiface_type = $bondidata.get("interface_type", "").lower()
#set $bondiface_master = $bondidata.get("interface_master", "")
#if $bondiface_master == $iname
#set $bondslaves += $bondiname + " "
#end if
#end for
echo " bond-slaves $bondslaves" >> /etc/network/interfaces
#for $bondopts in $bonding_opts.split(" ")
#set [$bondkey, $bondvalue] = $bondopts.split("=")
echo " bond-$bondkey $bondvalue" >> /etc/network/interfaces
#end for
#end if
#else
echo "iface $iname inet manual" >> /etc/network/interfaces
#end if
#if $iface_type in ("slave","bond_slave") and $iface_master != ""
echo "bond-master $iface_master" >> /etc/network/interfaces
#end if
#if $enableipv6 == True and $ipv6_autoconfiguration == False
#if $ipv6_address != ""
#pass
#end if
#if $ipv6_secondaries != ""
#set ipv6_secondaries = ' '.join(ipv6_secondaries)
#end if
#if $ipv6_mtu != ""
#pass
#end if
#if $ipv6_default_gateway != ""
#pass
#end if
#end if
#else
echo "iface $iname inet dhcp" >> /etc/network/interfaces
#end if
## ===================================================================
## VLAN configuration
## ===================================================================
#if $is_vlan == "true"
#pass
#end if
## ===================================================================
## Optional configuration stuff
## ===================================================================
#if $if_gateway != ""
echo " gateway $if_gateway" >> /etc/network/interfaces
#end if
#if $mtu != ""
echo " mtu $mtu" >> /etc/network/interfaces
#end if
## ===================================================================
## Interface route configuration
## ===================================================================
#for $route in $static_routes
#set routepattern = $re.compile("[0-9/.]+:[0-9.]+")
#if $routepattern.match($route)
#set [$network, $router] = $route.split(":")
echo " up ip route add $network via $router dev $iname || true" >> /etc/network/interfaces
#else
echo " # Warning: invalid route: $route" >> /etc/network/interfaces
#end if
#end for
#if $enableipv6 == True
#for $route in $ipv6_static_routes
#set routepattern = $re.compile("[0-9a-fA-F:/]+,[0-9a-fA-F:]+")
#if $routepattern.match($route)
#set [$network, $router] = $route.split(",")
echo " up ip -6 route add $network via $router dev $iname || true" >> /etc/network/interfaces
#else
echo " # Warning: invalid route: $route" >> /etc/network/interfaces
#end if
#end for
#end if
## ===================================================================
## Done with this interface
## ===================================================================
#end for
## =============================================================================
## Configure the system's primary hostname. This is also passed to anaconda, but
## anaconda doesn't seem to honour it in DHCP-setups.
#if $hostname != ""
echo "$hostname" > /etc/hostname
/bin/hostname $hostname
#end if
## =============================================================================
## Configure name server search path in /etc/resolv.conf
#set $num_ns = $len($name_servers)
#set $num_ns_search = $len($name_servers_search)
#if $num_ns_search > 0
sed -i -e "/^search /d" /etc/resolv.conf
echo -n "search " >>/etc/resolv.conf
#for $nameserversearch in $name_servers_search
echo -n "$nameserversearch " >>/etc/resolv.conf
#end for
echo "" >>/etc/resolv.conf
#end if
## =============================================================================
## Configure name servers in /etc/resolv.conf
#if $num_ns > 0
sed -i -e "/^nameserver /d" /etc/resolv.conf
#for $nameserver in $name_servers
echo "nameserver $nameserver" >>/etc/resolv.conf
#end for
#end if
#end if
# End post_install_network_config generated code