Fix networkd templating integration and access permissions

This commit is contained in:
Ethan Paul 2021-11-06 01:19:37 -04:00
parent d24a9b2713
commit f66a1fb8cc
No known key found for this signature in database
GPG Key ID: 6A337337DF6B5B1A
2 changed files with 86 additions and 90 deletions

View File

@ -1,20 +1,21 @@
---
- name: Install systemd-networkd on Rocky
- name: Configure network settings
become: true
block:
- name: Install systemd-networkd on Rocky
ansible.builtin.dnf:
name: systemd-networkd
state: present
- name: Ensure network config directory exists
- name: Ensure network config directory exists
ansible.builtin.file:
path: /etc/systemd/network
state: directory
owner: root
group: root
mode: 0644
mode: 0755
- name: Create network files
become: true
- name: Create network files
ansible.builtin.template:
src: network.j2
dest: /etc/systemd/network/{{ item.key }}.network
@ -22,10 +23,11 @@
owner: root
group: "{{ ansible_user }}"
loop: "{{ skylab_networking.interfaces | dict2items }}"
loop_control:
label: "{{ item.key }}"
- name: Create netdev files
become: true
when: item.kind is defined
- name: Create netdev files
when: item.value.type is defined
ansible.builtin.template:
src: netdev.j2
dest: /etc/systemd/network/{{ item.key }}.netdev
@ -33,31 +35,31 @@
owner: root
group: "{{ ansible_user }}"
loop: "{{ skylab_networking.interfaces | dict2items }}"
loop_control:
label: "{{ item.key }}"
- name: Fetch existing network config directory contents
become: true
- name: Fetch existing network config directory contents
changed_when: false
ansible.builtin.command:
cmd: /usr/bin/ls /etc/systemd/network
register: _network_config_dir_raw
- name: Remove legacy network config files
become: true
- name: Remove legacy network config files
when: item.strip().replace('.netdev', '').replace('.network', '') not in skylab_networking.interfaces
ansible.builtin.file:
path: /etc/systemd/network/{{ item }}
state: absent
loop: "{{ _network_config_dir_raw.stdout.split(' ') }}"
loop: "{{ _network_config_dir_raw.stdout_lines }}"
loop_control:
label: "{{ item.strip() }}"
- name: Configure fallback DNS
become: true
- name: Configure fallback DNS
ansible.builtin.lineinfile:
path: /etc/systemd/resolved.conf
create: false
line: FallbackDNS=
- name: Enable systemd-networkd
become: true
- name: Enable systemd-networkd
ansible.builtin.systemd:
name: "{{ item }}"
enabled: true
@ -66,8 +68,7 @@
- systemd-networkd-wait-online
- systemd-resolved
- name: Disable NetworkManager
become: true
- name: Disable NetworkManager
ansible.builtin.systemd:
name: "{{ item }}"
enabled: false
@ -75,14 +76,12 @@
- NetworkManager
- NetworkManager-wait-online
- name: Start systemd-resolved to enable symlink creation
become: true
- name: Start systemd-resolved to enable symlink creation
ansible.builtin.systemd:
name: systemd-resolved
state: started
- name: Link system resolv.conf to systemd-resolved
become: true
- name: Link system resolv.conf to systemd-resolved
ansible.builtin.file:
dest: /etc/resolv.conf
src: /run/systemd/resolve/resolv.conf
@ -90,8 +89,7 @@
force: true
setype: net_conf_t
- name: Link systemd-resolved to multi-user target
become: true
- name: Link systemd-resolved to multi-user target
ansible.builtin.file:
dest: /etc/systemd/system/multi-user.target.wants/systemd-resolved.service
src: /usr/lib/systemd/system/systemd-resolved.service

View File

@ -14,17 +14,15 @@ DNS={{ server }}
{% if item.value.bond is defined %}
Bond={{ item.value.bond }}
{% endif %}
{% if item.value.dhcp | default(false) %}
Gateway={{ item.value.gateway | ansible.netcommon.ipaddr('address') }}
{% for address in item.value.addresses %}
Address={{ address | ansible.netcommon.ipaddr('host/prefix') }}
{% endfor %}
{% endif %}
{% for interface in skylab_networking.interfaces.keys() %}
{% if interface.startswith(item.key) and interface.partition('.')[2] | number %}
{% if interface.startswith(item.key) and interface.partition('.')[2] | regex_search('^[0-9]{1,4}$') and interface != item.key %}
VLAN={{ interface }}
{% endif %}
{% endfor %}