Merge "Get OVS port details from port ID"
This commit is contained in:
commit
6c7582e7a7
@ -19,6 +19,7 @@
|
|||||||
# @author: Dave Lapsley, Nicira Networks, Inc.
|
# @author: Dave Lapsley, Nicira Networks, Inc.
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
|
import re
|
||||||
import shlex
|
import shlex
|
||||||
import signal
|
import signal
|
||||||
import subprocess
|
import subprocess
|
||||||
@ -47,6 +48,17 @@ class OVSBridge:
|
|||||||
def __init__(self, br_name, root_helper):
|
def __init__(self, br_name, root_helper):
|
||||||
self.br_name = br_name
|
self.br_name = br_name
|
||||||
self.root_helper = root_helper
|
self.root_helper = root_helper
|
||||||
|
self.re_id = self.re_compile_id()
|
||||||
|
|
||||||
|
def re_compile_id(self):
|
||||||
|
external = 'external_ids\s*'
|
||||||
|
mac = 'attached-mac="(?P<vif_mac>([a-fA-F\d]{2}:){5}([a-fA-F\d]{2}))"'
|
||||||
|
iface = 'iface-id="(?P<vif_id>[^"]+)"'
|
||||||
|
name = 'name\s*:\s"(?P<port_name>[^"]*)"'
|
||||||
|
port = 'ofport\s*:\s(?P<ofport>\d+)'
|
||||||
|
_re = ('%(external)s:\s{ ( %(mac)s,? | %(iface)s,? | . )* }'
|
||||||
|
' \s+ %(name)s \s+ %(port)s' % locals())
|
||||||
|
return re.compile(_re, re.M | re.X)
|
||||||
|
|
||||||
def run_vsctl(self, args):
|
def run_vsctl(self, args):
|
||||||
full_args = ["ovs-vsctl", "--timeout=2"] + args
|
full_args = ["ovs-vsctl", "--timeout=2"] + args
|
||||||
@ -221,8 +233,20 @@ class OVSBridge:
|
|||||||
edge_ports.add(iface_id)
|
edge_ports.add(iface_id)
|
||||||
return edge_ports
|
return edge_ports
|
||||||
|
|
||||||
def get_vif_port(self, port_name):
|
def get_vif_port_by_id(self, port_id):
|
||||||
external_ids = self.db_get_map("Interface", port_name, "external_ids")
|
args = ['--', '--columns=external_ids,name,ofport',
|
||||||
ofport = self.db_get_val("Interface", port_name, "ofport")
|
'find', 'Interface',
|
||||||
return VifPort(port_name, ofport, external_ids["iface-id"],
|
'external_ids:iface-id="%s"' % port_id]
|
||||||
external_ids["attached-mac"], self)
|
result = self.run_vsctl(args)
|
||||||
|
if not result:
|
||||||
|
return
|
||||||
|
match = self.re_id.search(result)
|
||||||
|
try:
|
||||||
|
vif_mac = match.group('vif_mac')
|
||||||
|
vif_id = match.group('vif_id')
|
||||||
|
port_name = match.group('port_name')
|
||||||
|
ofport = int(match.group('ofport'))
|
||||||
|
return VifPort(port_name, ofport, vif_id, vif_mac, self)
|
||||||
|
except Exception, e:
|
||||||
|
LOG.info("Unable to parse regex results. Exception: %s", e)
|
||||||
|
return
|
||||||
|
@ -115,16 +115,17 @@ class OVSRpcCallbacks():
|
|||||||
def port_update(self, context, **kwargs):
|
def port_update(self, context, **kwargs):
|
||||||
LOG.debug("port_update received")
|
LOG.debug("port_update received")
|
||||||
port = kwargs.get('port')
|
port = kwargs.get('port')
|
||||||
port_name = 'tap%s' % port['id'][0:11]
|
vif_port = self.int_br.get_vif_port_by_id(port['id'])
|
||||||
vif_port = self.int_br.get_vif_port(port_name)
|
if vif_port:
|
||||||
if port['admin_state_up']:
|
if port['admin_state_up']:
|
||||||
vlan_id = kwargs.get('vlan_id')
|
vlan_id = kwargs.get('vlan_id')
|
||||||
# create the networking for the port
|
# create the networking for the port
|
||||||
self.int_br.set_db_attribute("Port", vif_port.port_name,
|
self.int_br.set_db_attribute("Port", vif_port.port_name,
|
||||||
"tag", str(vlan_id))
|
"tag", str(vlan_id))
|
||||||
self.int_br.delete_flows(in_port=vif_port.ofport)
|
self.int_br.delete_flows(in_port=vif_port.ofport)
|
||||||
else:
|
else:
|
||||||
self.int_br.clear_db_attribute("Port", vif_port.port_name, "tag")
|
self.int_br.clear_db_attribute("Port", vif_port.port_name,
|
||||||
|
"tag")
|
||||||
|
|
||||||
def tunnel_update(self, context, **kwargs):
|
def tunnel_update(self, context, **kwargs):
|
||||||
LOG.debug("tunnel_update received")
|
LOG.debug("tunnel_update received")
|
||||||
@ -316,12 +317,12 @@ class OVSQuantumAgent(object):
|
|||||||
continue
|
continue
|
||||||
if 'port_id' in details:
|
if 'port_id' in details:
|
||||||
LOG.info("Port %s updated. Details: %s", device, details)
|
LOG.info("Port %s updated. Details: %s", device, details)
|
||||||
port_name = 'tap%s' % details['port_id'][0:11]
|
port = self.int_br.get_vif_port_by_id(details['port_id'])
|
||||||
port = self.int_br.get_vif_port(port_name)
|
if port:
|
||||||
if details['admin_state_up']:
|
if details['admin_state_up']:
|
||||||
self.port_bound(port, details['vlan_id'])
|
self.port_bound(port, details['vlan_id'])
|
||||||
else:
|
else:
|
||||||
self.port_unbound(port, True)
|
self.port_unbound(port, True)
|
||||||
else:
|
else:
|
||||||
LOG.debug("Device %s not defined on plugin", device)
|
LOG.debug("Device %s not defined on plugin", device)
|
||||||
return resync
|
return resync
|
||||||
@ -734,13 +735,13 @@ class OVSQuantumTunnelAgent(object):
|
|||||||
continue
|
continue
|
||||||
if 'port_id' in details:
|
if 'port_id' in details:
|
||||||
LOG.info("Port %s updated. Details: %s", device, details)
|
LOG.info("Port %s updated. Details: %s", device, details)
|
||||||
port_name = 'tap%s' % details['port_id'][0:11]
|
port = self.int_br.get_vif_port_by_id(details['port_id'])
|
||||||
port = self.int_br.get_vif_port(port_name)
|
if port:
|
||||||
if details['admin_state_up']:
|
if details['admin_state_up']:
|
||||||
self.port_bound(port, details['network_id'],
|
self.port_bound(port, details['network_id'],
|
||||||
details['vlan_id'])
|
details['vlan_id'])
|
||||||
else:
|
else:
|
||||||
self.port_unbound(port, details['network_id'])
|
self.port_unbound(port, details['network_id'])
|
||||||
else:
|
else:
|
||||||
LOG.debug("Device %s not defined on plugin", device)
|
LOG.debug("Device %s not defined on plugin", device)
|
||||||
return resync
|
return resync
|
||||||
|
@ -277,3 +277,18 @@ class OVS_Lib_Test(unittest.TestCase):
|
|||||||
self.mox.ReplayAll()
|
self.mox.ReplayAll()
|
||||||
self.br.clear_db_attribute("Port", pname, "tag")
|
self.br.clear_db_attribute("Port", pname, "tag")
|
||||||
self.mox.VerifyAll()
|
self.mox.VerifyAll()
|
||||||
|
|
||||||
|
def test_port_id_regex(self):
|
||||||
|
result = ('external_ids : {attached-mac="fa:16:3e:23:5b:f2",'
|
||||||
|
' iface-id="5c1321a7-c73f-4a77-95e6-9f86402e5c8f",'
|
||||||
|
' iface-status=active}\nname :'
|
||||||
|
' "dhc5c1321a7-c7"\nofport : 2\n')
|
||||||
|
match = self.br.re_id.search(result)
|
||||||
|
vif_mac = match.group('vif_mac')
|
||||||
|
vif_id = match.group('vif_id')
|
||||||
|
port_name = match.group('port_name')
|
||||||
|
ofport = int(match.group('ofport'))
|
||||||
|
self.assertEqual(vif_mac, 'fa:16:3e:23:5b:f2')
|
||||||
|
self.assertEqual(vif_id, '5c1321a7-c73f-4a77-95e6-9f86402e5c8f')
|
||||||
|
self.assertEqual(port_name, 'dhc5c1321a7-c7')
|
||||||
|
self.assertEqual(ofport, 2)
|
||||||
|
Loading…
Reference in New Issue
Block a user