Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

VyOS v1.4 support for BGP (T6892 & T6888 & T6822) #367

Merged
merged 38 commits into from
Dec 19, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
38 commits
Select commit Hold shift + click to select a range
af91688
VyOS v1.4 support for BGP (T6892)
omnom62 Nov 28, 2024
c10b03a
WIP: chnages to scanners and facts for BGP on v1.4
omnom62 Nov 30, 2024
4e83507
scanners and facts modification to support as_numberless commands
omnom62 Dec 1, 2024
89c469f
remove optional regex groups
omnom62 Dec 1, 2024
bdf9104
VyOS v1.4 BGP system-as functionality
omnom62 Dec 1, 2024
68b9c33
bgp_af linter
omnom62 Dec 1, 2024
dc8dbbc
bgp_global mods and testing
omnom62 Dec 2, 2024
dc41dd2
bgp_global v.1.4 support
omnom62 Dec 2, 2024
6bf61fa
linter fixes
omnom62 Dec 2, 2024
c676bb1
bgp_global and bgp_af fixed 1.3 test cases
omnom62 Dec 3, 2024
f9645bd
unit tests for bgp modules for both versions
omnom62 Dec 3, 2024
ffc9533
obsolete stranzas removed from bgp_global for both versions
omnom62 Dec 3, 2024
e71c031
some typos removed
omnom62 Dec 4, 2024
9d1c0c4
bgp_global rst updates
omnom62 Dec 4, 2024
d12f92a
t6829 related draft changes
omnom62 Dec 5, 2024
730f22e
Draft changes to unit tests fot original set and t6888 updates
omnom62 Dec 5, 2024
08a3e41
changelog
omnom62 Dec 5, 2024
2d4aaac
D.R.Y for bgp_global and testmodule names
omnom62 Dec 6, 2024
0715d68
linter fixes
omnom62 Dec 6, 2024
c0a388c
fixtures for bgp_af options testts
omnom62 Dec 8, 2024
b2821bf
stranzas options processing
omnom62 Dec 11, 2024
d10dff4
T6888 bgp option test func and cases
omnom62 Dec 11, 2024
b51f014
clean-up draft code and update to rm_templates
omnom62 Dec 11, 2024
b92a8ef
v14 system-as change supported in conf and tests
omnom62 Dec 11, 2024
c777efd
T6822 BGP global passive bugfix
omnom62 Dec 13, 2024
61785d4
clean-up
omnom62 Dec 13, 2024
b37c770
T6829: update integration tests
gaige Dec 15, 2024
1d0a98d
T6829: fix integration tests for global
gaige Dec 15, 2024
c969dbd
T6829: fix integration tests for bgp_global
gaige Dec 15, 2024
08ef2a3
T6829: fix for 1.4 AF integration tests
gaige Dec 15, 2024
4dad478
T6829: fix unit tests after removing obsolete items
gaige Dec 15, 2024
40bba69
T6829: fix sanity test failures
gaige Dec 15, 2024
46a8323
T6829: fix documentation
gaige Dec 15, 2024
0f2fb47
Lint and comments are addressed
omnom62 Dec 16, 2024
dedeffd
rtt.yaml and fix to integration tests
omnom62 Dec 16, 2024
f7d9875
updated fragments for bgp_global
omnom62 Dec 16, 2024
07af8a8
lint fixes
omnom62 Dec 16, 2024
8f2b653
Merge branch 'main' into bgp_af_rework_t6829
omnom62 Dec 19, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 12 additions & 0 deletions changelogs/fragments/bgp_address_family.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
---
major_changes:
- Aligned with version 1.3+ configuration - aggregate_address, maximum_paths, network, and redistribute
moved from `bgp_global` module. These are now Address-family specific.
- Many neighbor attributes also moved from `bgp_global` to `bgp_address_family` module.
- Redistribute, network stanza - added support for modifiers (metric, backdoor etc as per T6829)
- Support for 1.3+ VyOS only

