Merge "NSX|V3: use route from nsxlib"

This commit is contained in:
Zuul 2017-10-29 12:06:05 +00:00 committed by Gerrit Code Review
commit ef8577da63

View File

@ -108,7 +108,6 @@ from vmware_nsx.services.trunk.nsx_v3 import driver as trunk_driver
from vmware_nsxlib.v3 import core_resources as nsx_resources from vmware_nsxlib.v3 import core_resources as nsx_resources
from vmware_nsxlib.v3 import exceptions as nsx_lib_exc from vmware_nsxlib.v3 import exceptions as nsx_lib_exc
from vmware_nsxlib.v3 import nsx_constants as nsxlib_consts from vmware_nsxlib.v3 import nsx_constants as nsxlib_consts
from vmware_nsxlib.v3 import router
from vmware_nsxlib.v3 import security from vmware_nsxlib.v3 import security
from vmware_nsxlib.v3 import utils as nsxlib_utils from vmware_nsxlib.v3 import utils as nsxlib_utils
@ -231,9 +230,6 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
self.default_section = self._init_default_section_rules() self.default_section = self._init_default_section_rules()
self._process_security_group_logging() self._process_security_group_logging()
self._routerlib = router.RouterLib(self.nsxlib.logical_router,
self.nsxlib.logical_router_port,
self.nsxlib)
# init profiles on nsx backend # init profiles on nsx backend
self._init_nsx_profiles() self._init_nsx_profiles()
@ -779,7 +775,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
'switch_mode': switch_mode} 'switch_mode': switch_mode}
def _get_edge_cluster(self, tier0_uuid): def _get_edge_cluster(self, tier0_uuid):
self._routerlib.validate_tier0(self.tier0_groups_dict, tier0_uuid) self.nsxlib.router.validate_tier0(self.tier0_groups_dict, tier0_uuid)
tier0_info = self.tier0_groups_dict[tier0_uuid] tier0_info = self.tier0_groups_dict[tier0_uuid]
return tier0_info['edge_cluster_uuid'] return tier0_info['edge_cluster_uuid']
@ -788,7 +784,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
tier0_uuid = self._default_tier0_router tier0_uuid = self._default_tier0_router
else: else:
tier0_uuid = net_data[pnet.PHYSICAL_NETWORK] tier0_uuid = net_data[pnet.PHYSICAL_NETWORK]
self._routerlib.validate_tier0(self.tier0_groups_dict, tier0_uuid) self.nsxlib.router.validate_tier0(self.tier0_groups_dict, tier0_uuid)
return (True, utils.NetworkTypes.L3_EXT, tier0_uuid, 0) return (True, utils.NetworkTypes.L3_EXT, tier0_uuid, 0)
def _create_network_at_the_backend(self, context, net_data, az): def _create_network_at_the_backend(self, context, net_data, az):
@ -3065,19 +3061,20 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
# TODO(berlin): revocate bgp announce on org tier0 router # TODO(berlin): revocate bgp announce on org tier0 router
pass pass
if remove_snat_rules: if remove_snat_rules:
self._routerlib.delete_gw_snat_rules(nsx_router_id, orgaddr) self.nsxlib.router.delete_gw_snat_rules(nsx_router_id, orgaddr)
if remove_router_link_port: if remove_router_link_port:
self._routerlib.remove_router_link_port( self.nsxlib.router.remove_router_link_port(
nsx_router_id, org_tier0_uuid) nsx_router_id, org_tier0_uuid)
if add_router_link_port: if add_router_link_port:
# First update edge cluster info for router # First update edge cluster info for router
edge_cluster_uuid = self._get_edge_cluster(new_tier0_uuid) edge_cluster_uuid = self._get_edge_cluster(new_tier0_uuid)
self._routerlib.update_router_edge_cluster( self.nsxlib.router.update_router_edge_cluster(
nsx_router_id, edge_cluster_uuid) nsx_router_id, edge_cluster_uuid)
tags = self.nsxlib.build_v3_tags_payload( tags = self.nsxlib.build_v3_tags_payload(
router, resource_type='os-neutron-rport', router, resource_type='os-neutron-rport',
project_name=context.tenant_name) project_name=context.tenant_name)
self._routerlib.add_router_link_port(nsx_router_id, new_tier0_uuid, self.nsxlib.router.add_router_link_port(nsx_router_id,
new_tier0_uuid,
tags=tags) tags=tags)
if add_snat_rules: if add_snat_rules:
# Add SNAT rules for all the subnets which are in different scope # Add SNAT rules for all the subnets which are in different scope
@ -3093,7 +3090,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
# TODO(berlin): bgp announce on new tier0 router # TODO(berlin): bgp announce on new tier0 router
pass pass
self._routerlib.update_advertisement(nsx_router_id, self.nsxlib.router.update_advertisement(nsx_router_id,
advertise_route_nat_flag, advertise_route_nat_flag,
advertise_route_connected_flag) advertise_route_connected_flag)
@ -3113,7 +3110,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
'addr_scope': gw_address_scope}) 'addr_scope': gw_address_scope})
return return
self._routerlib.add_gw_snat_rule(nsx_router_id, gw_ip, self.nsxlib.router.add_gw_snat_rule(nsx_router_id, gw_ip,
source_net=subnet['cidr'], source_net=subnet['cidr'],
bypass_firewall=False) bypass_firewall=False)
@ -3295,9 +3292,10 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
nsx_router_id = nsx_db.get_nsx_router_id(context.session, nsx_router_id = nsx_db.get_nsx_router_id(context.session,
router_id) router_id)
for route in routes_removed: for route in routes_removed:
self._routerlib.delete_static_routes(nsx_router_id, route) self.nsxlib.router.delete_static_routes(nsx_router_id,
route)
for route in routes_added: for route in routes_added:
self._routerlib.add_static_routes(nsx_router_id, route) self.nsxlib.router.add_static_routes(nsx_router_id, route)
if 'name' in router_data: if 'name' in router_data:
# Update the name of logical router. # Update the name of logical router.
router_name = router_data['name'] or 'router' router_name = router_data['name'] or 'router'
@ -3346,10 +3344,11 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
router_db['status'] = const.NET_STATUS_ERROR router_db['status'] = const.NET_STATUS_ERROR
if nsx_router_id: if nsx_router_id:
for route in routes_added: for route in routes_added:
self._routerlib.delete_static_routes( self.nsxlib.router.delete_static_routes(
nsx_router_id, route) nsx_router_id, route)
for route in routes_removed: for route in routes_removed:
self._routerlib.add_static_routes(nsx_router_id, route) self.nsxlib.router.add_static_routes(nsx_router_id,
route)
router_db['status'] = curr_status router_db['status'] = curr_status
def update_router_firewall(self, context, router_id): def update_router_firewall(self, context, router_id):
@ -3570,7 +3569,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
net_az = self.get_network_az_by_net_id(context, network_id) net_az = self.get_network_az_by_net_id(context, network_id)
relay_service = net_az.dhcp_relay_service relay_service = net_az.dhcp_relay_service
self._routerlib.create_logical_router_intf_port_by_ls_id( self.nsxlib.router.create_logical_router_intf_port_by_ls_id(
logical_router_id=nsx_router_id, logical_router_id=nsx_router_id,
display_name=display_name, display_name=display_name,
tags=tags, tags=tags,
@ -3674,7 +3673,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
if (router_db.gw_port and router_db.enable_snat and if (router_db.gw_port and router_db.enable_snat and
router_db.gw_port.get('fixed_ips')): router_db.gw_port.get('fixed_ips')):
gw_ip = router_db.gw_port['fixed_ips'][0]['ip_address'] gw_ip = router_db.gw_port['fixed_ips'][0]['ip_address']
self._routerlib.delete_gw_snat_rule_by_source( self.nsxlib.router.delete_gw_snat_rule_by_source(
nsx_router_id, gw_ip, subnet['cidr'], nsx_router_id, gw_ip, subnet['cidr'],
skip_not_found=True) skip_not_found=True)
@ -3755,7 +3754,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
try: try:
nsx_router_id = nsx_db.get_nsx_router_id(context.session, nsx_router_id = nsx_db.get_nsx_router_id(context.session,
router_id) router_id)
self._routerlib.add_fip_nat_rules( self.nsxlib.router.add_fip_nat_rules(
nsx_router_id, new_fip['floating_ip_address'], nsx_router_id, new_fip['floating_ip_address'],
new_fip['fixed_ip_address'], new_fip['fixed_ip_address'],
bypass_firewall=False) bypass_firewall=False)
@ -3783,7 +3782,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
try: try:
nsx_router_id = nsx_db.get_nsx_router_id(context.session, nsx_router_id = nsx_db.get_nsx_router_id(context.session,
router_id) router_id)
self._routerlib.delete_fip_nat_rules( self.nsxlib.router.delete_fip_nat_rules(
nsx_router_id, fip['floating_ip_address'], nsx_router_id, fip['floating_ip_address'],
fip['fixed_ip_address']) fip['fixed_ip_address'])
except nsx_lib_exc.ResourceNotFound: except nsx_lib_exc.ResourceNotFound:
@ -3821,7 +3820,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
try: try:
old_nsx_router_id = nsx_db.get_nsx_router_id( old_nsx_router_id = nsx_db.get_nsx_router_id(
context.session, old_fip['router_id']) context.session, old_fip['router_id'])
self._routerlib.delete_fip_nat_rules( self.nsxlib.router.delete_fip_nat_rules(
old_nsx_router_id, old_fip['floating_ip_address'], old_nsx_router_id, old_fip['floating_ip_address'],
old_fip['fixed_ip_address']) old_fip['fixed_ip_address'])
except nsx_lib_exc.ResourceNotFound: except nsx_lib_exc.ResourceNotFound:
@ -3850,7 +3849,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
if router_id and not is_lb_port: if router_id and not is_lb_port:
nsx_router_id = nsx_db.get_nsx_router_id(context.session, nsx_router_id = nsx_db.get_nsx_router_id(context.session,
router_id) router_id)
self._routerlib.add_fip_nat_rules( self.nsxlib.router.add_fip_nat_rules(
nsx_router_id, new_fip['floating_ip_address'], nsx_router_id, new_fip['floating_ip_address'],
new_fip['fixed_ip_address'], new_fip['fixed_ip_address'],
bypass_firewall=False) bypass_firewall=False)
@ -3875,7 +3874,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
try: try:
nsx_router_id = nsx_db.get_nsx_router_id(context.session, nsx_router_id = nsx_db.get_nsx_router_id(context.session,
fip_db.router_id) fip_db.router_id)
self._routerlib.delete_fip_nat_rules( self.nsxlib.router.delete_fip_nat_rules(
nsx_router_id, fip_db.floating_ip_address, nsx_router_id, fip_db.floating_ip_address,
fip_db.fixed_ip_address) fip_db.fixed_ip_address)
except nsx_lib_exc.ResourceNotFound: except nsx_lib_exc.ResourceNotFound:
@ -4214,7 +4213,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
'subnet': subnet['id']}) 'subnet': subnet['id']})
# Delete rule for this router/subnet pair if it exists # Delete rule for this router/subnet pair if it exists
self._routerlib.delete_gw_snat_rule_by_source( self.nsxlib.router.delete_gw_snat_rule_by_source(
nsx_router_id, ext_addr, subnet['cidr'], nsx_router_id, ext_addr, subnet['cidr'],
skip_not_found=True) skip_not_found=True)
@ -4224,6 +4223,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
"and subnet %(subnet)s", "and subnet %(subnet)s",
{'router': router['id'], {'router': router['id'],
'subnet': subnet['id']}) 'subnet': subnet['id']})
self._routerlib.add_gw_snat_rule(nsx_router_id, ext_addr, self.nsxlib.router.add_gw_snat_rule(
nsx_router_id, ext_addr,
source_net=subnet['cidr'], source_net=subnet['cidr'],
bypass_firewall=False) bypass_firewall=False)