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 /src | |
| 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
Diffstat (limited to 'src')
| -rwxr-xr-x | src/conf_mode/protocols_ospf.py | 6 | ||||
| -rwxr-xr-x | src/conf_mode/protocols_ospfv3.py | 8 | 
2 files changed, 11 insertions, 3 deletions
| 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 | 