minor_changes:
- as_number - Added support for 1.4+ "system-as. 1.3 embedded as_number is still supported"
- fix tests for 1.4+ bgp_address_family
- updated documentation
10 changes: 10 additions & 0 deletions changelogs/fragments/bgp_global.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
---
minor_changes:
- Added support for `solo` neighbor attribute
- as_number - Added support for 1.4+ "system-as. 1.3 embedded as_number is still supported"
- Fixed tests for 1.4+ bgp_global
- updated documentation
- Aligned with version 1.3+ configuration - aggregate_address, maximum_paths, network, and redistribute
Removed to `bgp_address_family` module.
- Many configuration attributes moved from `bgp_global` to `bgp_address_family` module.
- Support for 1.3+ VyOS only
1 change: 1 addition & 0 deletions docs/vyos.vyos.vyos_bgp_address_family_module.rst
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ Version added: 1.0.0
Synopsis
--------
- This module manages BGP address family configuration of interfaces on devices running VYOS.
- Tested against VYOS 1.3, 1.4



Expand Down
913 changes: 72 additions & 841 deletions docs/vyos.vyos.vyos_bgp_global_module.rst

Large diffs are not rendered by default.

113 changes: 4 additions & 109 deletions plugins/module_utils/network/vyos/argspec/bgp_global/bgp_global.py
Original file line number Diff line number Diff line change
Expand Up @@ -36,44 +36,17 @@ class Bgp_globalArgs(object): # pylint: disable=R0903
"type": "dict",
"options": {
"as_number": {"type": "int"},
"aggregate_address": {
"type": "list",
"elements": "dict",
"options": {
"prefix": {"type": "str"},
"as_set": {"type": "bool"},
"summary_only": {"type": "bool"},
},
},
omnom62 marked this conversation as resolved.
Show resolved Hide resolved
"maximum_paths": {
"type": "list",
"elements": "dict",
"options": {"path": {"type": "str"}, "count": {"type": "int"}},
},
"neighbor": {
"type": "list",
"elements": "dict",
"options": {
"address": {"type": "str"},
"advertisement_interval": {"type": "int"},
"allowas_in": {"type": "int"},
"as_override": {"type": "bool"},
"attribute_unchanged": {
"type": "dict",
"options": {
"as_path": {"type": "bool"},
"med": {"type": "bool"},
"next_hop": {"type": "bool"},
},
},
"capability": {
"type": "dict",
"options": {
"dynamic": {"type": "bool"},
"orf": {
"type": "str",
"choices": ["send", "receive"],
},
"extended_nexthop": {"type": "bool"},
},
},
"default_originate": {"type": "str"},
Expand All @@ -84,71 +57,18 @@ class Bgp_globalArgs(object): # pylint: disable=R0903
"type": "str",
"choices": ["extended", "standard"],
},
"distribute_list": {
"type": "list",
"elements": "dict",
"options": {
"action": {
"type": "str",
"choices": ["export", "import"],
},
"acl": {"type": "int"},
},
},
"ebgp_multihop": {"type": "int"},
"filter_list": {
"type": "list",
"elements": "dict",
"options": {
"action": {
"type": "str",
"choices": ["export", "import"],
},
"path_list": {"type": "str"},
},
},
"local_as": {"type": "int"},
"maximum_prefix": {"type": "int"},
"nexthop_self": {"type": "bool"},
"override_capability": {"type": "bool"},
"passive": {"type": "bool"},
"password": {"type": "str", "no_log": True},
"peer_group_name": {"type": "str"},
"peer_group": {"type": "bool"},
"port": {"type": "int"},
"prefix_list": {
"type": "list",
"elements": "dict",
"options": {
"action": {
"type": "str",
"choices": ["export", "import"],
},
"prefix_list": {"type": "str"},
},
},
"remote_as": {"type": "int"},
"remove_private_as": {"type": "bool"},
"route_map": {
"type": "list",
"elements": "dict",
"options": {
"action": {
"type": "str",
"choices": ["export", "import"],
},
"route_map": {"type": "str"},
},
},
"route_reflector_client": {"type": "bool"},
"route_server_client": {"type": "bool"},
"solo": {"type": "bool"},
"shutdown": {"type": "bool"},
"soft_reconfiguration": {"type": "bool"},
"strict_capability_match": {"type": "bool"},
"unsuppress_map": {"type": "str"},
"update_source": {"type": "str"},
"weight": {"type": "int"},
"ttl_security": {"type": "int"},
"timers": {
"type": "dict",
"options": {
Expand All @@ -157,33 +77,8 @@ class Bgp_globalArgs(object): # pylint: disable=R0903
"keepalive": {"type": "int"},
},
},
},
},
"network": {
"type": "list",
"elements": "dict",
"options": {
"address": {"type": "str"},
"backdoor": {"type": "bool"},
"route_map": {"type": "str"},
},
},
"redistribute": {
"type": "list",
"elements": "dict",
"options": {
"protocol": {
"type": "str",
"choices": [
"connected",
"kernel",
"ospf",
"rip",
"static",
],
},
"route_map": {"type": "str"},
"metric": {"type": "int"},
"ttl_security": {"type": "int"},
"update_source": {"type": "str"},
},
},
"timers": {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,14 @@
Bgp_address_familyTemplate,
)

