feat: Add Infrahub Jinja2 transforms for VLANs, interfaces, and VXLAN (#20) #24

Merged
Damien merged 4 commits from feat/infrahub-transforms-vlan-interfaces-vxlan into main 2026-02-28 17:42:09 +00:00
3 changed files with 45 additions and 45 deletions
Showing only changes of commit a415de85bd - Show all commits

View File

@@ -17,9 +17,9 @@
{%- set _ = interfaces.append({ {%- set _ = interfaces.append({
"type": "loopback", "type": "loopback",
"name": iface.name.value, "name": iface.name.value,
"description": iface.description.value, "description": iface.description.value | default(none),
"enabled": iface.enabled.value, "enabled": iface.enabled.value,
"mtu": iface.mtu.value, "mtu": iface.mtu.value | default(none),
"ip_addresses": ip_list "ip_addresses": ip_list
}) -%} }) -%}
{%- endfor -%} {%- endfor -%}
@@ -31,18 +31,18 @@
{%- for ip_edge in iface.ip_addresses.edges -%} {%- for ip_edge in iface.ip_addresses.edges -%}
{%- set _ = ip_list.append(ip_edge.node.address.value) -%} {%- set _ = ip_list.append(ip_edge.node.address.value) -%}
{%- endfor -%} {%- endfor -%}
{%- set lag_name = null -%} {%- set lag_name = none -%}
{%- if iface.lag and iface.lag.node -%} {%- if iface.lag is defined and iface.lag is not none and iface.lag.node is not none -%}
{%- set lag_name = iface.lag.node.name.value -%} {%- set lag_name = iface.lag.node.name.value -%}
{%- endif -%} {%- endif -%}
{%- set _ = interfaces.append({ {%- set _ = interfaces.append({
"type": "ethernet", "type": "ethernet",
"name": iface.name.value, "name": iface.name.value,
"description": iface.description.value, "description": iface.description.value | default(none),
"enabled": iface.enabled.value, "enabled": iface.enabled.value,
"mtu": iface.mtu.value, "mtu": iface.mtu.value | default(none),
"speed": iface.speed.value, "speed": iface.speed.value | default(none),
"mode": iface.mode.value, "mode": iface.mode.value | default(none),
"lag": lag_name, "lag": lag_name,
"ip_addresses": ip_list "ip_addresses": ip_list
}) -%} }) -%}
@@ -55,18 +55,18 @@
{%- for ip_edge in iface.ip_addresses.edges -%} {%- for ip_edge in iface.ip_addresses.edges -%}
{%- set _ = ip_list.append(ip_edge.node.address.value) -%} {%- set _ = ip_list.append(ip_edge.node.address.value) -%}
{%- endfor -%} {%- endfor -%}
{%- set vlan_id = null -%} {%- set vlan_id = none -%}
{%- if iface.vlan and iface.vlan.node -%} {%- if iface.vlan is defined and iface.vlan is not none and iface.vlan.node is not none -%}
{%- set vlan_id = iface.vlan.node.vlan_id.value -%} {%- set vlan_id = iface.vlan.node.vlan_id.value -%}
{%- endif -%} {%- endif -%}
{%- set _ = interfaces.append({ {%- set _ = interfaces.append({
"type": "vlan", "type": "vlan",
"name": iface.name.value, "name": iface.name.value,
"description": iface.description.value, "description": iface.description.value | default(none),
"enabled": iface.enabled.value, "enabled": iface.enabled.value,
"mtu": iface.mtu.value, "mtu": iface.mtu.value | default(none),
"vlan_id": vlan_id, "vlan_id": vlan_id,
"virtual_router_address": iface.virtual_router_address.value, "virtual_router_address": iface.virtual_router_address.value | default(none),
"autostate": iface.autostate.value, "autostate": iface.autostate.value,
"ip_addresses": ip_list "ip_addresses": ip_list
}) -%} }) -%}
@@ -86,11 +86,11 @@
{%- set _ = interfaces.append({ {%- set _ = interfaces.append({
"type": "lag", "type": "lag",
"name": iface.name.value, "name": iface.name.value,
"description": iface.description.value, "description": iface.description.value | default(none),
"enabled": iface.enabled.value, "enabled": iface.enabled.value,
"mtu": iface.mtu.value, "mtu": iface.mtu.value | default(none),
"lacp_mode": iface.lacp_mode.value, "lacp_mode": iface.lacp_mode.value | default(none),
"mlag_id": iface.mlag_id.value, "mlag_id": iface.mlag_id.value | default(none),
"members": member_list, "members": member_list,
"ip_addresses": ip_list "ip_addresses": ip_list
}) -%} }) -%}

View File

@@ -16,18 +16,18 @@
{%- set vlan_node = mapping_edge.node.vlan.node -%} {%- set vlan_node = mapping_edge.node.vlan.node -%}
{%- set vid = vlan_node.vlan_id.value | string -%} {%- set vid = vlan_node.vlan_id.value | string -%}
{%- if vid not in vlans -%} {%- if vid not in vlans -%}
{%- set vni_val = null -%} {%- set vni_val = none -%}
{%- set vni_type_val = null -%} {%- set vni_type_val = none -%}
{%- if vlan_node.vni and vlan_node.vni.node -%} {%- if vlan_node.vni is defined and vlan_node.vni is not none and vlan_node.vni.node is not none -%}
{%- set vni_val = vlan_node.vni.node.vni.value -%} {%- set vni_val = vlan_node.vni.node.vni.value -%}
{%- set vni_type_val = vlan_node.vni.node.vni_type.value -%} {%- set vni_type_val = vlan_node.vni.node.vni_type.value -%}
{%- endif -%} {%- endif -%}
{%- set _ = vlans.update({vid: { {%- set _ = vlans.update({vid: {
"vlan_id": vlan_node.vlan_id.value, "vlan_id": vlan_node.vlan_id.value,
"name": vlan_node.name.value, "name": vlan_node.name.value,
"status": vlan_node.status.value | upper, "status": vlan_node.status.value | default('') | upper,
"vlan_type": vlan_node.vlan_type.value, "vlan_type": vlan_node.vlan_type.value | default(none),
"trunk_groups": vlan_node.trunk_groups.value if vlan_node.trunk_groups.value else [], "trunk_groups": vlan_node.trunk_groups.value | default([]),
"stp_enabled": vlan_node.stp_enabled.value, "stp_enabled": vlan_node.stp_enabled.value,
"vni": vni_val, "vni": vni_val,
"vni_type": vni_type_val "vni_type": vni_type_val
@@ -38,22 +38,22 @@
{#— Collect VLANs from SVI interfaces —#} {#— Collect VLANs from SVI interfaces —#}
{%- for svi_edge in data.InfraInterfaceVlan.edges -%} {%- for svi_edge in data.InfraInterfaceVlan.edges -%}
{%- if svi_edge.node.vlan and svi_edge.node.vlan.node -%} {%- if svi_edge.node.vlan is defined and svi_edge.node.vlan is not none and svi_edge.node.vlan.node is not none -%}
{%- set vlan_node = svi_edge.node.vlan.node -%} {%- set vlan_node = svi_edge.node.vlan.node -%}
{%- set vid = vlan_node.vlan_id.value | string -%} {%- set vid = vlan_node.vlan_id.value | string -%}
{%- if vid not in vlans -%} {%- if vid not in vlans -%}
{%- set vni_val = null -%} {%- set vni_val = none -%}
{%- set vni_type_val = null -%} {%- set vni_type_val = none -%}
{%- if vlan_node.vni and vlan_node.vni.node -%} {%- if vlan_node.vni is defined and vlan_node.vni is not none and vlan_node.vni.node is not none -%}
{%- set vni_val = vlan_node.vni.node.vni.value -%} {%- set vni_val = vlan_node.vni.node.vni.value -%}
{%- set vni_type_val = vlan_node.vni.node.vni_type.value -%} {%- set vni_type_val = vlan_node.vni.node.vni_type.value -%}
{%- endif -%} {%- endif -%}
{%- set _ = vlans.update({vid: { {%- set _ = vlans.update({vid: {
"vlan_id": vlan_node.vlan_id.value, "vlan_id": vlan_node.vlan_id.value,
"name": vlan_node.name.value, "name": vlan_node.name.value,
"status": vlan_node.status.value | upper, "status": vlan_node.status.value | default('') | upper,
"vlan_type": vlan_node.vlan_type.value, "vlan_type": vlan_node.vlan_type.value | default(none),
"trunk_groups": vlan_node.trunk_groups.value if vlan_node.trunk_groups.value else [], "trunk_groups": vlan_node.trunk_groups.value | default([]),
"stp_enabled": vlan_node.stp_enabled.value, "stp_enabled": vlan_node.stp_enabled.value,
"vni": vni_val, "vni": vni_val,
"vni_type": vni_type_val "vni_type": vni_type_val

View File

@@ -10,8 +10,8 @@
{#— Build VTEP section (there is one VTEP per device) —#} {#— Build VTEP section (there is one VTEP per device) —#}
{%- if vtep_edges | length > 0 -%} {%- if vtep_edges | length > 0 -%}
{%- set vtep = vtep_edges[0].node -%} {%- set vtep = vtep_edges[0].node -%}
{%- set source_iface = null -%} {%- set source_iface = none -%}
{%- if vtep.source_interface and vtep.source_interface.node -%} {%- if vtep.source_interface is defined and vtep.source_interface is not none and vtep.source_interface.node is not none -%}
{%- set source_iface = vtep.source_interface.node.name.value -%} {%- set source_iface = vtep.source_interface.node.name.value -%}
{%- endif -%} {%- endif -%}
@@ -19,15 +19,15 @@
{%- set vlan_vni_list = [] -%} {%- set vlan_vni_list = [] -%}
{%- for mapping_edge in vtep.vlan_vni_mappings.edges -%} {%- for mapping_edge in vtep.vlan_vni_mappings.edges -%}
{%- set m = mapping_edge.node -%} {%- set m = mapping_edge.node -%}
{%- set vlan_id = null -%} {%- set vlan_id = none -%}
{%- set vlan_name = null -%} {%- set vlan_name = none -%}
{%- if m.vlan and m.vlan.node -%} {%- if m.vlan is defined and m.vlan is not none and m.vlan.node is not none -%}
{%- set vlan_id = m.vlan.node.vlan_id.value -%} {%- set vlan_id = m.vlan.node.vlan_id.value -%}
{%- set vlan_name = m.vlan.node.name.value -%} {%- set vlan_name = m.vlan.node.name.value -%}
{%- endif -%} {%- endif -%}
{%- set vni_val = null -%} {%- set vni_val = none -%}
{%- set vni_type_val = null -%} {%- set vni_type_val = none -%}
{%- if m.vni and m.vni.node -%} {%- if m.vni is defined and m.vni is not none and m.vni.node is not none -%}
{%- set vni_val = m.vni.node.vni.value -%} {%- set vni_val = m.vni.node.vni.value -%}
{%- set vni_type_val = m.vni.node.vni_type.value -%} {%- set vni_type_val = m.vni.node.vni_type.value -%}
{%- endif -%} {%- endif -%}
@@ -43,14 +43,14 @@
{%- set vrf_vni_list = [] -%} {%- set vrf_vni_list = [] -%}
{%- for vrf_edge in vrf_edges -%} {%- for vrf_edge in vrf_edges -%}
{%- set assignment = vrf_edge.node -%} {%- set assignment = vrf_edge.node -%}
{%- set vrf_name = null -%} {%- set vrf_name = none -%}
{%- set l3vni = null -%} {%- set l3vni = none -%}
{%- set import_rts = [] -%} {%- set import_rts = [] -%}
{%- set export_rts = [] -%} {%- set export_rts = [] -%}
{%- if assignment.vrf and assignment.vrf.node -%} {%- if assignment.vrf is defined and assignment.vrf is not none and assignment.vrf.node is not none -%}
{%- set vrf_node = assignment.vrf.node -%} {%- set vrf_node = assignment.vrf.node -%}
{%- set vrf_name = vrf_node.name.value -%} {%- set vrf_name = vrf_node.name.value -%}
{%- if vrf_node.l3vni and vrf_node.l3vni.node -%} {%- if vrf_node.l3vni is defined and vrf_node.l3vni is not none and vrf_node.l3vni.node is not none -%}
{%- set l3vni = vrf_node.l3vni.node.vni.value -%} {%- set l3vni = vrf_node.l3vni.node.vni.value -%}
{%- endif -%} {%- endif -%}
{%- for rt_edge in vrf_node.import_targets.edges -%} {%- for rt_edge in vrf_node.import_targets.edges -%}
@@ -63,7 +63,7 @@
{%- set _ = vrf_vni_list.append({ {%- set _ = vrf_vni_list.append({
"vrf": vrf_name, "vrf": vrf_name,
"l3vni": l3vni, "l3vni": l3vni,
"route_distinguisher": assignment.route_distinguisher.value, "route_distinguisher": assignment.route_distinguisher.value | default(none),
"import_targets": import_rts, "import_targets": import_rts,
"export_targets": export_rts "export_targets": export_rts
}) -%} }) -%}
@@ -74,14 +74,14 @@
"source_address": vtep.source_address.value, "source_address": vtep.source_address.value,
"source_interface": source_iface, "source_interface": source_iface,
"udp_port": vtep.udp_port.value, "udp_port": vtep.udp_port.value,
"learn_restrict": vtep.learn_restrict.value, "learn_restrict": vtep.learn_restrict.value | default(none),
"vlan_vni_mappings": vlan_vni_list | sort(attribute='vlan_id'), "vlan_vni_mappings": vlan_vni_list | sort(attribute='vlan_id'),
"vrf_vni_mappings": vrf_vni_list "vrf_vni_mappings": vrf_vni_list
} }
} -%} } -%}
{%- else -%} {%- else -%}
{%- set result = { {%- set result = {
"vtep": null, "vtep": none,
"vrf_vni_mappings": [] "vrf_vni_mappings": []
} -%} } -%}
{%- endif -%} {%- endif -%}