Merge "NSX|V3: ensure Mac learning has port security disabled"

This commit is contained in:
Jenkins 2016-09-20 05:55:34 +00:00 committed by Gerrit Code Review
commit b6decdd9be

View File

@ -1648,6 +1648,10 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
sgids |= set(provider_groups) sgids |= set(provider_groups)
self._extend_port_dict_binding(context, port_data) self._extend_port_dict_binding(context, port_data)
if validators.is_attr_set(port_data.get(mac_ext.MAC_LEARNING)): if validators.is_attr_set(port_data.get(mac_ext.MAC_LEARNING)):
if is_psec_on:
msg = _('Mac learning requires that port security be '
'disabled')
raise n_exc.InvalidInput(error_message=msg)
self._create_mac_learning_state(context, port_data) self._create_mac_learning_state(context, port_data)
elif mac_ext.MAC_LEARNING in port_data: elif mac_ext.MAC_LEARNING in port_data:
# This is due to the fact that the default is # This is due to the fact that the default is
@ -1949,7 +1953,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
with context.session.begin(subtransactions=True): with context.session.begin(subtransactions=True):
original_port = super(NsxV3Plugin, self).get_port(context, id) original_port = super(NsxV3Plugin, self).get_port(context, id)
_, nsx_lport_id = nsx_db.get_nsx_switch_and_port_id( nsx_lswitch_id, nsx_lport_id = nsx_db.get_nsx_switch_and_port_id(
context.session, id) context.session, id)
is_external_net = self._network_is_external( is_external_net = self._network_is_external(
context, original_port['network_id']) context, original_port['network_id'])
@ -1987,6 +1991,10 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
new_mac_learning_state = updated_port.get(mac_ext.MAC_LEARNING) new_mac_learning_state = updated_port.get(mac_ext.MAC_LEARNING)
if (new_mac_learning_state is not None and if (new_mac_learning_state is not None and
old_mac_learning_state != new_mac_learning_state): old_mac_learning_state != new_mac_learning_state):
if port_security and new_mac_learning_state:
msg = _('Mac learning requires that port security be '
'disabled')
raise n_exc.InvalidInput(error_message=msg)
self._update_mac_learning_state(context, id, self._update_mac_learning_state(context, id,
new_mac_learning_state) new_mac_learning_state)