From de19dd6104f369c3dd98d026dd2286ca0c7aec9f Mon Sep 17 00:00:00 2001 From: Ryan Cavicchioni Date: Sun, 25 Aug 2019 02:07:11 +0000 Subject: [PATCH] Network role fixes --- roles/network/defaults/main.yml | 2 +- roles/network/tasks/ifupdown.yml | 22 ++++++++ roles/network/tasks/main.yml | 70 ++++-------------------- roles/network/tasks/netplan.yml | 15 +++++ roles/network/tasks/systemd-networkd.yml | 23 ++++++++ 5 files changed, 72 insertions(+), 60 deletions(-) create mode 100644 roles/network/tasks/ifupdown.yml create mode 100644 roles/network/tasks/netplan.yml create mode 100644 roles/network/tasks/systemd-networkd.yml diff --git a/roles/network/defaults/main.yml b/roles/network/defaults/main.yml index 4c3167d..16bf860 100644 --- a/roles/network/defaults/main.yml +++ b/roles/network/defaults/main.yml @@ -1,6 +1,6 @@ --- network_interfaces: - - name: "{{ facter_networking.primary }}" + - name: "{{ ansible_default_ipv4.interface }}" address: - "{{ ansible_default_ipv4.address }}/{{ (ansible_default_ipv4.address + '/' + ansible_default_ipv4.netmask) | ipaddr('prefix') }}" - "{{ ansible_default_ipv6.address + '/' + ansible_default_ipv6.prefix }}" diff --git a/roles/network/tasks/ifupdown.yml b/roles/network/tasks/ifupdown.yml new file mode 100644 index 0000000..bb1845b --- /dev/null +++ b/roles/network/tasks/ifupdown.yml @@ -0,0 +1,22 @@ +--- +# ifupdown + +- name: manage ifupdown services + service: + name: "{{ _network_ifupdown_service_name }}" + state: "{{ _network_ifupdown_enabled | ternary('started', 'stopped') }}" + enabled: "{{ _network_ifupdown_enabled }}" + +- name: manage ifupdown package + package: + name: "{{ _network_ifupdown_package_name }}" + state: "{{ _network_ifupdown_enabled | ternary('present', 'absent') }}" + +- name: manage /etc/network/interfaces + template: + src: network-interfaces.j2 + dest: /etc/network/interfaces + notify: restart ifupdown + with_items: "{{ network_interfaces }}" + when: _network_ifupdown_enabled | bool + diff --git a/roles/network/tasks/main.yml b/roles/network/tasks/main.yml index 8a191b0..aaa7768 100644 --- a/roles/network/tasks/main.yml +++ b/roles/network/tasks/main.yml @@ -1,67 +1,19 @@ --- - name: gather OS specific variables - include_vars: "{{ item }} " + include_vars: "{{ item }}" with_first_found: - "{{ ansible_distribution }}-{{ ansible_distribution_major_version }}.yaml" - "{{ ansible_distribution }}.yaml" - "{{ ansible_os_family }}.yaml" -# systemd-networkd +- name: systemd-networkd + include: systemd-networkd.yml -- name: manage systemd-networkd package - package: - name: "{{ _network_systemd_networkd_package_name }}" - state: "{{ _network_systemd_networkd_enabled | ternary('present', 'absent') }}" - when: _systemd_networkd_package_name is defined +- name: ifupdown + include: ifupdown.yml -- name: manage systemd-networkd service - service: - name: "{{ _network_systemd_networkd_service_name }}" - state: "{{ _network_systemd_networkd_enabled | ternary('started', 'stopped') }}" - enabled: "{{ _network_systemd_networkd_enabled }}" - -- name: configure systemd-networkd - template: - src: systemd-network.j2 - dest: "/etc/systemd/network/05-{{ item.name }}.network" - notify: restart systemd-networkd - with_items: "{{ network_interfaces }}" - when: _network_systemd_networkd_enabled - -# ifupdown - -- name: manage ifupdown services - service: - name: "{{ _network_ifupdown_service_name }}" - state: "{{ _network_ifupdown_enabled | ternary('started', 'stopped') }}" - enabled: "{{ _network_ifupdown_enabled }}" - -- name: manage ifupdown package - package: - name: "{{ _network_ifupdown_package_name }}" - state: "{{ _network_ifupdown_enabled | ternary('present', 'absent') }}" - -- name: manage /etc/network/interfaces - template: - src: network-interfaces.j2 - dest: /etc/network/interfaces - notify: restart ifupdown - with_items: "{{ network_interfaces }}" - when: _network_ifupdown_enabled - -# netplan.io - -- name: manage netplan package - package: - name: "{{ _network_netplan_package_name }}" - state: "{{ _network_netplan_enabled | ternary('present', 'absent') }}" - -- name: manage netplan - template: - src: netcfg.yaml.j2 - dest: /etc/netplan/01-netcfg.yaml - notify: netplan apply - when: _network_netplan_enabled +- name: netplan.io + include: netplan.yml # resolv.conf @@ -70,7 +22,7 @@ src: resolv.conf.j2 dest: /etc/resolv.conf notify: restart systemd-resolved - when: _network_resolv_conf_enabled + when: _network_resolv_conf_enabled | bool # systemd-resolved @@ -86,19 +38,19 @@ dest: /etc/resolv.conf state: link force: yes - when: _network_systemd_resolved_enabled + when: _network_systemd_resolved_enabled | bool - name: configure systemd-resolved template: src: resolved.conf.j2 dest: /etc/systemd/resolved.conf notify: restart systemd-resolved - when: _network_systemd_resolved_enabled + when: _network_systemd_resolved_enabled | bool - name: remove systemd-resolved configuration file: path: /etc/systemd/resolved.conf state: absent - when: not _network_systemd_resolved_enabled + when: not _network_systemd_resolved_enabled | bool # vim:ft=yaml.ansible: diff --git a/roles/network/tasks/netplan.yml b/roles/network/tasks/netplan.yml new file mode 100644 index 0000000..3915e61 --- /dev/null +++ b/roles/network/tasks/netplan.yml @@ -0,0 +1,15 @@ +--- +# netplan.io + +- name: manage netplan package + package: + name: "{{ _network_netplan_package_name }}" + state: "{{ _network_netplan_enabled | ternary('present', 'absent') }}" + +- name: manage netplan + template: + src: netcfg.yaml.j2 + dest: /etc/netplan/01-netcfg.yaml + notify: netplan apply + when: _network_netplan_enabled | bool + diff --git a/roles/network/tasks/systemd-networkd.yml b/roles/network/tasks/systemd-networkd.yml new file mode 100644 index 0000000..962c231 --- /dev/null +++ b/roles/network/tasks/systemd-networkd.yml @@ -0,0 +1,23 @@ +--- +# systemd-networkd + +- name: manage systemd-networkd package + package: + name: "{{ _network_systemd_networkd_package_name }}" + state: "{{ _network_systemd_networkd_enabled | ternary('present', 'absent') }}" + when: _systemd_networkd_package_name is defined + +- name: manage systemd-networkd service + service: + name: "{{ _network_systemd_networkd_service_name }}" + state: "{{ _network_systemd_networkd_enabled | ternary('started', 'stopped') }}" + enabled: "{{ _network_systemd_networkd_enabled }}" + +- name: configure systemd-networkd + template: + src: systemd-network.j2 + dest: "/etc/systemd/network/05-{{ item.name }}.network" + notify: restart systemd-networkd + with_items: "{{ network_interfaces }}" + when: _network_systemd_networkd_enabled | bool +