From 1b7ff25d56592b114aca6aaf25c8ff820e46ca1d Mon Sep 17 00:00:00 2001 From: Kobi Samoray Date: Tue, 2 Apr 2019 11:01:58 +0300 Subject: [PATCH] NSXP: Use native route advertisement rule API Change-Id: Ia35986c082f4d8daf355a6e535393e4b06c3f707 Depends-On: Iad1011252fd21c87b1b5bd454fd6fb5a8064835d --- .../lbaas/nsx_p/implementation/lb_utils.py | 37 ++++++------------- 1 file changed, 12 insertions(+), 25 deletions(-) diff --git a/vmware_nsx/services/lbaas/nsx_p/implementation/lb_utils.py b/vmware_nsx/services/lbaas/nsx_p/implementation/lb_utils.py index 52a6a7c6a8..0bf8cc6970 100644 --- a/vmware_nsx/services/lbaas/nsx_p/implementation/lb_utils.py +++ b/vmware_nsx/services/lbaas/nsx_p/implementation/lb_utils.py @@ -14,13 +14,12 @@ # under the License. from neutron_lib import exceptions as n_exc -from oslo_config import cfg from oslo_log import helpers as log_helpers from vmware_nsx._i18n import _ from vmware_nsx.services.lbaas import lb_const from vmware_nsx.services.lbaas.nsx_p.implementation import lb_const as p_const -from vmware_nsx.services.lbaas.nsx_v3.implementation import lb_utils +from vmware_nsxlib.v3.policy import constants as p_constants ADV_RULE_NAME = 'LB external VIP advertisement' @@ -122,26 +121,14 @@ def update_router_lb_vip_advertisement(context, core_plugin, router_id): router = core_plugin.get_router(context, router_id) # Add a rule to advertise external vips on the router - - # TODO(kobis): Code below should be executed when platform supports - # - # external_subnets = core_plugin._find_router_gw_subnets( - # context.elevated(), router) - # external_cidrs = [s['cidr'] for s in external_subnets] - # if external_cidrs: - # core_plugin.nsxpolicy.tier1.add_advertisement_rule( - # router_id, - # ADV_RULE_NAME, - # p_constants.ADV_RULE_PERMIT, - # p_constants.ADV_RULE_OPERATOR_GE, - # [p_constants.ADV_RULE_TIER1_LB_VIP], - # external_cidrs) - if cfg.CONF.nsx_p.allow_passthrough: - lb_utils.update_router_lb_vip_advertisement( - context, core_plugin, router, - core_plugin.nsxpolicy.tier1.get_realized_id( - router_id, entity_type='RealizedLogicalRouter')) - else: - msg = (_('Failed to set loadbalancer advertisement rule for router %s') - % router_id) - raise n_exc.BadRequest(resource='lbaas-loadbalancer', msg=msg) + external_subnets = core_plugin._find_router_gw_subnets( + context.elevated(), router) + external_cidrs = [s['cidr'] for s in external_subnets] + if external_cidrs: + core_plugin.nsxpolicy.tier1.add_advertisement_rule( + router_id, + ADV_RULE_NAME, + p_constants.ADV_RULE_PERMIT, + p_constants.ADV_RULE_OPERATOR_GE, + [p_constants.ADV_RULE_TIER1_LB_VIP], + external_cidrs)