aboutsummaryrefslogtreecommitdiffstats
path: root/os_net_config/objects.py
diff options
context:
space:
mode:
authorDan Prince <dprince@redhat.com>2014-08-12 11:06:46 -0400
committerDan Prince <dprince@redhat.com>2014-08-12 11:51:31 -0400
commitf0ae3282450c2bb1bb35f22414858768f08d2653 (patch)
treeedcf2d322f4b222bd0b11034ce4e09689caf10ef /os_net_config/objects.py
parentf57b67880d5c70bbc287ab56395895bb88a1b011 (diff)
Set the MAC to the primary interface
Adds support for a new 'primary' interface option exposed via the object model and JSON parsers which can be used to force the MAC address on a bridge. Only one interface on a given bridge (or bond) may be set as the primary interface. Also, update the ifcfg and eni providers so that they use OVS_EXTRA (or ovs_extra) to pin the mac accordingly.
Diffstat (limited to 'os_net_config/objects.py')
-rw-r--r--os_net_config/objects.py50
1 files changed, 37 insertions, 13 deletions
diff --git a/os_net_config/objects.py b/os_net_config/objects.py
index baef767..14ecfc6 100644
--- a/os_net_config/objects.py
+++ b/os_net_config/objects.py
@@ -79,15 +79,17 @@ class _BaseOpts(object):
"""Base abstraction for logical port options."""
def __init__(self, name, use_dhcp=False, use_dhcpv6=False, addresses=[],
- routes=[], mtu=1500):
+ routes=[], mtu=1500, primary=False):
self.name = name
self.mtu = mtu
self.use_dhcp = use_dhcp
self.use_dhcpv6 = use_dhcpv6
self.addresses = addresses
self.routes = routes
- self.bridge_name = None
- self.ovs_port = False
+ self.primary = primary
+ self.bridge_name = None # internal
+ self.ovs_port = False # internal
+ self.primary_interface_name = None # internal
def v4_addresses(self):
v4_addresses = []
@@ -106,11 +108,12 @@ class _BaseOpts(object):
return v6_addresses
@staticmethod
- def base_opts_from_json(json):
+ def base_opts_from_json(json, include_primary=True):
use_dhcp = strutils.bool_from_string(str(json.get('use_dhcp', False)))
use_dhcpv6 = strutils.bool_from_string(str(json.get('use_dhcpv6',
False)))
mtu = json.get('mtu', 1500)
+ primary = strutils.bool_from_string(str(json.get('primary', False)))
addresses = []
routes = []
@@ -134,16 +137,19 @@ class _BaseOpts(object):
msg = 'Routes must be a list.'
raise InvalidConfigException(msg)
- return (use_dhcp, use_dhcpv6, addresses, routes, mtu)
+ if include_primary:
+ return (use_dhcp, use_dhcpv6, addresses, routes, mtu, primary)
+ else:
+ return (use_dhcp, use_dhcpv6, addresses, routes, mtu)
class Interface(_BaseOpts):
"""Base class for network interfaces."""
def __init__(self, name, use_dhcp=False, use_dhcpv6=False, addresses=[],
- routes=[], mtu=1500):
+ routes=[], mtu=1500, primary=False):
super(Interface, self).__init__(name, use_dhcp, use_dhcpv6, addresses,
- routes, mtu)
+ routes, mtu, primary)
@staticmethod
def from_json(json):
@@ -160,10 +166,10 @@ class Vlan(_BaseOpts):
"""
def __init__(self, device, vlan_id, use_dhcp=False, use_dhcpv6=False,
- addresses=[], routes=[], mtu=1500):
+ addresses=[], routes=[], mtu=1500, primary=False):
name = 'vlan%i' % vlan_id
super(Vlan, self).__init__(name, use_dhcp, use_dhcpv6, addresses,
- routes, mtu)
+ routes, mtu, primary)
self.vlan_id = int(vlan_id)
self.device = device
@@ -181,17 +187,25 @@ class OvsBridge(_BaseOpts):
def __init__(self, name, use_dhcp=False, use_dhcpv6=False, addresses=[],
routes=[], mtu=1500, members=[], ovs_options=None):
super(OvsBridge, self).__init__(name, use_dhcp, use_dhcpv6, addresses,
- routes, mtu)
+ routes, mtu, False)
self.members = members
self.ovs_options = ovs_options
for member in self.members:
member.bridge_name = name
member.ovs_port = True
+ if member.primary:
+ if self.primary_interface_name:
+ msg = 'Only one primary interface allowed per bridge.'
+ raise InvalidConfigException(msg)
+ if member.primary_interface_name:
+ self.primary_interface_name = member.primary_interface_name
+ else:
+ self.primary_interface_name = member.name
@staticmethod
def from_json(json):
name = _get_required_field(json, 'name', 'OvsBridge')
- opts = _BaseOpts.base_opts_from_json(json)
+ opts = _BaseOpts.base_opts_from_json(json, include_primary=False)
ovs_options = json.get('ovs_options')
members = []
@@ -212,11 +226,21 @@ class OvsBond(_BaseOpts):
"""Base class for OVS bonds."""
def __init__(self, name, use_dhcp=False, use_dhcpv6=False, addresses=[],
- routes=[], mtu=1500, members=[], ovs_options=None):
+ routes=[], mtu=1500, primary=False, members=[],
+ ovs_options=None):
super(OvsBond, self).__init__(name, use_dhcp, use_dhcpv6, addresses,
- routes, mtu)
+ routes, mtu, primary)
self.members = members
self.ovs_options = ovs_options
+ for member in self.members:
+ if member.primary:
+ if self.primary_interface_name:
+ msg = 'Only one primary interface allowed per bond.'
+ raise InvalidConfigException(msg)
+ if member.primary_interface_name:
+ self.primary_interface_name = member.primary_interface_name
+ else:
+ self.primary_interface_name = member.name
@staticmethod
def from_json(json):