Commit fcaece64 authored by Andy Whitcroft's avatar Andy Whitcroft Committed by Tim Gardner

UBUNTU: [Debian] hv: hv_set_ifconfig -- fix numerous parameter handling issues

Fix a number of KVP parameter parsing issues:

1) we should not be separating the prefix and instance numbers with an '_',
2) IPADDR/NETMASK instance 0 does have a suffix which we do not provide,
3) GATEWAY instance 0 is inconsistant,
4) IPv6 should be configured whether IPv4 is DHCP or not, and
5) DHCP mode is selected via BOOTPROTO=dhcp not DHCP=yes.

BugLink: http://bugs.launchpad.net/bugs/1540586Signed-off-by: default avatarAndy Whitcroft <apw@canonical.com>
parent 6b4d4038
...@@ -55,6 +55,23 @@ if len(sys.argv) != 2 : ...@@ -55,6 +55,23 @@ if len(sys.argv) != 2 :
# BOOTPROTO=<protocol> (where <protocol> is "dhcp" if DHCP is configured # BOOTPROTO=<protocol> (where <protocol> is "dhcp" if DHCP is configured
# or "none" if no boot-time protocol should be used) # or "none" if no boot-time protocol should be used)
# #
# IPADDR0=ipaddr1
# IPADDR1=ipaddr2
# IPADDRx=ipaddry (where y = x + 1)
#
# NETMASK0=netmask1
# NETMASKx=netmasky (where y = x + 1)
#
# GATEWAY=ipaddr1
# GATEWAYx=ipaddry (where y = x + 1)
#
# DNSx=ipaddrx (where first DNS address is tagged as DNS1 etc)
#
# IPV6 addresses will be tagged as IPV6ADDR, IPV6 gateway will be
# tagged as IPV6_DEFAULTGW and IPV6 NETMASK will be tagged as
# IPV6NETMASK.
#
kvp=dict(line.strip().split("=") for line in fileinput.input()) kvp=dict(line.strip().split("=") for line in fileinput.input())
# Setting the hwaddress to something azure is not expecting is fatal # Setting the hwaddress to something azure is not expecting is fatal
...@@ -69,92 +86,96 @@ if not "DEVICE" in kvp : ...@@ -69,92 +86,96 @@ if not "DEVICE" in kvp :
output=[] output=[]
basename=kvp["DEVICE"] basename=kvp["DEVICE"]
if "DHCP" in kvp and kvp["DHCP"]=="yes" : # DNS entries will go with the first interface and there can be a max
# of three. These will be emitted with the first interface.
dns = []
for count in (1, 2, 3):
key = "DNS" + str(count)
if key in kvp:
dns += [kvp[key]]
dns_emitted = False
# IPV4 may either be dhcp or static.
if ("DHCP" in kvp and kvp["DHCP"] == "yes") or \
("BOOTPROTO" in kvp and kvp["BOOTPROTO"] == "dhcp"):
output += ["auto " + basename] output += ["auto " + basename]
output += ["iface " + basename + " inet dhcp"] output += ["iface " + basename + " inet dhcp"]
output += [""] output += [""]
else: else:
autolist = []
# Matchup the interface specific lines # Matchup the interface specific lines
# DNS entries will go with the first interface
# and there can be a max of three
autolist=[]
dns=[]
if "DNS1" in kvp :
dns+=[kvp["DNS1"]]
if "DNS2" in kvp :
dns+=[kvp["DNS2"]]
if "DNS3" in kvp :
dns+=[kvp["DNS3"]]
# No real max for the number of interface + aliases ... # No real max for the number of interface + aliases ...
# only required is the address (but mate everything up that comes in. # only required is the address (but mate everything up that comes in.
# IPv4 # IPv4 -- ensure we sort by numeric suffixes.
v4names=[name for name in kvp.keys() if name.startswith("IPADDR")] v4names = [ int(name[6:]) for name in kvp.keys() if name.startswith("IPADDR") ]
v4names.sort() v4names.sort()
if_count=0 for if_count in v4names:
for v4 in v4names: ifname = basename
ifname=basename which = str(if_count)
suffix=""
if if_count : if if_count:
ifname+=":" + str(if_count) ifname += ":" + str(if_count)
suffix="_"+str(if_count) which_gw = which
else:
which_gw = ""
if not ifname in autolist: if not ifname in autolist:
autolist += [ifname] autolist += [ifname]
output += [ "iface " + ifname + " inet static"]
output += [ "\t" + "address " + kvp[v4]] output += [ "iface " + ifname + " inet static" ]
if "NETMASK"+suffix in kvp.keys(): output += [ "\t" + "address " + kvp["IPADDR" + which] ]
output += ["\tnetmask " + kvp["NETMASK"+suffix]] if "NETMASK" + which in kvp:
if "GATEWAY"+suffix in kvp.keys(): output += [ "\tnetmask " + kvp["NETMASK" + which] ]
output += ["\tgateway " + kvp["GATEWAY"+suffix]] if "GATEWAY" + which_gw in kvp:
if not if_count : output += ["\tgateway " + kvp["GATEWAY" + which_gw]]
if not dns_emitted:
dns_emitted = True
output += ["\tdns-nameservers " + ' '.join(dns)] output += ["\tdns-nameservers " + ' '.join(dns)]
output += [""] output += [""]
if_count+=1
# IPv6 requires a netmask
# If an ipv6 exists, you'll want to turn off /proc/sys/net/ipv6/conf/all/autoconf with
# IPv6 requires a netmask # echo 0 > /proc/sys/net/ipv6/conf/all/autoconf
# If an ipv6 exists, you'll want to turn off /proc/sys/net/ipv6/conf/all/autoconf with v6names = [ int(name[8:]) for name in kvp.keys() if name.startswith("IPV6ADDR") ]
# echo 0 > /proc/sys/net/ipv6/conf/all/autoconf v6names.sort()
v6names=[name for name in kvp.keys() if name.startswith("IPV6ADDR")]
v6names.sort() for if6_count in v6names:
ifname = basename
if6_count=0 which = str(if6_count)
if6_used=0
for v6 in v6names: if if6_count:
ifname=basename ifname += ":" + str(if6_count)
suffix="" which_gw = which
if if6_used : else:
ifname+=":" + str(if6_used) which_gw = ""
if if6_count :
suffix="_" + str(if6_count) if not ifname in autolist:
if not ifname in autolist: autolist += [ifname]
autolist += [ifname]
if "IPV6NETMASK"+suffix in kvp.keys(): if "IPV6NETMASK" + which in kvp:
output += [ "iface " + ifname + " inet6 static"] output += [ "iface " + ifname + " inet6 static"]
output += [ "\taddress " + kvp[v6]] output += [ "\taddress " + kvp["IPV6ADDR" + which]]
output += [ "\tnetmask " + kvp["IPV6NETMASK"+suffix]] output += [ "\tnetmask " + kvp["IPV6NETMASK" + which]]
if "IPV6_DEFAULTGW"+suffix in kvp.keys(): if "IPV6_DEFAULTGW" + which_gw in kvp:
output += [ "\tgateway " + kvp["IPV6_DEFAULTGW"+suffix] ] output += [ "\tgateway " + kvp["IPV6_DEFAULTGW" + which_gw] ]
if not if_count : if not dns_emitted:
output += ["\tdns-nameservers " + ' '.join(dns)] dns_emitted = True
output += [""] output += ["\tdns-nameservers " + ' '.join(dns)]
if_count += 1 output += [""]
if6_used += 1
if6_count += 1 # Mark this new interface for automatic up.
output = ["auto "+" ".join(autolist)] + output
# Mark this new interface for automatic up.
output = ["auto "+" ".join(autolist)] + output
print("===================================") print("===================================")
print(output) print(output)
print("===================================") print("===================================")
''' Time to clean out the existing interface file''' # Time to clean out the existing interface file
# Markers. # Markers.
start_mark = "# The following stanza(s) added by hv_set_ifconfig" start_mark = "# The following stanza(s) added by hv_set_ifconfig"
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment