Skip to content

Commit

Permalink
Move FWAAS related object creation into a dedicated method
Browse files Browse the repository at this point in the history
  • Loading branch information
swagner-de committed Mar 18, 2024
1 parent 4278890 commit 9f31e74
Showing 1 changed file with 30 additions and 27 deletions.
57 changes: 30 additions & 27 deletions asr1k_neutron_l3/models/neutron/l3/router.py
Original file line number Diff line number Diff line change
Expand Up @@ -88,33 +88,7 @@ def __init__(self, router_info):
rd=self.router_atts.get('rd'), routable_interface=self.routable_interface,
rt_import=self.rt_import, rt_export=self.rt_export, global_vrf_id=global_vrf_id)

self.fwaas_conf = list()
self.fwaas_external_policies = {'ingress': None, 'egress': None}
for name, policy in router_info.get('fwaas_policies', {}).items():
if self.gateway_interface.id in policy['ingress_ports'] \
or self.gateway_interface.id in policy['egress_ports']:
# This policy will be bound on a external interface, so we need to create
# class-map and service-policy
if self.gateway_interface.id in policy['ingress_ports']:
self.fwaas_external_policies['ingress'] = name
if self.gateway_interface.id in policy['egress_ports']:
self.fwaas_external_policies['egress'] = name
self.fwaas_conf.append(firewall.ClassMap(name))
self.fwaas_conf.append(firewall.ServicePolicy(name))
self.fwaas_conf.append(firewall.AccessList(name, policy['rules']))

if self.fwaas_external_policies['ingress'] or self.fwaas_external_policies['egress']:
# As there are external interfaces policies, we create zones and zone-pairs
self.fwaas_conf.append(firewall.Zone(self.router_id))
self.fwaas_conf.append(
firewall.ZonePairExtEgress(self.router_id, self.fwaas_external_policies['egress']))
self.fwaas_conf.append(
firewall.ZonePairExtIngress(self.router_id, self.fwaas_external_policies['ingress']))
# We also want to link the VRF to a policer so we limit VRFs (by boilerplate)
self.fwaas_conf.append(firewall.FirewallVrfPolicer(self.router_id))
# Mark all interfaces for stateful firewalling
for interface in self.interfaces.all_interfaces:
interface.has_stateful_firewall = True
self._build_fwaas_conf(router_info)

self.nat_acl = self._build_nat_acl()
self.pbr_acl = self._build_pbr_acl()
Expand Down Expand Up @@ -342,6 +316,35 @@ def _build_prefix_lists(self):

return result

def _build_fwaas_conf(self, router_info):
self.fwaas_conf = list()
self.fwaas_external_policies = {'ingress': None, 'egress': None}
for name, policy in router_info.get('fwaas_policies', {}).items():
if self.gateway_interface.id in policy['ingress_ports'] \
or self.gateway_interface.id in policy['egress_ports']:
# This policy will be bound on a external interface, so we need to create
# class-map and service-policy
if self.gateway_interface.id in policy['ingress_ports']:
self.fwaas_external_policies['ingress'] = name
if self.gateway_interface.id in policy['egress_ports']:
self.fwaas_external_policies['egress'] = name
self.fwaas_conf.append(firewall.ClassMap(name))
self.fwaas_conf.append(firewall.ServicePolicy(name))
self.fwaas_conf.append(firewall.AccessList(name, policy['rules']))

if self.fwaas_external_policies['ingress'] or self.fwaas_external_policies['egress']:
# As there are external interfaces policies, we create zones and zone-pairs
self.fwaas_conf.append(firewall.Zone(self.router_id))
self.fwaas_conf.append(
firewall.ZonePairExtEgress(self.router_id, self.fwaas_external_policies['egress']))
self.fwaas_conf.append(
firewall.ZonePairExtIngress(self.router_id, self.fwaas_external_policies['ingress']))
# We also want to link the VRF to a policer so we limit VRFs (by boilerplate)
self.fwaas_conf.append(firewall.FirewallVrfPolicer(self.router_id))
# Mark all interfaces for stateful firewalling
for interface in self.interfaces.all_interfaces:
interface.has_stateful_firewall = True

def _primary_route(self):
if self.gateway_interface is not None and self.gateway_interface.primary_gateway_ip is not None:
return route.Route(self.router_id, "0.0.0.0", "0.0.0.0", self.gateway_interface.primary_gateway_ip)
Expand Down

0 comments on commit 9f31e74

Please sign in to comment.