Timotej Lazar
e7f9132571
Firewall policy is set in NetBox as cluster services¹. For Proxmox we have to manually allow communication between nodes when using L3, since the default management ipset does not get populated correctly. We also need to open VTEP communication between nodes, which the default rules don’t. We allow all inter-node traffic, as SSH without passwords must be permitted anyway. This also adds some helper filters that are spectacularly annoying to implement purely in templates. ¹ There is actually no such thing as as a cluster service (yet?), so instead we create a fake VM for the cluster, define services for it, and then add the same services to a custom field on the cluster. Alternative would be to tie services to a specific node, but that could be problematic if that node is replaced.
13 lines
355 B
YAML
13 lines
355 B
YAML
- name: Retrieve service list
|
|
set_fact:
|
|
services: '{{ query("netbox.netbox.nb_lookup", "clusters", raw_data=true, api_filter="name="+cluster) | map(attribute="custom_fields.services") | flatten }}'
|
|
|
|
- name: Set up firewall
|
|
template:
|
|
dest: /etc/pve/firewall/cluster.fw
|
|
src: cluster.fw.j2
|
|
mode: 0640
|
|
owner: root
|
|
group: www-data
|
|
|