diff options
| author | Christian Breunig <christian@breunig.cc> | 2024-03-02 11:00:12 +0100 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-03-02 11:00:12 +0100 | 
| commit | 70cf2388a184eacc6fb52d9edfb1c930de3bbb6a (patch) | |
| tree | b6f57e021e95e3dd7cc1912498ce11cdac5e0909 | |
| parent | ce25bc49dd6b28fb80c85ec2dbe37c8ac6c11217 (diff) | |
| parent | 298bcc5cb90c4c83981ec4baaaa0db785306867d (diff) | |
| download | vyos-1x-70cf2388a184eacc6fb52d9edfb1c930de3bbb6a.tar.gz vyos-1x-70cf2388a184eacc6fb52d9edfb1c930de3bbb6a.zip | |
Merge pull request #3073 from c-po/ospfv3-redistribution-T5717
ospfv3: allow metric and metric-type on redistributed routes
| -rw-r--r-- | data/templates/frr/ospf6d.frr.j2 | 2 | ||||
| -rw-r--r-- | data/templates/frr/ospfd.frr.j2 | 8 | ||||
| -rw-r--r-- | interface-definitions/include/ospfv3/protocol-common-config.xml.i | 28 | ||||
| -rwxr-xr-x | smoketest/scripts/cli/test_protocols_ospfv3.py | 8 | ||||
| -rwxr-xr-x | src/conf_mode/protocols_ospf.py | 6 | ||||
| -rwxr-xr-x | src/conf_mode/protocols_ospfv3.py | 8 | 
6 files changed, 42 insertions, 18 deletions
| diff --git a/data/templates/frr/ospf6d.frr.j2 b/data/templates/frr/ospf6d.frr.j2 index b0b5663dd..5f758f9e5 100644 --- a/data/templates/frr/ospf6d.frr.j2 +++ b/data/templates/frr/ospf6d.frr.j2 @@ -109,7 +109,7 @@ router ospf6 {{ 'vrf ' ~ vrf if vrf is vyos_defined }}  {% endif %}  {% if redistribute is vyos_defined %}  {%     for protocol, options in redistribute.items() %} - redistribute {{ protocol }} {{ 'route-map ' ~ options.route_map if options.route_map is vyos_defined }} + redistribute {{ protocol }} {{ 'metric ' ~ options.metric if options.metric is vyos_defined }} {{ 'metric-type ' ~ options.metric_type if options.metric_type is vyos_defined }} {{ 'route-map ' ~ options.route_map if options.route_map is vyos_defined }}  {%     endfor %}  {% endif %}  exit diff --git a/data/templates/frr/ospfd.frr.j2 b/data/templates/frr/ospfd.frr.j2 index 040628e82..ab074b6a2 100644 --- a/data/templates/frr/ospfd.frr.j2 +++ b/data/templates/frr/ospfd.frr.j2 @@ -214,13 +214,13 @@ router ospf {{ 'vrf ' ~ vrf if vrf is vyos_defined }}   passive-interface default  {% endif %}  {% if redistribute is vyos_defined %} -{%     for protocol, protocols_options in redistribute.items() %} +{%     for protocol, options in redistribute.items() %}  {%         if protocol == 'table' %} -{%             for table, table_options in protocols_options.items() %} - redistribute {{ protocol }} {{ table }} {{ 'metric ' + table_options.metric if table_options.metric is vyos_defined }} {{ 'metric-type ' + table_options.metric_type if table_options.metric_type is vyos_defined }} {{ 'route-map ' + table_options.route_map if table_options.route_map is vyos_defined }} +{%             for table, table_options in options.items() %} + redistribute {{ protocol }} {{ table }} {{ 'metric ' ~ table_options.metric if table_options.metric is vyos_defined }} {{ 'metric-type ' ~ table_options.metric_type if table_options.metric_type is vyos_defined }} {{ 'route-map ' ~ table_options.route_map if table_options.route_map is vyos_defined }}  {%             endfor %}  {%         else %} - redistribute {{ protocol }} {{ 'metric ' + protocols_options.metric if protocols_options.metric is vyos_defined }} {{ 'metric-type ' + protocols_options.metric_type if protocols_options.metric_type is vyos_defined }} {{ 'route-map ' + protocols_options.route_map if protocols_options.route_map is vyos_defined }} + redistribute {{ protocol }} {{ 'metric ' ~ options.metric if options.metric is vyos_defined }} {{ 'metric-type ' ~ options.metric_type if options.metric_type is vyos_defined }} {{ 'route-map ' ~ options.route_map if options.route_map is vyos_defined }}  {%         endif %}  {%     endfor %}  {% endif %} diff --git a/interface-definitions/include/ospfv3/protocol-common-config.xml.i b/interface-definitions/include/ospfv3/protocol-common-config.xml.i index 4c3ca68e1..1462b9c15 100644 --- a/interface-definitions/include/ospfv3/protocol-common-config.xml.i +++ b/interface-definitions/include/ospfv3/protocol-common-config.xml.i @@ -221,11 +221,23 @@      <help>Redistribute information from another routing protocol</help>    </properties>    <children> +    <node name="babel"> +      <properties> +        <help>Redistribute Babel routes</help> +      </properties> +      <children> +        #include <include/ospf/metric.xml.i> +        #include <include/ospf/metric-type.xml.i> +        #include <include/route-map.xml.i> +      </children> +    </node>      <node name="bgp">        <properties>          <help>Redistribute BGP routes</help>        </properties>        <children> +        #include <include/ospf/metric.xml.i> +        #include <include/ospf/metric-type.xml.i>          #include <include/route-map.xml.i>        </children>      </node> @@ -234,6 +246,8 @@          <help>Redistribute connected routes</help>        </properties>        <children> +        #include <include/ospf/metric.xml.i> +        #include <include/ospf/metric-type.xml.i>          #include <include/route-map.xml.i>        </children>      </node> @@ -242,6 +256,8 @@          <help>Redistribute kernel routes</help>        </properties>        <children> +        #include <include/ospf/metric.xml.i> +        #include <include/ospf/metric-type.xml.i>          #include <include/route-map.xml.i>        </children>      </node> @@ -250,14 +266,8 @@          <help>Redistribute RIPNG routes</help>        </properties>        <children> -        #include <include/route-map.xml.i> -      </children> -    </node> -    <node name="babel"> -      <properties> -        <help>Redistribute Babel routes</help> -      </properties> -      <children> +        #include <include/ospf/metric.xml.i> +        #include <include/ospf/metric-type.xml.i>          #include <include/route-map.xml.i>        </children>      </node> @@ -266,6 +276,8 @@          <help>Redistribute static routes</help>        </properties>        <children> +        #include <include/ospf/metric.xml.i> +        #include <include/ospf/metric-type.xml.i>          #include <include/route-map.xml.i>        </children>      </node> diff --git a/smoketest/scripts/cli/test_protocols_ospfv3.py b/smoketest/scripts/cli/test_protocols_ospfv3.py index 4ae7f05d9..a9894009d 100755 --- a/smoketest/scripts/cli/test_protocols_ospfv3.py +++ b/smoketest/scripts/cli/test_protocols_ospfv3.py @@ -1,6 +1,6 @@  #!/usr/bin/env python3  # -# Copyright (C) 2021-2023 VyOS maintainers and contributors +# Copyright (C) 2021-2024 VyOS maintainers and contributors  #  # This program is free software; you can redistribute it and/or modify  # it under the terms of the GNU General Public License version 2 or later as @@ -114,6 +114,8 @@ class TestProtocolsOSPFv3(VyOSUnitTestSHIM.TestCase):      def test_ospfv3_03_redistribute(self): +        metric = '15' +        metric_type = '1'          route_map = 'foo-bar'          route_map_seq = '10'          redistribute = ['bgp', 'connected', 'kernel', 'ripng', 'static'] @@ -121,7 +123,9 @@ class TestProtocolsOSPFv3(VyOSUnitTestSHIM.TestCase):          self.cli_set(['policy', 'route-map', route_map, 'rule', route_map_seq, 'action', 'permit'])          for protocol in redistribute: +            self.cli_set(base_path + ['redistribute', protocol, 'metric', metric])              self.cli_set(base_path + ['redistribute', protocol, 'route-map', route_map]) +            self.cli_set(base_path + ['redistribute', protocol, 'metric-type', metric_type])          # commit changes          self.cli_commit() @@ -130,7 +134,7 @@ class TestProtocolsOSPFv3(VyOSUnitTestSHIM.TestCase):          frrconfig = self.getFRRconfig('router ospf6', daemon=PROCESS_NAME)          self.assertIn(f'router ospf6', frrconfig)          for protocol in redistribute: -            self.assertIn(f' redistribute {protocol} route-map {route_map}', frrconfig) +            self.assertIn(f' redistribute {protocol} metric {metric} metric-type {metric_type} route-map {route_map}', frrconfig)      def test_ospfv3_04_interfaces(self): diff --git a/src/conf_mode/protocols_ospf.py b/src/conf_mode/protocols_ospf.py index 34cf49286..695842795 100755 --- a/src/conf_mode/protocols_ospf.py +++ b/src/conf_mode/protocols_ospf.py @@ -1,6 +1,6 @@  #!/usr/bin/env python3  # -# Copyright (C) 2021-2023 VyOS maintainers and contributors +# Copyright (C) 2021-2024 VyOS maintainers and contributors  #  # This program is free software; you can redistribute it and/or modify  # it under the terms of the GNU General Public License version 2 or later as @@ -91,6 +91,8 @@ def get_config(config=None):      for protocol in ['babel', 'bgp', 'connected', 'isis', 'kernel', 'rip', 'static']:          if dict_search(f'redistribute.{protocol}', ospf) is None:              del default_values['redistribute'][protocol] +    if not bool(default_values['redistribute']): +        del default_values['redistribute']      for interface in ospf.get('interface', []):          # We need to reload the defaults on every pass b/c of @@ -213,7 +215,7 @@ def verify(ospf):                      raise ConfigError(f'Segment routing prefix {prefix} cannot have both explicit-null '\                                        f'and no-php-flag configured at the same time.') -    # Check for index ranges being larger than the segment routing global block     +    # Check for index ranges being larger than the segment routing global block      if dict_search('segment_routing.global_block', ospf):          g_high_label_value = dict_search('segment_routing.global_block.high_label_value', ospf)          g_low_label_value = dict_search('segment_routing.global_block.low_label_value', ospf) diff --git a/src/conf_mode/protocols_ospfv3.py b/src/conf_mode/protocols_ospfv3.py index 5b1adce30..2c1cbfecd 100755 --- a/src/conf_mode/protocols_ospfv3.py +++ b/src/conf_mode/protocols_ospfv3.py @@ -1,6 +1,6 @@  #!/usr/bin/env python3  # -# Copyright (C) 2021-2023 VyOS maintainers and contributors +# Copyright (C) 2021-2024 VyOS maintainers and contributors  #  # This program is free software; you can redistribute it and/or modify  # it under the terms of the GNU General Public License version 2 or later as @@ -85,6 +85,12 @@ def get_config(config=None):      if 'graceful_restart' not in ospfv3:          del default_values['graceful_restart'] +    for protocol in ['babel', 'bgp', 'connected', 'kernel', 'ripng', 'static']: +        if dict_search(f'redistribute.{protocol}', ospfv3) is None: +            del default_values['redistribute'][protocol] +    if not bool(default_values['redistribute']): +        del default_values['redistribute'] +      default_values.pop('interface', {})      # merge in remaining default values | 
