|
| 1 | +--- |
| 2 | +# source: multi-namespace/network-values2/values.yaml.j2 |
| 3 | +{% set _ipv = cifmw_ci_gen_kustomize_values_ip_version_var_mapping %} |
| 4 | +{% set ns = namespace(interfaces={}, |
| 5 | + ocp_index=0, |
| 6 | + lb_tools={}) %} |
| 7 | +data: |
| 8 | +{% for host in cifmw_networking_env_definition.instances.keys() -%} |
| 9 | +{% if host is match('^(ocp|crc).*') %} |
| 10 | + node_{{ ns.ocp_index }}: |
| 11 | +{% set ns.ocp_index = ns.ocp_index+1 %} |
| 12 | + name: {{ cifmw_networking_env_definition.instances[host]['hostname'] }} |
| 13 | +{% for network in cifmw_networking_env_definition.instances[host]['networks'].values() %} |
| 14 | +{% set ns.interfaces = ns.interfaces | |
| 15 | + combine({network.network_name: (network.parent_interface | |
| 16 | + default(network.interface_name) |
| 17 | + ) |
| 18 | + }, |
| 19 | + recursive=true) %} |
| 20 | +{% if "2" in network.network_name %} |
| 21 | + {{ network.network_name | replace("2", "") }}_ip: {{ network[_ipv.ip_vX] }} |
| 22 | +{% endif %} |
| 23 | +{% endfor %} |
| 24 | +{% endif %} |
| 25 | +{% endfor %} |
| 26 | + |
| 27 | +{% for network in cifmw_networking_env_definition.networks.values() if "2" in network %} |
| 28 | +{% set ns.lb_tools = {} %} |
| 29 | + {{ network.network_name | replace("2", "") }}: |
| 30 | + dnsDomain: {{ network.search_domain }} |
| 31 | +{% if network.tools is defined and network.tools.keys() | length > 0 %} |
| 32 | + subnets: |
| 33 | +{% for tool in network.tools.keys() %} |
| 34 | +{% if tool is match('.*lb$') %} |
| 35 | +{% set _ = ns.lb_tools.update({tool: []}) %} |
| 36 | +{% endif %} |
| 37 | +{% endfor %} |
| 38 | + - allocationRanges: |
| 39 | +{% for range in network.tools.netconfig[_ipv.ipvX_ranges] %} |
| 40 | + - end: {{ range.end }} |
| 41 | + start: {{ range.start }} |
| 42 | +{% endfor %} |
| 43 | + cidr: {{ network[_ipv.network_vX] }} |
| 44 | +{% if network[_ipv.gw_vX] is defined %} |
| 45 | + gateway: {{ network[_ipv.gw_vX] }} |
| 46 | +{% endif %} |
| 47 | + name: subnet1 |
| 48 | +{% if network.vlan_id is defined %} |
| 49 | + vlan: {{ network.vlan_id }} |
| 50 | +{% endif %} |
| 51 | +{% if ns.lb_tools | length > 0 %} |
| 52 | + lb_addresses: |
| 53 | +{% for tool in ns.lb_tools.keys() %} |
| 54 | +{% for lb_range in network.tools[tool][_ipv.ipvX_ranges] %} |
| 55 | + - {{ lb_range.start }}-{{ lb_range.end }} |
| 56 | +{% set _ = ns.lb_tools[tool].append(lb_range.start) %} |
| 57 | +{% endfor %} |
| 58 | + endpoint_annotations: |
| 59 | + {{ tool }}.universe.tf/address-pool: {{ network.network_name }} |
| 60 | + {{ tool }}.universe.tf/allow-shared-ip: {{ network.network_name }} |
| 61 | + {{ tool }}.universe.tf/loadBalancerIPs: {{ ','.join(ns.lb_tools[tool]) }} |
| 62 | +{% endfor %} |
| 63 | +{% endif %} |
| 64 | +{% endif %} |
| 65 | + prefix-length: {{ network[_ipv.network_vX] | ansible.utils.ipaddr('prefix') }} |
| 66 | + mtu: {{ network.mtu | default(1500) }} |
| 67 | +{% if network.vlan_id is defined %} |
| 68 | + vlan: {{ network.vlan_id }} |
| 69 | +{% if ns.interfaces[network.network_name] is defined %} |
| 70 | + iface: {{ network.network_name }} |
| 71 | + base_iface: {{ ns.interfaces[network.network_name] }} |
| 72 | +{% endif %} |
| 73 | +{% else %} |
| 74 | +{% if ns.interfaces[network.network_name] is defined %} |
| 75 | + iface: {{ ns.interfaces[network.network_name] }} |
| 76 | +{% endif %} |
| 77 | +{% endif %} |
| 78 | +{% if network.tools.multus is defined %} |
| 79 | + net-attach-def: | |
| 80 | + { |
| 81 | + "cniVersion": "0.3.1", |
| 82 | + "name": "{{ network.network_name }}", |
| 83 | + "type": "macvlan", |
| 84 | +{% if network.vlan_id is defined%} |
| 85 | + "master": "{{ network.network_name }}", |
| 86 | +{% elif network.network_name == "ctlplane" %} |
| 87 | + "master": "ospbr", |
| 88 | +{% else %} |
| 89 | + "master": "{{ ns.interfaces[network.network_name] }}", |
| 90 | +{% endif %} |
| 91 | + "ipam": { |
| 92 | + "type": "whereabouts", |
| 93 | + "range": "{{ network[_ipv.network_vX] }}", |
| 94 | + "range_start": "{{ network.tools.multus[_ipv.ipvX_ranges].0.start }}", |
| 95 | + "range_end": "{{ network.tools.multus[_ipv.ipvX_ranges].0.end }}" |
| 96 | + } |
| 97 | + } |
| 98 | +{% endif %} |
| 99 | +{% endfor %} |
| 100 | + |
| 101 | + dns-resolver: |
| 102 | + config: |
| 103 | + server: |
| 104 | + - "{{ cifmw_networking_env_definition.networks.ctlplane2[_ipv.gw_vX] }}" |
| 105 | + search: [] |
| 106 | + options: |
| 107 | + - key: server |
| 108 | + values: |
| 109 | + - {{ cifmw_networking_env_definition.networks.ctlplane2[_ipv.gw_vX] }} |
| 110 | +{% for nameserver in cifmw_ci_gen_kustomize_values_nameservers %} |
| 111 | + - key: server |
| 112 | + values: |
| 113 | + - {{ nameserver }} |
| 114 | +{% endfor %} |
| 115 | + |
| 116 | + routes: |
| 117 | + config: [] |
| 118 | + |
| 119 | +# Hardcoding the last IP bit since we don't have support for endpoint_annotations in the networking_mapper output |
| 120 | + rabbitmq: |
| 121 | + endpoint_annotations: |
| 122 | + metallb.universe.tf/address-pool: internalapi2 |
| 123 | + metallb.universe.tf/loadBalancerIPs: {{ cifmw_networking_env_definition.networks['internalapi2'][_ipv.network_vX] | ansible.utils.ipmath(85) }} |
| 124 | + rabbitmq-cell1: |
| 125 | + endpoint_annotations: |
| 126 | + metallb.universe.tf/address-pool: internalapi2 |
| 127 | + metallb.universe.tf/loadBalancerIPs: {{ cifmw_networking_env_definition.networks['internalapi2'][_ipv.network_vX] | ansible.utils.ipmath(86) }} |
| 128 | + |
| 129 | + lbServiceType: LoadBalancer |
| 130 | + storageClass: {{ cifmw_ci_gen_kustomize_values_storage_class }} |
0 commit comments