feat: Add Infrahub Jinja2 transform for BGP configuration (#23) #27
Reference in New Issue
Block a user
Delete Branch "feat/infrahub-transforms-bgp"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Summary
Closes #23. Implements a single unified
bgp_yang_transformcovering the complete BGP router stanza for all 10 fabric devices.Design decision: One transform (one query + one template) rather than 4 separate transforms, because all BGP components (process config, peer groups, neighbors, AFs) live under a single
router bgp <ASN>stanza and must be consistent. This avoids multiple API calls per device and keeps the data model coherent.infrahub/transforms/queries/bgp_intent.gqlInfraBGPRouterConfig(with peer_groups, sessions) +InfraBGPAddressFamily(with active_peer_groups, active_sessions, networks, optional vrf)infrahub/transforms/templates/bgp_yang.j2bgp.global,bgp.peer_groups,bgp.neighbors,bgp.address_families,bgp.vrf_neighbors,bgp.vrf_address_families; returns[]for devices with no BGP configinfrahub/transforms/tests/bgp_yang/test.ymlinfrahub/transforms/tests/bgp_yang/leaf1/infrahub/transforms/tests/bgp_yang/spine1/infrahub/transforms/tests/bgp_yang/leaf7/.infrahub.ymlbgp_intentquery andbgp_yang_transformValidation
leaf1spine1remote_asn, 8 EVPN via peer-group), IPv4 AF activates individual sessionsleaf7vrf_neighbors: [{10.90.90.1, AS 64999, VRF gold}]+vrf_address_families: [{ipv4, VRF gold, active_sessions: [10.90.90.1]}]Design notes
remote_asn,peer_group,vrf,peer_device,update_source, etc.) wrapped inis defined and is not noneguardssend_communityvalue"none"(schema default) is normalised tonullin the output — keeps the rendered JSON clean for downstream consumersvrf_neighbors/vrf_address_familiesarrays, each entry carrying a"vrf"key, so the template consumer can trivially iterate per-VRF without filtering🤖 Generated with Claude Code
Single unified bgp_yang_transform covering the full BGP router stanza (process config, peer groups, neighbors, address families) for all 10 fabric devices in a single query+template pass. - Add GraphQL query bgp_intent.gql: queries InfraBGPRouterConfig by device name, traversing local_asn, peer_groups (with remote_asn), and sessions (with peer_group, remote_asn, vrf, peer_device); separately queries InfraBGPAddressFamily for the same device, including active_peer_groups, active_sessions, networks, and optional vrf relationship - Add Jinja2 template bgp_yang.j2: renders a JSON object with bgp.global (ASN, router-id, distances, ECMP), bgp.peer_groups, bgp.neighbors, bgp.address_families for global sessions, plus bgp.vrf_neighbors and bgp.vrf_address_families for VRF-scoped entries (e.g. leaf7 VRF gold border peering); returns [] for devices with no BGP config; all optional relationships guarded with 'is defined and is not none' checks; send_community "none" normalised to null in output - Update .infrahub.yml: register bgp_intent query and bgp_yang_transform - Add unit test fixtures for three representative devices: leaf1 — 3 peer-groups, 5 global neighbors, 2 global AFs spine1 — 1 peer-group (evpn/next-hop-unchanged), 16 neighbors (8 direct underlay with remote_asn, 8 EVPN via peer-group), IPv4 AF activates individual sessions leaf7 — leaf1 pattern + VRF gold border session (AS 64999) and VRF-scoped IPv4 unicast AF Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>