from ansible_collections.vyos.vyos.plugins.module_utils.network.vyos.rm_templates.bgp_address_family_14 import (
Bgp_address_familyTemplate14,
)

from ansible_collections.vyos.vyos.plugins.module_utils.network.vyos.vyos import get_os_version

from ansible_collections.vyos.vyos.plugins.module_utils.network.vyos.utils.version import LooseVersion


class Bgp_address_family(ResourceModule):
"""
Expand All @@ -49,12 +57,30 @@ def __init__(self, module):
)
self.parsers = []

def _validate_template(self):
version = get_os_version(self._module)
if LooseVersion(version) >= LooseVersion("1.4"):
self._tmplt = Bgp_address_familyTemplate14()
else:
self._tmplt = Bgp_address_familyTemplate()

def parse(self):
""" override parse to check template """
self._validate_template()
return super().parse()

def get_parser(self, name):
"""get_parsers"""
self._validate_template()
return super().get_parser(name)

def execute_module(self):
"""Execute the module

:rtype: A dictionary
:returns: The result from module execution
"""
self._validate_template()
if self.state not in ["parsed", "gathered"]:
self.generate_commands()
self.run_commands()
Expand All @@ -67,7 +93,9 @@ def generate_commands(self):
wantd = {}
haved = {}

if self.want.get("as_number") == self.have.get("as_number") or not self.have:
if (self.want.get("as_number") == self.have.get("as_number") or
not self.have or
LooseVersion(get_os_version(self._module)) >= LooseVersion("1.4")):
if self.want:
wantd = {self.want["as_number"]: self.want}
if self.have:
Expand Down Expand Up @@ -103,6 +131,9 @@ def _compare(self, want, have):
the `want` and `have` data with the `parsers` defined
for the Bgp_address_family network resource.
"""
if LooseVersion(get_os_version(self._module)) >= LooseVersion("1.4"):
omnom62 marked this conversation as resolved.
Show resolved Hide resolved
self._compare_asn(want, have)

self._compare_af(want, have)
self._compare_neighbors(want, have)
# Do the negation first
Expand Down Expand Up @@ -268,13 +299,21 @@ def _compare_neighbors(self, want, have):
def _compare_lists(self, want, have, as_number, afi):
parsers = [
"aggregate_address",
"network",
"network.backdoor",
"network.path_limit",
"network.route_map",
"redistribute",
"redistribute.metric",
"redistribute.route_map",
"redistribute.table",
]

if LooseVersion(get_os_version(self._module)) >= LooseVersion("1.4"):
delete_asn = ""
else:
delete_asn = " " + str(as_number)

for attrib in ["redistribute", "networks", "aggregate_address"]:
wdict = want.pop(attrib, {})
hdict = have.pop(attrib, {})
Expand All @@ -300,8 +339,8 @@ def _compare_lists(self, want, have, as_number, afi):
attrib = re.sub("_", "-", attrib)
attrib = re.sub("networks", "network", attrib)
self.commands.append(
"delete protocols bgp "
+ str(as_number)
"delete protocols bgp"
+ delete_asn
+ " "
+ "address-family "
+ afi
Expand All @@ -318,6 +357,19 @@ def _compare_lists(self, want, have, as_number, afi):
"address_family": {"afi": afi, attrib: entry},
},
)
# de-duplicate child commands if parent command is present
for val in (self.commands):
for val2 in self.commands:
if val != val2 and val2.startswith(val):
self.commands.remove(val2)

def _compare_asn(self, want, have):
if want.get("as_number") and not have.get("as_number"):
self.commands.append(
"set protocols bgp "
+ "system-as "
+ str(want.get("as_number")),
)

def _bgp_af_list_to_dict(self, entry):
for name, proc in iteritems(entry):
Expand Down
Loading
Loading