- уточнение кода для ipv4/ipv6
This commit is contained in:
135
2025-01-13 01:21:45 +03:00
parent c281a13b8e
commit fb2741023d
4 changed files with 106 additions and 47 deletions

View File

@@ -1,12 +1,27 @@
---
# tasks file for network-manager
- name: "apt install NetworkManager {{ nm_version }} "
when: nm__skip_install is not true
apt:
name: "network-manager{{ nm_version }}"
default_release: "{{ ansible_distribution_release }}-backports"
autoremove: true
update_cache: true
#- name: "apt install NetworkManager {{ nm_version }} "
# when: nm__skip_install is not true
# apt:
# name: "network-manager{{ nm_version }}"
# default_release: "{{ ansible_distribution_release }}-backports"
# autoremove: true
# update_cache: true
- name: Get OS and major version specific for NetworkManager installation
ansible.builtin.set_fact:
install_nm_tasks: >-
{%- if ansible_distribution == "Debian" and ansible_distribution_major_version == "12" -%}
install-nm.debian-12.yml
{%- elif ansible_distribution == "Debian" and ansible_distribution_major_version in ["10", "11"] -%}
install-nm.debian-10.yml
{%- elif ansible_distribution == "Ubuntu" -%}
install-nm.ubuntu.yml
{%- else -%}
install-nm.default.yml
{%- endif -%}
- name: Install NetworkManager for {{ ansible_distribution }} {{ ansible_distribution_major_version }}
ansible.builtin.include_tasks: "{{ install_nm_tasks }}"
- name: Enable service NetworkManager and ensure it is not masked
ansible.builtin.systemd_service:
@@ -14,8 +29,8 @@
enabled: true
masked: no
- name: config globally managed devices
template:
- name: Configure globally managed devices to NM
ansible.builtin.template:
src: "conf.d/10-globally-managed-devices.j2"
dest: "{{ globally_managed_devices_path }}"
owner: root
@@ -24,51 +39,19 @@
when: globally_managed_devices is true
notify: Restart NetworkManager
- name: cleanup globally managed devices
file:
- name: Cleanup globally managed devices
ansible.builtin.file:
path: "{{ globally_managed_devices_path }}"
state: absent
when: not globally_managed_devices
notify: Restart NetworkManager
- name: Include tasks for checking and removing udev rules
include_tasks: check_udev_rules.yml
ansible.builtin.include_tasks: check_udev_rules.yml
- name: Configure NetworkManager [ type loopback ]
community.general.nmcli:
autoconnect: "{{ connection.autoconnect | default('true') }}"
conn_name: "{{ connection.con_name | default('lo') }}"
ifname: "{{ connection.ifname | default('lo') }}"
type: "{{ connection.type }}"
ip4: "{{ connection.ip4 | default('') }}"
dns4: "{{ connection.dns4 | default([]) }}"
method4: "{{ connection.method4 | default('manual') }}"
method6: "{{ connection.method6 | default('auto') }}"
state: present
with_items: "{{ network }}"
when: connection.type == 'loopback'
loop_control:
loop_var: connection
notify: Restart NetworkManager
- name: Configure NetworkManager [ type ethernet ]
community.general.nmcli:
autoconnect: "{{ connection.autoconnect | default('true') }}"
conn_name: "{{ connection.con_name }}"
ifname: "{{ connection.ifname }}"
type: "{{ connection.type }}"
ip4: "{{ connection.ip4 | default('') }}"
gw4: "{{ connection.gw4 | default('') }}"
dns4: "{{ connection.dns4 | default([]) }}"
routes4: "{{ connection.routes4 | default([]) }}"
method4: "{{ connection.method4 | default('manual') }}"
method6: "{{ connection.method6 | default('disabled') }}"
state: present
with_items: "{{ network }}"
when: connection.type == 'ethernet'
loop_control:
loop_var: connection
notify: Restart NetworkManager
- name: Include tasks for managing connections
when: network is defined
ansible.builtin.include_tasks: connections.config.yml
- name: Notify the reboot handler
meta: flush_handlers