servers/roles/dnsmasq/templates/10-ranges.conf.j2
Timotej Lazar 8276c6e8b4 dnsmasq: allow DHCP for non-primary IP address
Not actually needed but doesn’t hurt. Except it makes instantiating
the template even slower. Maybe rewrite the whole thing.
2026-01-06 16:48:48 +01:00

28 lines
1.3 KiB
Django/Jinja

{% for prefix in prefixes | selectattr('custom_fields.dhcp_server') | sort(attribute='vlan.name') %}
{% if prefix.custom_fields.dhcp_server.address | ipaddr('address') == primary_ip4 %}
# {{ prefix.vlan.name }}
{% for range in prefix.custom_fields.dhcp_ranges | default([], true) %}
dhcp-range = set:{{ prefix.vlan.name }},{{ range.start_address | ipaddr('address') }},{{ range.end_address | ipaddr('address') }},{{ prefix.prefix | ipaddr('netmask') }}
{% endfor %}
{% if prefix.custom_fields.gateway %}
dhcp-option = tag:{{ prefix.vlan.name }},option:router,{{ prefix.custom_fields.gateway.address | ipaddr('address') }}
{% endif -%}
{% for host in hostvars.values() | selectattr('interfaces', 'defined') %}
{% for interface in host.interfaces | selectattr('mac_address') %}
{% for address in interface.ip_addresses
| selectattr('status.value', '==', 'dhcp')
| map(attribute='address') | map('ipaddr', 'address')
| select('ansible.utils.in_network', prefix.prefix) %}
dhcp-host = {{ interface.mac_address | lower }},{{ address }},{{ interface.device.name | lower }}
{% endfor %}
{% endfor %}
{% endfor %}
{% endif %}
{% endfor %}
# custom reservations
{% for reservation in reservations | default([]) %}
dhcp-host = {{ reservation.mac | lower }},{{ reservation.ip | ipaddr('address') }},{{ reservation.host | lower }}
{% endfor %}