network and serial complete
This commit is contained in:
3
ansible/roles/systemd_networkd/defaults/main.yaml
Normal file
3
ansible/roles/systemd_networkd/defaults/main.yaml
Normal file
@ -0,0 +1,3 @@
|
||||
default_network_services:
|
||||
Archlinux:
|
||||
NetworkManager
|
9
ansible/roles/systemd_networkd/handlers/main.yaml
Normal file
9
ansible/roles/systemd_networkd/handlers/main.yaml
Normal file
@ -0,0 +1,9 @@
|
||||
- name: Restart systemd-networkd
|
||||
ansible.builtin.service:
|
||||
name: systemd-networkd.service
|
||||
state: restarted
|
||||
|
||||
- name: Restart systemd-resolved
|
||||
ansible.builtin.service:
|
||||
name: systemd-resolved.service
|
||||
state: restarted
|
39
ansible/roles/systemd_networkd/tasks/main.yaml
Normal file
39
ansible/roles/systemd_networkd/tasks/main.yaml
Normal file
@ -0,0 +1,39 @@
|
||||
---
|
||||
|
||||
- name: Clear systemd-networkd config directory
|
||||
ansible.builtin.file:
|
||||
path: "/etc/systemd/network/"
|
||||
state: "{{ item }}"
|
||||
owner: root
|
||||
group: root
|
||||
mode: '0755'
|
||||
with_items:
|
||||
- absent
|
||||
- directory
|
||||
|
||||
- name: Create systemd-networkd config files
|
||||
ansible.builtin.template:
|
||||
src: "{{ item.src }}"
|
||||
dest: /etc/systemd/network/"{{ item.name }}"
|
||||
owner: root
|
||||
group: root
|
||||
mode: '0644'
|
||||
loop: "{{ systemd_networkd_configs }}"
|
||||
notify:
|
||||
- Restart systemd-resolved
|
||||
- Restart systemd-networkd
|
||||
|
||||
- name: Disable non-systemd networking services
|
||||
ansible.builtin.service:
|
||||
name: "{{ item }}"
|
||||
state: stopped
|
||||
enabled: false
|
||||
loop: "{{ default_network_services[ansible_os_family] }}"
|
||||
|
||||
- name: Enable systemd networking
|
||||
ansible.builtin.service:
|
||||
name: "{{ item }}"
|
||||
enabled: true
|
||||
loop:
|
||||
- systemd-networkd
|
||||
- systemd-resolved
|
@ -0,0 +1,9 @@
|
||||
[NetDev]
|
||||
Name={{ item.name | regex_replace('^[0-9]*-', '') | regex_replace('\.netdev', '') }}
|
||||
Kind=bridge
|
||||
|
||||
[Bridge]
|
||||
DefaultPVID=none
|
||||
VLANFiltering={{ item.vlan_filtering | default(false)}}
|
||||
VLANProtocol=802.1q
|
||||
STP={{ item.stp | default(false) }}
|
15
ansible/roles/systemd_networkd/templates/bridge.network.j2
Normal file
15
ansible/roles/systemd_networkd/templates/bridge.network.j2
Normal file
@ -0,0 +1,15 @@
|
||||
[Match]
|
||||
Name={{ item.name | regex_replace('^[0-9]*-', '') | regex_replace('\.network', '') }}
|
||||
|
||||
[Link]
|
||||
ARP={{ item.arp | default(true) }}
|
||||
|
||||
[Network]
|
||||
DHCP={{ item.dhcp | default(true) }}
|
||||
LinkLocalAddressing=False
|
||||
LLDP={{ item.lldp | default(true) }}
|
||||
{% if item.vlans is defined -%}
|
||||
{% for vlan in item.vlans -%}
|
||||
VLAN={{ item.vlan }}
|
||||
{% endfor -%}
|
||||
{% endif -%}
|
@ -0,0 +1,8 @@
|
||||
[Match]
|
||||
PermanentMACAddress={{ item.mac_address }}
|
||||
|
||||
[Link]
|
||||
Name={{ item.name | regex_replace('^[0-9]*-', '') | regex_replace('\.link', '') }}
|
||||
MACAddressPolicy=permanent
|
||||
MACAddress={{ item.mac_address }}
|
||||
|
73
ansible/roles/systemd_networkd/templates/ethernet.network.j2
Normal file
73
ansible/roles/systemd_networkd/templates/ethernet.network.j2
Normal file
@ -0,0 +1,73 @@
|
||||
[Match]
|
||||
MACAddress={{ item.mac_address }}
|
||||
|
||||
[Link]
|
||||
ARP={{ item.arp | default(true) }}
|
||||
|
||||
[Network]
|
||||
DHCP={{ item.dhcp | default(true) }}
|
||||
LinkLocalAddressing=False
|
||||
LLDP={{ item.lldp | default(true) }}
|
||||
{% if item.nameserver is defined and item.nameserver.ipv4 is defined -%}
|
||||
{% for nameserver in item.nameserver.ipv4 -%}
|
||||
DNS={{ nameserver }}
|
||||
{% endfor -%}
|
||||
{% endif -%}
|
||||
{% if item.nameserver is defined and item.nameserver.ipv6 is defined -%}
|
||||
{% for nameserver in item.nameserver.ipv6 -%}
|
||||
DNS={{ nameserver }}
|
||||
{% endfor -%}
|
||||
{% endif -%}
|
||||
{% if item.bond is defined -%}
|
||||
Bond={{ item.bond }}
|
||||
{% endif -%}
|
||||
{% if item.bridge is defined -%}
|
||||
Bridge={{ item.bridge.name }}
|
||||
{% endif -%}
|
||||
{% if item.vlans is defined -%}
|
||||
{% for vlan in item.vlans -%}
|
||||
VLAN={{ vlan }}
|
||||
{% endfor -%}
|
||||
{% endif -%}
|
||||
|
||||
{% if item.address is defined %}
|
||||
[Address]
|
||||
{% if item.address.ipv4 is defined -%}
|
||||
{% for address in item.address.ipv4 -%}
|
||||
Address={{ address }}
|
||||
{% endfor -%}
|
||||
{% endif -%}
|
||||
{% if item.address.ipv6 is defined -%}
|
||||
{% for address in item.address.ipv6 -%}
|
||||
Address={{ address }}
|
||||
{% endfor -%}
|
||||
{% endif -%}
|
||||
{% endif -%}
|
||||
|
||||
{% if item.gateway is defined and item.gateway.ipv4 is defined %}
|
||||
[Route]
|
||||
Destination=0.0.0.0/0
|
||||
Gateway={{ item.gateway.ipv4 }}
|
||||
Scope=global
|
||||
Protocol=static
|
||||
Type=unicast
|
||||
{% endif -%}
|
||||
|
||||
{% if item.gateway is defined and item.gateway.ipv6 is defined %}
|
||||
[Route]
|
||||
Destination=::/0
|
||||
Gateway={{ item.gateway.ipv6 }}
|
||||
Protocol=static
|
||||
Type=unicast
|
||||
{% endif -%}
|
||||
|
||||
{% if item.bridge is defined and item.bridge.vlans is defined %}
|
||||
[BridgeVLANs]
|
||||
{% for vlan in item.bridge.vlans -%}
|
||||
VLAN={{ vlan }}
|
||||
{% endfor -%}
|
||||
{% if item.bridge.pvid is defined -%}
|
||||
PVID={{ item.bridge.pvid }}
|
||||
EgressUntagged={{ item.bridge.pvid }}
|
||||
{% endif -%}
|
||||
{% endif -%}
|
7
ansible/roles/systemd_networkd/templates/vlan.netdev.j2
Normal file
7
ansible/roles/systemd_networkd/templates/vlan.netdev.j2
Normal file
@ -0,0 +1,7 @@
|
||||
[NetDev]
|
||||
Name={{ item.name | regex_replace('^[0-9]*-', '') | regex_replace('\.netdev', '') }}
|
||||
Kind=vlan
|
||||
|
||||
[VLAN]
|
||||
Id={{ item.vlan_id }}
|
||||
Protocol=802.1q
|
51
ansible/roles/systemd_networkd/templates/vlan.network.j2
Normal file
51
ansible/roles/systemd_networkd/templates/vlan.network.j2
Normal file
@ -0,0 +1,51 @@
|
||||
[Match]
|
||||
Name={{ item.name | regex_replace('^[0-9]*-', '') | regex_replace('\.network', '') }}
|
||||
|
||||
[Link]
|
||||
ARP={{ item.arp | default(true) }}
|
||||
|
||||
[Network]
|
||||
DHCP={{ item.dhcp | default(true) }}
|
||||
LinkLocalAddressing=False
|
||||
LLDP={{ item.lldp | default(true) }}
|
||||
{% if item.nameserver is defined and item.nameserver.ipv4 is defined -%}
|
||||
{% for nameserver in item.nameserver.ipv4 -%}
|
||||
DNS={{ nameserver }}
|
||||
{% endfor -%}
|
||||
{% endif -%}
|
||||
{% if item.nameserver is defined and item.nameserver.ipv6 is defined -%}
|
||||
{% for nameserver in item.nameserver.ipv6 -%}
|
||||
DNS={{ nameserver }}
|
||||
{% endfor -%}
|
||||
{% endif -%}
|
||||
|
||||
{% if item.address is defined %}
|
||||
[Address]
|
||||
{% if item.address.ipv4 is defined -%}
|
||||
{% for address in item.address.ipv4 -%}
|
||||
Address={{ address }}
|
||||
{% endfor -%}
|
||||
{% endif -%}
|
||||
{% if item.address.ipv6 is defined -%}
|
||||
{% for address in item.address.ipv6 -%}
|
||||
Address={{ address }}
|
||||
{% endfor -%}
|
||||
{% endif -%}
|
||||
{% endif -%}
|
||||
|
||||
{% if item.gateway is defined and item.gateway.ipv4 is defined %}
|
||||
[Route]
|
||||
Destination=0.0.0.0/0
|
||||
Gateway={{ item.gateway.ipv4 }}
|
||||
Scope=global
|
||||
Protocol=static
|
||||
Type=unicast
|
||||
{% endif -%}
|
||||
|
||||
{% if item.gateway is defined and item.gateway.ipv6 is defined %}
|
||||
[Route]
|
||||
Destination=::/0
|
||||
Gateway={{ item.gateway.ipv6 }}
|
||||
Protocol=static
|
||||
Type=unicast
|
||||
{% endif -%}
|
Reference in New Issue
Block a user