Compare commits
3 Commits
master
...
6df7d5ccfc
| Author | SHA1 | Date | |
|---|---|---|---|
| 6df7d5ccfc | |||
| 75b0e41be6 | |||
| 38defef1a0 |
40
README.md
40
README.md
@@ -1,35 +1,18 @@
|
|||||||
# Ansible-Bootstrap
|
# Ansible-Bootstrap
|
||||||
|
|
||||||
An Ansible playbook for automating system bootstrap processes in an Infrastructure-as-Code manner, utilizing ArchISO as the foundational tool.
|
An Ansible playbook for automating system bootstrap processes in an Infrastructure-as-Code manner.
|
||||||
|
|
||||||
# Info
|
# Info
|
||||||
|
|
||||||
Most of the roles are adaptable for use with systems beyond ArchLinux, requiring only that the target system can install a necessary package manager, such as `dnf` for RHEL-based systems. Additionally, a replacement for the `arch-chroot` command may be required for these systems.
|
|
||||||
|
|
||||||
**NOTE**:
|
|
||||||
|
|
||||||
- For RHEL 8 and RHEL 9, repository access requires the `rhel_iso` variable. This variable specifies a local ISO or proxy repository.
|
- For RHEL 8 and RHEL 9, repository access requires the `rhel_iso` variable. This variable specifies a local ISO or proxy repository.
|
||||||
- RHEL systems do not support `btrfs`. Use `ext4` or `xfs` as alternatives.
|
- RHEL systems do not support `btrfs`. Use `ext4` or `xfs` as alternatives.
|
||||||
- For RHEL 8, `xfs` may cause installation issues; `ext4` is recommended.
|
- For RHEL 8, `xfs` may cause installation issues; `ext4` is recommended.
|
||||||
|
|
||||||
# Supported Distributions
|
# Supported Distributions
|
||||||
|
|
||||||
This playbook supports multiple Linux distributions with specific versions tailored to each. Below is a list of supported distributions:
|
|
||||||
|
|
||||||
| `os` | Distribution |
|
| `os` | Distribution |
|
||||||
| ---------- | ---------------------------------- |
|
|------------|------------------------------------|
|
||||||
| archlinux | ArchLinux (Latest rolling release) |
|
|
||||||
| almalinux | AlmaLinux 9.x |
|
|
||||||
| debian11 | Debian 11 (Bullseye) |
|
|
||||||
| debian12 | Debian 12 (Bookworm) |
|
|
||||||
| debian13 | Debian 13 (Trixie) |
|
|
||||||
| fedora | Fedora 42 |
|
|
||||||
| rhel8 | Red Hat Enterprise Linux 8 |
|
| rhel8 | Red Hat Enterprise Linux 8 |
|
||||||
| rhel9 | Red Hat Enterprise Linux 9 |
|
| rhel9 | Red Hat Enterprise Linux 9 |
|
||||||
| rhel10 | Red Hat Enterprise Linux 10 |
|
|
||||||
| rocky | Rocky Linux 9.x |
|
|
||||||
| ubuntu | Ubuntu 25.04 (Plucky Puffin) |
|
|
||||||
| ubuntu-lts | Ubuntu 24.04 LTS (Noble Numbat) |
|
|
||||||
|
|
||||||
# Documentation
|
# Documentation
|
||||||
|
|
||||||
@@ -45,19 +28,17 @@ This playbook supports multiple Linux distributions with specific versions tailo
|
|||||||
|
|
||||||
## 1. Overview
|
## 1. Overview
|
||||||
|
|
||||||
The playbook uses the ArchLinux ISO as a foundational tool to provides an efficient and systematic method for the automatic deployment of a variety of Linux distributions on designated target systems. It ensures a standardized setup across different platforms, equipping each system with the essential configurations and software necessary for its designated role.
|
The playbook uses the RHEL ISO to configure and bootstrap an RHEL system from the ground up.
|
||||||
|
|
||||||
## 2. Global Variables
|
## 2. Global Variables
|
||||||
|
|
||||||
Global variables apply across your Ansible project and are loaded from `vars.yml` by default. These variables define common settings such as hypervisor connection details and the boot ISO path. They can be overridden by inventory variables for specific hosts or VMs if needed.
|
Global variables apply across your Ansible project and are loaded from `vars.yml` by default. These variables define common settings such as hypervisor connection details and the boot ISO path. They can be overridden by inventory variables for specific hosts or VMs if needed.
|
||||||
|
|
||||||
| Variable | Description | Example Value |
|
| Variable | Description | Example Value |
|
||||||
| ----------------------- | ---------------------------------------------------------- | ----------------------------------------- |
|
|-----------------------|--------------------------------------------------------------------|-----------------------------------------|
|
||||||
| `boot_iso` | Path to the boot ISO image. | `local-btrfs:iso/archlinux-x86_64.iso` |
|
| `boot_iso` | Path to the boot ISO image. | `local-btrfs:iso/archlinux-x86_64.iso` |
|
||||||
| `rhel_iso` | Path to the RHEL ISO file, required for RHEL 8 and RHEL 9. |`local-btrfs:iso/rhel-9.4-x86_64-dvd.iso`|
|
| `rhel_iso` | Path to the RHEL ISO file, required for RHEL 8 and RHEL 9. |`local-btrfs:iso/rhel-9.4-x86_64-dvd.iso`|
|
||||||
| `hypervisor` | Type of hypervisor. | `libvirt`, `proxmox`, `vmware`, `none` |
|
| `hypervisor` | Type of hypervisor. | `vmware` |
|
||||||
| `vmware_ssh` | If Ansible should use SSH after base VM setup on VMware. | `true`, `false (default)` |
|
|
||||||
| `hypervisor_datacenter` | Name of the hypervisor datacenter. | `default-datacenter` |
|
|
||||||
| `hypervisor_cluster` | Name of the hypervisor cluster. | `default-cluster` |
|
| `hypervisor_cluster` | Name of the hypervisor cluster. | `default-cluster` |
|
||||||
| `hypervisor_node` | Hypervisor node name. | `node01` |
|
| `hypervisor_node` | Hypervisor node name. | `node01` |
|
||||||
| `hypervisor_password` | Password for hypervisor authentication. | `123456` |
|
| `hypervisor_password` | Password for hypervisor authentication. | `123456` |
|
||||||
@@ -65,7 +46,7 @@ Global variables apply across your Ansible project and are loaded from `vars.yml
|
|||||||
| `hypervisor_url` | URL/IP address for the hypervisor interface. | `192.168.0.2` |
|
| `hypervisor_url` | URL/IP address for the hypervisor interface. | `192.168.0.2` |
|
||||||
| `hypervisor_username` | Username for hypervisor authentication. | `root@pam` |
|
| `hypervisor_username` | Username for hypervisor authentication. | `root@pam` |
|
||||||
| `install_drive` | Drive where the system will be installed. | `/dev/sda` |
|
| `install_drive` | Drive where the system will be installed. | `/dev/sda` |
|
||||||
| `install_type` | Type of installation. | `virtual`, `physical` |
|
| `install_type` | Type of installation. | `virtual` |
|
||||||
| `vlan_name` (optional)| VLAN for the VM's network interface. | `vlan100` |
|
| `vlan_name` (optional)| VLAN for the VM's network interface. | `vlan100` |
|
||||||
|
|
||||||
To protect sensitive information, such as passwords, API keys, and other confidential variables (e.g., `hypervisor_password`), **it is recommended to use Ansible Vault**.
|
To protect sensitive information, such as passwords, API keys, and other confidential variables (e.g., `hypervisor_password`), **it is recommended to use Ansible Vault**.
|
||||||
@@ -75,20 +56,17 @@ To protect sensitive information, such as passwords, API keys, and other confide
|
|||||||
Inventory variables are defined for individual hosts or VMs in the inventory file, allowing customization of settings such as the operating system, filesystem, and compliance with CIS benchmarks. These variables can be set globally and overridden for specific hosts or VMs.
|
Inventory variables are defined for individual hosts or VMs in the inventory file, allowing customization of settings such as the operating system, filesystem, and compliance with CIS benchmarks. These variables can be set globally and overridden for specific hosts or VMs.
|
||||||
|
|
||||||
| Variable | Description | Example Value |
|
| Variable | Description | Example Value |
|
||||||
| --------------------- | -------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------- |
|
|-------------------------|-----------------------------------------------------------------------------------|----------------------------------------------------|
|
||||||
| `cis` (optional) | Adjusts the installation to be CIS level 3 conformant. | `true`, `false` |
|
| `cis` (optional) | Adjusts the installation to be CIS level 3 conformant. | `true`, `false` |
|
||||||
| `selinux` (optional) | Toggle SELinux, `false` means it should be disabled.` | `true`, `false` |
|
| `filesystem` | Filesystem type for the VM's primary storage. | `ext4`, `xfs` |
|
||||||
| `filesystem` | Filesystem type for the VM's primary storage. | `btrfs`, `ext4`, `xfs` |
|
|
||||||
| `hostname` | The hostname assigned to the virtual machine or system. | `vm01` |
|
| `hostname` | The hostname assigned to the virtual machine or system. | `vm01` |
|
||||||
| `os` | Operating system to be installed on the VM. | `archlinux`, `almalinux`, `debian11`, `debian12`, `fedora`, `rhel8`, `rhel9`, `rhel10`, `rocky`, `ubuntu`, `ubuntu-lts` |
|
| `os` | Operating system to be installed on the VM. | `rhel8`, `rhel9` |
|
||||||
| `root_password` | Root password for the VM or system, used for initial setup or secure access. | `SecurePass123` |
|
| `root_password` | Root password for the VM or system, used for initial setup or secure access. | `SecurePass123` |
|
||||||
| `user_name` | Username for a user account within the VM, often used with cloud-init. | `adminuser` |
|
| `user_name` | Username for a user account within the VM, often used with cloud-init. | `adminuser` |
|
||||||
| `user_password` | Password for the user account within the VM. | `UserPass123` |
|
| `user_password` | Password for the user account within the VM. | `UserPass123` |
|
||||||
| `user_public_key` | SSH Key for the user account within the VM. | `ssh-ed25519 AAAAC` |
|
|
||||||
| `vm_ballo` (optional) | Ballooning memory size for the VM, used to adjust memory allocation dynamically. | `2048` |
|
| `vm_ballo` (optional) | Ballooning memory size for the VM, used to adjust memory allocation dynamically. | `2048` |
|
||||||
| `vm_cpus` | Number of CPU cores assigned to the virtual machine. | `4` |
|
| `vm_cpus` | Number of CPU cores assigned to the virtual machine. | `4` |
|
||||||
| `vm_dns` | DNS server IP address(es) for the virtual machine's network configuration. | `1.0.0.1`, `1.1.1.1` |
|
| `vm_dns` | DNS server IP address(es) for the virtual machine's network configuration. | `1.0.0.1`, `1.1.1.1` |
|
||||||
| `vm_dns_search` | DNS search zone for the virtual machine's network configuration. | `example.com` |
|
|
||||||
| `vm_gw` | Default gateway IP address for the virtual machine's network configuration. | `192.168.0.1` |
|
| `vm_gw` | Default gateway IP address for the virtual machine's network configuration. | `192.168.0.1` |
|
||||||
| `vm_id` | Unique identifier for the virtual machine. | `101` |
|
| `vm_id` | Unique identifier for the virtual machine. | `101` |
|
||||||
| `vm_ip` | IP address assigned to the virtual machine. | `192.168.0.10` |
|
| `vm_ip` | IP address assigned to the virtual machine. | `192.168.0.10` |
|
||||||
|
|||||||
29
inventory_example.ini
Normal file
29
inventory_example.ini
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
[promox-kvm]
|
||||||
|
192.168.122.10
|
||||||
|
192.168.122.11
|
||||||
|
|
||||||
|
[promox-kvm:vars]
|
||||||
|
vm_gw=192.168.122.1
|
||||||
|
vm_dns=1.1.1.1
|
||||||
|
|
||||||
|
[192.168.122.10]
|
||||||
|
hostname=proxy
|
||||||
|
vm_id=300
|
||||||
|
os=archlinux
|
||||||
|
filesystem=btrfs
|
||||||
|
vm_memory=2048
|
||||||
|
vm_ballo=1024
|
||||||
|
vm_cpus=2
|
||||||
|
vm_size=5
|
||||||
|
vm_nif=vmbr1
|
||||||
|
|
||||||
|
[192.168.122.11]
|
||||||
|
hostname=database
|
||||||
|
vm_id=101
|
||||||
|
os=archlinux
|
||||||
|
filesystem=btrfs
|
||||||
|
vm_memory=6144
|
||||||
|
vm_ballo=3072
|
||||||
|
vm_cpus=4
|
||||||
|
vm_size=40
|
||||||
|
vm_nif=vmbr1
|
||||||
@@ -3,7 +3,6 @@ all:
|
|||||||
hypervisor: 'proxmox'
|
hypervisor: 'proxmox'
|
||||||
install_drive: '/dev/sda'
|
install_drive: '/dev/sda'
|
||||||
cis: true
|
cis: true
|
||||||
boot_iso: "local-btrfs:iso/archlinux-x86_64.iso"
|
|
||||||
children:
|
children:
|
||||||
promox-kvm:
|
promox-kvm:
|
||||||
hosts:
|
hosts:
|
||||||
@@ -19,7 +18,6 @@ all:
|
|||||||
vm_nif: vmbr1
|
vm_nif: vmbr1
|
||||||
vm_gw: 192.168.122.1
|
vm_gw: 192.168.122.1
|
||||||
vm_dns: 1.1.1.1
|
vm_dns: 1.1.1.1
|
||||||
vm_dns_search: "example.com"
|
|
||||||
192.168.122.11:
|
192.168.122.11:
|
||||||
hostname: database
|
hostname: database
|
||||||
vm_id: 101
|
vm_id: 101
|
||||||
|
|||||||
35
main.yml
35
main.yml
@@ -10,11 +10,6 @@
|
|||||||
What is your username?
|
What is your username?
|
||||||
private: false
|
private: false
|
||||||
|
|
||||||
- name: user_public_key
|
|
||||||
prompt: |
|
|
||||||
What is your ssh key?
|
|
||||||
private: false
|
|
||||||
|
|
||||||
- name: user_password
|
- name: user_password
|
||||||
prompt: |
|
prompt: |
|
||||||
What is your password?
|
What is your password?
|
||||||
@@ -27,49 +22,33 @@
|
|||||||
vars_files: vars.yml
|
vars_files: vars.yml
|
||||||
pre_tasks:
|
pre_tasks:
|
||||||
- name: Set ansible_python_interpreter
|
- name: Set ansible_python_interpreter
|
||||||
when: os | lower in ["almalinux", "rhel8", "rhel9", "rhel10", "rocky"]
|
when: os | lower in ["rhel9", "rhel8"]
|
||||||
ansible.builtin.set_fact:
|
ansible.builtin.set_fact:
|
||||||
ansible_python_interpreter: /usr/bin/python3
|
ansible_python_interpreter: /usr/bin/python3
|
||||||
|
|
||||||
- name: Set default variables
|
|
||||||
ansible.builtin.set_fact:
|
|
||||||
cis: false
|
|
||||||
|
|
||||||
- name: Set SSH Access
|
|
||||||
when: hypervisor != "vmware"
|
|
||||||
ansible.builtin.set_fact:
|
|
||||||
ansible_user: "{{ user_name }}"
|
|
||||||
ansible_password: "{{ user_password }}"
|
|
||||||
ansible_become_password: "{{ user_password }}"
|
|
||||||
ansible_ssh_extra_args: "-o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no"
|
|
||||||
|
|
||||||
- name: Validate variables
|
- name: Validate variables
|
||||||
ansible.builtin.assert:
|
ansible.builtin.assert:
|
||||||
that:
|
that:
|
||||||
- hypervisor in ["libvirt", "proxmox", "vmware", "none"]
|
- filesystem in ["ext4", "xfs"]
|
||||||
- filesystem in ["btrfs", "ext4", "xfs"]
|
|
||||||
- install_drive is defined
|
- install_drive is defined
|
||||||
- os in ["archlinux", "almalinux", "debian11", "debian12", "debian13", "fedora", "rhel8", "rhel9", "rhel10", "rocky", "ubuntu", "ubuntu-lts"]
|
- os in ["rhel8", "rhel9"]
|
||||||
- os not in ["rhel8", "rhel9", "rhel10"] or rhel_iso is defined
|
- (vm_size | int) >= 20)
|
||||||
- (filesystem == "btrfs" and (vm_size | int) >= 10) or (filesystem != "btrfs" and (vm_size | int) >= 20)
|
|
||||||
- (vm_size | float) >= ((vm_memory | float / 1024 >= 16.0) | ternary((vm_memory | float / 2048), [vm_memory | float / 1024, 4.0] | max) + 16)
|
- (vm_size | float) >= ((vm_memory | float / 1024 >= 16.0) | ternary((vm_memory | float / 2048), [vm_memory | float / 1024, 4.0] | max) + 16)
|
||||||
fail_msg: Invalid input specified, please try again.
|
fail_msg: Invalid input specified, please try again.
|
||||||
|
|
||||||
- name: Set connection
|
- name: Set connection
|
||||||
when: hypervisor == "vmware"
|
|
||||||
ansible.builtin.set_fact:
|
ansible.builtin.set_fact:
|
||||||
ansible_connection: vmware_tools
|
ansible_connection: vmware_tools
|
||||||
|
|
||||||
roles:
|
roles:
|
||||||
- role: virtualization
|
- role: virtualization
|
||||||
when: install_type == "virtual"
|
|
||||||
become: false
|
become: false
|
||||||
vars:
|
vars:
|
||||||
ansible_connection: local
|
ansible_connection: local
|
||||||
|
|
||||||
- role: environment
|
- role: environment
|
||||||
vars:
|
vars:
|
||||||
ansible_connection: "{{ 'vmware_tools' if hypervisor == 'vmware' else 'ssh' }}"
|
ansible_connection: vmware
|
||||||
|
|
||||||
- role: partitioning
|
- role: partitioning
|
||||||
vars:
|
vars:
|
||||||
@@ -84,13 +63,12 @@
|
|||||||
when: cis | bool
|
when: cis | bool
|
||||||
|
|
||||||
- role: cleanup
|
- role: cleanup
|
||||||
when: install_type == "virtual"
|
|
||||||
vars:
|
vars:
|
||||||
ansible_connection: local
|
ansible_connection: local
|
||||||
|
|
||||||
tasks:
|
tasks:
|
||||||
- name: Set final SSH Credentials
|
- name: Set final SSH Credentials
|
||||||
when: hypervisor != 'vmware' or (hypervisor == 'vmware' and vmware_ssh | bool)
|
when: vmware_ssh | bool
|
||||||
ansible.builtin.set_fact:
|
ansible.builtin.set_fact:
|
||||||
ansible_user: "{{ user_name }}"
|
ansible_user: "{{ user_name }}"
|
||||||
ansible_password: "{{ user_password }}"
|
ansible_password: "{{ user_password }}"
|
||||||
@@ -98,6 +76,5 @@
|
|||||||
ansible_ssh_extra_args: "-o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no"
|
ansible_ssh_extra_args: "-o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no"
|
||||||
|
|
||||||
- name: Check if VM is back and running
|
- name: Check if VM is back and running
|
||||||
when: not (hypervisor == 'vmware' and cis | bool)
|
|
||||||
ansible.builtin.wait_for_connection:
|
ansible.builtin.wait_for_connection:
|
||||||
timeout: 300
|
timeout: 300
|
||||||
|
|||||||
@@ -1,85 +1,25 @@
|
|||||||
---
|
---
|
||||||
|
- name: Include Packages
|
||||||
|
ansible.builtin.include_vars:
|
||||||
|
file: packages.yml
|
||||||
|
name: role_packages
|
||||||
|
|
||||||
- name: Run OS-specific bootstrap process
|
- name: Run OS-specific bootstrap process
|
||||||
block:
|
block:
|
||||||
- name: Bootstrap ArchLinux
|
|
||||||
when: os | lower == 'archlinux'
|
|
||||||
ansible.builtin.command: pacstrap /mnt {{ archlinux | join(' ') }} --asexplicit
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
|
|
||||||
- name: Bootstrap Debian System
|
|
||||||
when: os | lower in ['debian11', 'debian12', 'debian13']
|
|
||||||
ansible.builtin.command: "{{ item }}"
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
with_items:
|
|
||||||
- debootstrap --include={{ vars[os].base | join(',') }} {{ 'bullseye' if os == 'debian11' else 'bookworm' if os == 'debian12' else 'trixie' }}
|
|
||||||
/mnt http://deb.debian.org/debian/
|
|
||||||
- arch-chroot /mnt apt install -y {{ vars[os].extra | join(' ') }}
|
|
||||||
- arch-chroot /mnt apt remove -y libcups2 libavahi-common3 libavahi-common-data
|
|
||||||
|
|
||||||
- name: Bootstrap Ubuntu System
|
|
||||||
when: os | lower in ['ubuntu', 'ubuntu-lts']
|
|
||||||
ansible.builtin.command: "{{ item }}"
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
with_items:
|
|
||||||
- debootstrap --include={{ vars[os].base | join(',') }} {{ 'plucky' if os == 'ubuntu' else 'noble' }}
|
|
||||||
/mnt http://archive.ubuntu.com/ubuntu/
|
|
||||||
- ln -sf /run/NetworkManager/resolv.conf /mnt/etc/resolv.conf
|
|
||||||
- arch-chroot /mnt sed -i '1s|$| universe|' /etc/apt/sources.list
|
|
||||||
- arch-chroot /mnt apt update -y
|
|
||||||
- arch-chroot /mnt apt install -y {{ vars[os].extra | join(' ') }}
|
|
||||||
|
|
||||||
- name: Bootstrap AlmaLinux 9
|
|
||||||
when: os | lower == 'almalinux'
|
|
||||||
ansible.builtin.command: "{{ item }}"
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
with_items:
|
|
||||||
- dnf --releasever=9 --best --repo=alma-baseos --installroot=/mnt --setopt=install_weak_deps=False groupinstall -y base core
|
|
||||||
- ln -sf /run/NetworkManager/resolv.conf /mnt/etc/resolv.conf
|
|
||||||
- arch-chroot /mnt dnf --releasever=9 --setopt=install_weak_deps=False install -y {{ almalinux | join(' ') }}
|
|
||||||
|
|
||||||
- name: Bootstrap Fedora 42
|
|
||||||
when: os | lower == 'fedora'
|
|
||||||
ansible.builtin.command: "{{ item }}"
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
with_items:
|
|
||||||
- dnf --releasever=42 --best --repo=fedora --repo=fedora-updates
|
|
||||||
--installroot=/mnt --setopt=install_weak_deps=False groupinstall -y critical-path-base core
|
|
||||||
- ln -sf /run/NetworkManager/resolv.conf /mnt/etc/resolv.conf
|
|
||||||
- arch-chroot /mnt dnf --releasever=42 --setopt=install_weak_deps=False install -y {{ fedora | join(' ') }}
|
|
||||||
- arch-chroot /mnt dnf reinstall -y kernel-core
|
|
||||||
|
|
||||||
- name: Bootstrap RockyLinux 9
|
|
||||||
when: os | lower == 'rocky'
|
|
||||||
ansible.builtin.command: "{{ item }}"
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
with_items:
|
|
||||||
- dnf --releasever=9 --best --repo=rocky-baseos --installroot=/mnt
|
|
||||||
--setopt=install_weak_deps=False --setopt=optional_metadata_types=filelists
|
|
||||||
groupinstall -y base core
|
|
||||||
- ln -sf /run/NetworkManager/resolv.conf /mnt/etc/resolv.conf
|
|
||||||
- arch-chroot /mnt dnf --releasever=9 --setopt=install_weak_deps=False install -y {{ rocky | join(' ') }}
|
|
||||||
|
|
||||||
- name: Bootstrap RHEL System
|
- name: Bootstrap RHEL System
|
||||||
when: os | lower in ['rhel8', 'rhel9', 'rhel10']
|
|
||||||
block:
|
block:
|
||||||
- name: Install base packages in chroot environment
|
- name: Install base packages in chroot environment
|
||||||
ansible.builtin.command: >-
|
ansible.builtin.command: >-
|
||||||
dnf --releasever={{ os | lower | replace('rhel', '') }} --repo={{ os | lower }}-baseos
|
dnf --releasever={{ '8' if os == 'rhel8' else '9' }} --repo={{ os | lower }}-baseos
|
||||||
--installroot=/mnt
|
--installroot=/mnt
|
||||||
--setopt=install_weak_deps=False --setopt=optional_metadata_types=filelists
|
--setopt=install_weak_deps=False --setopt=optional_metadata_types=filelists
|
||||||
groupinstall -y core base standard
|
groupinstall -y base core
|
||||||
changed_when: result.rc == 0
|
changed_when: result.rc == 0
|
||||||
register: result
|
register: result
|
||||||
|
|
||||||
- name: Prepare chroot environment
|
- name: Prepare chroot environment
|
||||||
ansible.builtin.shell: |
|
ansible.builtin.shell: |
|
||||||
ln -sf /run/NetworkManager/resolv.conf /mnt/etc/resolv.conf
|
ln -sf /run/systemd/resolve/resolv.conf /mnt/etc/resolv.conf
|
||||||
mkdir -p /mnt/usr/local/install/redhat/dvd
|
mkdir -p /mnt/usr/local/install/redhat/dvd
|
||||||
mount --bind /usr/local/install/redhat/dvd /mnt/usr/local/install/redhat/dvd
|
mount --bind /usr/local/install/redhat/dvd /mnt/usr/local/install/redhat/dvd
|
||||||
arch-chroot /mnt rpm --rebuilddb
|
arch-chroot /mnt rpm --rebuilddb
|
||||||
@@ -89,13 +29,13 @@
|
|||||||
- name: Copy RHEL repo file into chroot environment
|
- name: Copy RHEL repo file into chroot environment
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
src: /etc/yum.repos.d/{{ os | lower }}.repo
|
src: /etc/yum.repos.d/{{ os | lower }}.repo
|
||||||
dest: /mnt/etc/yum.repos.d/redhat.repo
|
dest: /mnt/etc/yum.repos.d/{{ os | lower }}.repo
|
||||||
mode: "0644"
|
mode: '0644'
|
||||||
remote_src: true
|
remote_src: true
|
||||||
|
|
||||||
- name: Install additional packages in chroot
|
- name: Install additional packages in chroot
|
||||||
ansible.builtin.command: >-
|
ansible.builtin.command: >-
|
||||||
arch-chroot /mnt dnf --releasever={{ os | lower | replace('rhel', '') }}
|
arch-chroot /mnt dnf --releasever={{ '8' if os == 'rhel8' else '9' }}
|
||||||
--setopt=install_weak_deps=False install -y {{ vars[os] | join(' ') }}
|
--setopt=install_weak_deps=False install -y {{ role_packages[os] | join(' ') }}
|
||||||
changed_when: result.rc == 0
|
changed_when: result.rc == 0
|
||||||
register: result
|
register: result
|
||||||
|
|||||||
@@ -1,455 +0,0 @@
|
|||||||
almalinux:
|
|
||||||
- bind-utils
|
|
||||||
- dbus-daemon
|
|
||||||
- dhcp-client
|
|
||||||
- efibootmgr
|
|
||||||
- glibc-langpack-de
|
|
||||||
- glibc-langpack-en
|
|
||||||
- grub2
|
|
||||||
- grub2-efi
|
|
||||||
- lrzsz
|
|
||||||
- lvm2
|
|
||||||
- nc
|
|
||||||
- nfs-utils
|
|
||||||
- nfsv4-client-utils
|
|
||||||
- mtr
|
|
||||||
- open-vm-tools
|
|
||||||
- ppp
|
|
||||||
- shim
|
|
||||||
- tmux
|
|
||||||
- vim
|
|
||||||
- wget
|
|
||||||
- zram-generator
|
|
||||||
- zstd
|
|
||||||
|
|
||||||
archlinux:
|
|
||||||
- base
|
|
||||||
- btrfs-progs
|
|
||||||
- cronie
|
|
||||||
- dhcpcd
|
|
||||||
- efibootmgr
|
|
||||||
- fastfetch
|
|
||||||
- firewalld
|
|
||||||
- fish
|
|
||||||
- fzf
|
|
||||||
- grub
|
|
||||||
- htop
|
|
||||||
- libpwquality
|
|
||||||
- linux
|
|
||||||
- logrotate
|
|
||||||
- lrzsz
|
|
||||||
- lsof
|
|
||||||
- lvm2
|
|
||||||
- ncdu
|
|
||||||
- networkmanager
|
|
||||||
- nfs-utils
|
|
||||||
- open-vm-tools
|
|
||||||
- openssh
|
|
||||||
- ppp
|
|
||||||
- prometheus-node-exporter
|
|
||||||
- python-psycopg2
|
|
||||||
- qemu-guest-agent
|
|
||||||
- reflector
|
|
||||||
- rsync
|
|
||||||
- sudo
|
|
||||||
- tldr
|
|
||||||
- tmux
|
|
||||||
- vim
|
|
||||||
- wireguard-tools
|
|
||||||
- zram-generator
|
|
||||||
|
|
||||||
debian11:
|
|
||||||
base:
|
|
||||||
- apparmor-utils
|
|
||||||
- btrfs-progs
|
|
||||||
- chrony
|
|
||||||
- cron
|
|
||||||
- gnupg
|
|
||||||
- grub-efi
|
|
||||||
- grub-efi-amd64-signed
|
|
||||||
- grub2-common
|
|
||||||
- linux-image-amd64
|
|
||||||
- locales
|
|
||||||
- logrotate
|
|
||||||
- lvm2
|
|
||||||
- net-tools
|
|
||||||
- openssh-server
|
|
||||||
- python3
|
|
||||||
- sudo
|
|
||||||
- xfsprogs
|
|
||||||
|
|
||||||
extra:
|
|
||||||
- bat
|
|
||||||
- curl
|
|
||||||
- entr
|
|
||||||
- firewalld
|
|
||||||
- fish
|
|
||||||
- fzf
|
|
||||||
- htop
|
|
||||||
- jq
|
|
||||||
- libpam-pwquality
|
|
||||||
- lrzsz
|
|
||||||
- mtr
|
|
||||||
- ncdu
|
|
||||||
- neofetch
|
|
||||||
- network-manager
|
|
||||||
- open-vm-tools
|
|
||||||
- python-is-python3
|
|
||||||
- ripgrep
|
|
||||||
- rsync
|
|
||||||
- screen
|
|
||||||
- software-properties-common
|
|
||||||
- syslog-ng
|
|
||||||
- tcpd
|
|
||||||
- tldr
|
|
||||||
- vim
|
|
||||||
- wget
|
|
||||||
- zstd
|
|
||||||
|
|
||||||
debian12:
|
|
||||||
base:
|
|
||||||
- btrfs-progs
|
|
||||||
- cron
|
|
||||||
- gnupg
|
|
||||||
- grub-efi
|
|
||||||
- grub-efi-amd64-signed
|
|
||||||
- grub2-common
|
|
||||||
- linux-image-amd64
|
|
||||||
- locales
|
|
||||||
- logrotate
|
|
||||||
- lvm2
|
|
||||||
- xfsprogs
|
|
||||||
|
|
||||||
extra:
|
|
||||||
- apparmor-utils
|
|
||||||
- bat
|
|
||||||
- chrony
|
|
||||||
- curl
|
|
||||||
- duf
|
|
||||||
- entr
|
|
||||||
- firewalld
|
|
||||||
- fish
|
|
||||||
- fzf
|
|
||||||
- htop
|
|
||||||
- jq
|
|
||||||
- libpam-pwquality
|
|
||||||
- logrotate
|
|
||||||
- lrzsz
|
|
||||||
- mtr
|
|
||||||
- ncdu
|
|
||||||
- neofetch
|
|
||||||
- net-tools
|
|
||||||
- network-manager
|
|
||||||
- open-vm-tools
|
|
||||||
- openssh-server
|
|
||||||
- python-is-python3
|
|
||||||
- python3
|
|
||||||
- ripgrep
|
|
||||||
- rsync
|
|
||||||
- screen
|
|
||||||
- software-properties-common
|
|
||||||
- sudo
|
|
||||||
- syslog-ng
|
|
||||||
- systemd-zram-generator
|
|
||||||
- tcpd
|
|
||||||
- tldr
|
|
||||||
- vim
|
|
||||||
- wget
|
|
||||||
- zstd
|
|
||||||
|
|
||||||
debian13:
|
|
||||||
base:
|
|
||||||
- btrfs-progs
|
|
||||||
- cron
|
|
||||||
- gnupg
|
|
||||||
- grub-efi
|
|
||||||
- grub-efi-amd64-signed
|
|
||||||
- grub2-common
|
|
||||||
- linux-image-amd64
|
|
||||||
- locales
|
|
||||||
- logrotate
|
|
||||||
- lvm2
|
|
||||||
- xfsprogs
|
|
||||||
|
|
||||||
extra:
|
|
||||||
- apparmor-utils
|
|
||||||
- bat
|
|
||||||
- chrony
|
|
||||||
- curl
|
|
||||||
- duf
|
|
||||||
- entr
|
|
||||||
- fastfetch
|
|
||||||
- firewalld
|
|
||||||
- fish
|
|
||||||
- fzf
|
|
||||||
- htop
|
|
||||||
- jq
|
|
||||||
- libpam-pwquality
|
|
||||||
- logrotate
|
|
||||||
- lrzsz
|
|
||||||
- mtr
|
|
||||||
- ncdu
|
|
||||||
- net-tools
|
|
||||||
- network-manager
|
|
||||||
- open-vm-tools
|
|
||||||
- openssh-server
|
|
||||||
- python-is-python3
|
|
||||||
- python3
|
|
||||||
- ripgrep
|
|
||||||
- rsync
|
|
||||||
- screen
|
|
||||||
- sudo
|
|
||||||
- syslog-ng
|
|
||||||
- systemd-zram-generator
|
|
||||||
- tcpd
|
|
||||||
- vim
|
|
||||||
- wget
|
|
||||||
- zstd
|
|
||||||
|
|
||||||
fedora:
|
|
||||||
- bat
|
|
||||||
- bind-utils
|
|
||||||
- btrfs-progs
|
|
||||||
- cronie
|
|
||||||
- dhcp-client
|
|
||||||
- duf
|
|
||||||
- efibootmgr
|
|
||||||
- entr
|
|
||||||
- fish
|
|
||||||
- fzf
|
|
||||||
- glibc-langpack-de
|
|
||||||
- glibc-langpack-en
|
|
||||||
- grub2
|
|
||||||
- grub2-efi
|
|
||||||
- htop
|
|
||||||
- iperf3
|
|
||||||
- logrotate
|
|
||||||
- lrzsz
|
|
||||||
- lvm2
|
|
||||||
- nc
|
|
||||||
- nfs-utils
|
|
||||||
- nfsv4-client-utils
|
|
||||||
- open-vm-tools
|
|
||||||
- polkit
|
|
||||||
- ppp
|
|
||||||
- ripgrep
|
|
||||||
- shim
|
|
||||||
- tmux
|
|
||||||
- vim-default-editor
|
|
||||||
- wget
|
|
||||||
- zoxide
|
|
||||||
- zram-generator
|
|
||||||
- zstd
|
|
||||||
|
|
||||||
rhel8:
|
|
||||||
- bind-utils
|
|
||||||
- dhcp-client
|
|
||||||
- efibootmgr
|
|
||||||
- glibc-langpack-de
|
|
||||||
- glibc-langpack-en
|
|
||||||
- grub2
|
|
||||||
- grub2-efi-x64
|
|
||||||
- grub2-tools-extra
|
|
||||||
- lrzsz
|
|
||||||
- lvm2
|
|
||||||
- mtr
|
|
||||||
- ncurses-term
|
|
||||||
- nfs-utils
|
|
||||||
- open-vm-tools
|
|
||||||
- policycoreutils-python-utils
|
|
||||||
- python39
|
|
||||||
- shim
|
|
||||||
- tmux
|
|
||||||
- vim
|
|
||||||
- zstd
|
|
||||||
|
|
||||||
rhel9:
|
|
||||||
- bind-utils
|
|
||||||
- dhcp-client
|
|
||||||
- efibootmgr
|
|
||||||
- glibc-langpack-de
|
|
||||||
- glibc-langpack-en
|
|
||||||
- grub2
|
|
||||||
- grub2-efi
|
|
||||||
- grub2-tools-extra
|
|
||||||
- lrzsz
|
|
||||||
- lvm2
|
|
||||||
- mtr
|
|
||||||
- ncurses-term
|
|
||||||
- nfs-utils
|
|
||||||
- open-vm-tools
|
|
||||||
- policycoreutils-python-utils
|
|
||||||
- python
|
|
||||||
- shim
|
|
||||||
- tmux
|
|
||||||
- vim
|
|
||||||
- zram-generator
|
|
||||||
- zstd
|
|
||||||
|
|
||||||
rhel10:
|
|
||||||
- bind-utils
|
|
||||||
- efibootmgr
|
|
||||||
- glibc-langpack-de
|
|
||||||
- glibc-langpack-en
|
|
||||||
- grub2
|
|
||||||
- grub2-efi
|
|
||||||
- kernel
|
|
||||||
- lrzsz
|
|
||||||
- lvm2
|
|
||||||
- mtr
|
|
||||||
- ncurses-term
|
|
||||||
- nfs-utils
|
|
||||||
- open-vm-tools
|
|
||||||
- policycoreutils-python-utils
|
|
||||||
- python
|
|
||||||
- shim
|
|
||||||
- tmux
|
|
||||||
- vim
|
|
||||||
- zram-generator
|
|
||||||
- zstd
|
|
||||||
|
|
||||||
rocky:
|
|
||||||
- bind-utils
|
|
||||||
- dbus-daemon
|
|
||||||
- dhcp-client
|
|
||||||
- efibootmgr
|
|
||||||
- glibc-langpack-de
|
|
||||||
- glibc-langpack-en
|
|
||||||
- grub2
|
|
||||||
- grub2-efi
|
|
||||||
- lrzsz
|
|
||||||
- lvm2
|
|
||||||
- mtr
|
|
||||||
- nc
|
|
||||||
- nfs-utils
|
|
||||||
- nfsv4-client-utils
|
|
||||||
- open-vm-tools
|
|
||||||
- ppp
|
|
||||||
- shim
|
|
||||||
- telnet
|
|
||||||
- tmux
|
|
||||||
- util-linux-core
|
|
||||||
- vim
|
|
||||||
- wget
|
|
||||||
- zram-generator
|
|
||||||
- zstd
|
|
||||||
|
|
||||||
ubuntu:
|
|
||||||
base:
|
|
||||||
- btrfs-progs
|
|
||||||
- cron
|
|
||||||
- gnupg
|
|
||||||
- grub-efi
|
|
||||||
- grub-efi-amd64-signed
|
|
||||||
- grub2-common
|
|
||||||
- initramfs-tools
|
|
||||||
- linux-image-generic
|
|
||||||
- locales
|
|
||||||
- lvm2
|
|
||||||
- xfsprogs
|
|
||||||
|
|
||||||
extra:
|
|
||||||
- apparmor-utils
|
|
||||||
- bash-completion
|
|
||||||
- bat
|
|
||||||
- chrony
|
|
||||||
- curl
|
|
||||||
- dnsutils
|
|
||||||
- duf
|
|
||||||
- entr
|
|
||||||
- eza
|
|
||||||
- fdupes
|
|
||||||
- fio
|
|
||||||
- firewalld
|
|
||||||
- fish
|
|
||||||
- htop
|
|
||||||
- jq
|
|
||||||
- libpam-pwquality
|
|
||||||
- logrotate
|
|
||||||
- lrzsz
|
|
||||||
- mtr
|
|
||||||
- ncdu
|
|
||||||
- ncurses-term
|
|
||||||
- net-tools
|
|
||||||
- network-manager
|
|
||||||
- open-vm-tools
|
|
||||||
- openssh-server
|
|
||||||
- python-is-python3
|
|
||||||
- python3
|
|
||||||
- ripgrep
|
|
||||||
- rsync
|
|
||||||
- screen
|
|
||||||
- software-properties-common
|
|
||||||
- sudo
|
|
||||||
- syslog-ng
|
|
||||||
- systemd-zram-generator
|
|
||||||
- tcpd
|
|
||||||
- tldr
|
|
||||||
- tmux
|
|
||||||
- traceroute
|
|
||||||
- util-linux-extra
|
|
||||||
- vim
|
|
||||||
- wget
|
|
||||||
- yq
|
|
||||||
- zoxide
|
|
||||||
- zstd
|
|
||||||
|
|
||||||
ubuntu-lts:
|
|
||||||
base:
|
|
||||||
- btrfs-progs
|
|
||||||
- cron
|
|
||||||
- gnupg
|
|
||||||
- grub-efi
|
|
||||||
- grub-efi-amd64-signed
|
|
||||||
- grub2-common
|
|
||||||
- initramfs-tools
|
|
||||||
- linux-image-generic
|
|
||||||
- locales
|
|
||||||
- lvm2
|
|
||||||
- xfsprogs
|
|
||||||
|
|
||||||
extra:
|
|
||||||
- apparmor-utils
|
|
||||||
- bash-completion
|
|
||||||
- bat
|
|
||||||
- chrony
|
|
||||||
- curl
|
|
||||||
- dnsutils
|
|
||||||
- duf
|
|
||||||
- entr
|
|
||||||
- eza
|
|
||||||
- fdupes
|
|
||||||
- fio
|
|
||||||
- firewalld
|
|
||||||
- fish
|
|
||||||
- htop
|
|
||||||
- jq
|
|
||||||
- libpam-pwquality
|
|
||||||
- logrotate
|
|
||||||
- lrzsz
|
|
||||||
- mtr
|
|
||||||
- ncdu
|
|
||||||
- ncurses-term
|
|
||||||
- net-tools
|
|
||||||
- network-manager
|
|
||||||
- open-vm-tools
|
|
||||||
- openssh-server
|
|
||||||
- python-is-python3
|
|
||||||
- python3
|
|
||||||
- ripgrep
|
|
||||||
- rsync
|
|
||||||
- screen
|
|
||||||
- software-properties-common
|
|
||||||
- sudo
|
|
||||||
- syslog-ng
|
|
||||||
- systemd-zram-generator
|
|
||||||
- tcpd
|
|
||||||
- tldr
|
|
||||||
- tmux
|
|
||||||
- traceroute
|
|
||||||
- util-linux-extra
|
|
||||||
- vim
|
|
||||||
- wget
|
|
||||||
- yq
|
|
||||||
- zoxide
|
|
||||||
- zstd
|
|
||||||
32
roles/bootstrap/vars/packages.yml
Normal file
32
roles/bootstrap/vars/packages.yml
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
rhel8:
|
||||||
|
- dhcp-client
|
||||||
|
- efibootmgr
|
||||||
|
- grub2
|
||||||
|
- grub2-efi-x64
|
||||||
|
- lrzsz
|
||||||
|
- lvm2
|
||||||
|
- mtr
|
||||||
|
- nfs-utils
|
||||||
|
- open-vm-tools
|
||||||
|
- shim
|
||||||
|
- telnet
|
||||||
|
- tmux
|
||||||
|
- vim
|
||||||
|
- zstd
|
||||||
|
|
||||||
|
rhel9:
|
||||||
|
- dhcp-client
|
||||||
|
- efibootmgr
|
||||||
|
- grub2
|
||||||
|
- grub2-efi
|
||||||
|
- lrzsz
|
||||||
|
- lvm2
|
||||||
|
- mtr
|
||||||
|
- nfs-utils
|
||||||
|
- open-vm-tools
|
||||||
|
- shim
|
||||||
|
- telnet
|
||||||
|
- tmux
|
||||||
|
- vim
|
||||||
|
- zram-generator
|
||||||
|
- zstd
|
||||||
@@ -4,27 +4,26 @@
|
|||||||
- name: Disable Kernel Modules
|
- name: Disable Kernel Modules
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
dest: /mnt/etc/modprobe.d/cis.conf
|
dest: /mnt/etc/modprobe.d/cis.conf
|
||||||
mode: "0644"
|
mode: '0644'
|
||||||
content: |
|
content: |
|
||||||
CIS LVL 3 Restrictions
|
CIS LVL 3 Restrictions
|
||||||
install freevxfs /bin/false
|
install freevxfs /bin/true
|
||||||
install jffs2 /bin/false
|
install jffs2 /bin/true
|
||||||
install hfs /bin/false
|
install hfs /bin/true
|
||||||
install hfsplus /bin/false
|
install hfsplus /bin/true
|
||||||
install cramfs /bin/false
|
install squashfs /bin/true
|
||||||
install squashfs /bin/false
|
install udf /bin/true
|
||||||
install udf /bin/false
|
install usb-storage /bin/true
|
||||||
install usb-storage /bin/false
|
|
||||||
|
|
||||||
install dccp /bin/false
|
install dccp /bin/true
|
||||||
install sctp /bin/false
|
install sctp /bin/true
|
||||||
install rds /bin/false
|
install rds /bin/true
|
||||||
install tipc /bin/false
|
install tipc /bin/true
|
||||||
|
|
||||||
- name: Create USB Rules
|
- name: Create USB Rules
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
dest: /mnt/etc/udev/rules.d/10-cis_usb_devices.sh
|
dest: /mnt/etc/udev/rules.d/10-cis_usb_devices.sh
|
||||||
mode: "0644"
|
mode: '0644'
|
||||||
content: |
|
content: |
|
||||||
By default, disable all.
|
By default, disable all.
|
||||||
ACTION=="add", SUBSYSTEMS=="usb", TEST=="authorized_default", ATTR{authorized_default}="0"
|
ACTION=="add", SUBSYSTEMS=="usb", TEST=="authorized_default", ATTR{authorized_default}="0"
|
||||||
@@ -41,23 +40,14 @@
|
|||||||
- name: Create a consolidated sysctl configuration file
|
- name: Create a consolidated sysctl configuration file
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
dest: /mnt/etc/sysctl.d/10-cis.conf
|
dest: /mnt/etc/sysctl.d/10-cis.conf
|
||||||
mode: "0644"
|
mode: '0644'
|
||||||
content: |
|
content: |
|
||||||
## CIS Sysctl configurations
|
## CIS Sysctl configurations
|
||||||
kernel.yama.ptrace_scope=1
|
|
||||||
kernel.randomize_va_space=2
|
|
||||||
|
|
||||||
# Network
|
|
||||||
net.ipv4.ip_forward=0
|
|
||||||
net.ipv4.tcp_syncookies=1
|
|
||||||
net.ipv4.icmp_echo_ignore_broadcasts=1
|
|
||||||
net.ipv4.icmp_ignore_bogus_error_responses=1
|
|
||||||
net.ipv4.conf.all.log_martians = 1
|
net.ipv4.conf.all.log_martians = 1
|
||||||
net.ipv4.conf.all.rp_filter = 1
|
net.ipv4.conf.all.rp_filter = 1
|
||||||
net.ipv4.conf.all.secure_redirects = 0
|
net.ipv4.conf.all.secure_redirects = 0
|
||||||
net.ipv4.conf.all.send_redirects = 0
|
net.ipv4.conf.all.send_redirects = 0
|
||||||
net.ipv4.conf.all.accept_redirects = 0
|
net.ipv4.conf.all.accept_redirects = 0
|
||||||
net.ipv4.conf.all.accept_source_route=0
|
|
||||||
net.ipv4.conf.default.log_martians = 1
|
net.ipv4.conf.default.log_martians = 1
|
||||||
net.ipv4.conf.default.rp_filter = 1
|
net.ipv4.conf.default.rp_filter = 1
|
||||||
net.ipv4.conf.default.secure_redirects = 0
|
net.ipv4.conf.default.secure_redirects = 0
|
||||||
@@ -79,32 +69,6 @@
|
|||||||
# - { regexp: '^PASS_MIN_DAYS.*', replace: 'PASS_MIN_DAYS 7' }
|
# - { regexp: '^PASS_MIN_DAYS.*', replace: 'PASS_MIN_DAYS 7' }
|
||||||
# - { regexp: '^UMASK.*', replace: 'UMASK 027' }
|
# - { regexp: '^UMASK.*', replace: 'UMASK 027' }
|
||||||
|
|
||||||
- name: Ensure the Default UMASK is Set Correctly
|
|
||||||
ansible.builtin.lineinfile:
|
|
||||||
path: "/mnt/etc/profile"
|
|
||||||
regexp: "^(\\s*)umask\\s+\\d+"
|
|
||||||
line: "umask 027"
|
|
||||||
|
|
||||||
- name: Prevent Login to Accounts With Empty Password
|
|
||||||
ansible.builtin.replace:
|
|
||||||
dest: "{{ item }}"
|
|
||||||
regexp: "nullok"
|
|
||||||
loop:
|
|
||||||
- /mnt/etc/pam.d/system-auth
|
|
||||||
- /mnt/etc/pam.d/password-auth
|
|
||||||
|
|
||||||
- name: Configure System Cryptography Policy
|
|
||||||
when: os in ["almalinux", "rhel9", "rhel10", "rocky"]
|
|
||||||
ansible.builtin.command: arch-chroot /mnt /usr/bin/update-crypto-policies --set DEFAULT:NO-SHA1
|
|
||||||
register: crypto_policy_result
|
|
||||||
changed_when: "'Setting system-wide crypto-policies to' in crypto_policy_result.stdout"
|
|
||||||
|
|
||||||
- name: Mask Systemd Services
|
|
||||||
ansible.builtin.command: >
|
|
||||||
arch-chroot /mnt systemctl mask nftables bluetooth rpcbind
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
|
|
||||||
- name: Ensure files exist
|
- name: Ensure files exist
|
||||||
ansible.builtin.file:
|
ansible.builtin.file:
|
||||||
path: "{{ item }}"
|
path: "{{ item }}"
|
||||||
@@ -116,15 +80,6 @@
|
|||||||
- /mnt/etc/hosts.allow
|
- /mnt/etc/hosts.allow
|
||||||
- /mnt/etc/hosts.deny
|
- /mnt/etc/hosts.deny
|
||||||
|
|
||||||
- name: Ensure files do not exist
|
|
||||||
ansible.builtin.file:
|
|
||||||
path: "{{ item }}"
|
|
||||||
state: touch
|
|
||||||
mode: "0600"
|
|
||||||
loop:
|
|
||||||
- /mnt/etc/at.deny
|
|
||||||
- /mnt/etc/cron.deny
|
|
||||||
|
|
||||||
- name: Add Security related lines into config files
|
- name: Add Security related lines into config files
|
||||||
ansible.builtin.lineinfile:
|
ansible.builtin.lineinfile:
|
||||||
path: "{{ item.path }}"
|
path: "{{ item.path }}"
|
||||||
@@ -136,39 +91,16 @@
|
|||||||
- { path: /mnt/etc/security/pwquality.conf, content: ucredit = -1 }
|
- { path: /mnt/etc/security/pwquality.conf, content: ucredit = -1 }
|
||||||
- { path: /mnt/etc/security/pwquality.conf, content: ocredit = -1 }
|
- { path: /mnt/etc/security/pwquality.conf, content: ocredit = -1 }
|
||||||
- { path: /mnt/etc/security/pwquality.conf, content: lcredit = -1 }
|
- { path: /mnt/etc/security/pwquality.conf, content: lcredit = -1 }
|
||||||
- {
|
- { path: '/mnt/etc/bashrc', content: umask 077 }
|
||||||
path: '/mnt/etc/{{ "bashrc" if os in ["almalinux", "fedora", "rhel8", "rhel9", "rhel10", "rocky"] else "bash.bashrc" }}',
|
- { path: '/mnt/etc/bashrc', content: export TMOUT=3000 }
|
||||||
content: umask 077,
|
- { path: '/mnt/etc/systemd/journald.conf', content: Storage=persistent }
|
||||||
}
|
- { path: /mnt/etc/sudoers, content: Defaults logfile="/var/log/sudo.log" }
|
||||||
- {
|
|
||||||
path: '/mnt/etc/{{ "bashrc" if os in ["almalinux", "fedora", "rhel8", "rhel9", "rhel10", "rocky"] else "bash.bashrc" }}',
|
|
||||||
content: export TMOUT=3000,
|
|
||||||
}
|
|
||||||
- {
|
|
||||||
path: '/mnt/{{ "usr/lib/systemd/journald.conf" if os == "fedora" else "etc/systemd/journald.conf" }}',
|
|
||||||
content: Storage=persistent,
|
|
||||||
}
|
|
||||||
- {
|
|
||||||
path: /mnt/etc/sudoers,
|
|
||||||
content: Defaults logfile="/var/log/sudo.log",
|
|
||||||
}
|
|
||||||
- { path: /mnt/etc/pam.d/su, content: auth required pam_wheel.so }
|
- { path: /mnt/etc/pam.d/su, content: auth required pam_wheel.so }
|
||||||
- {
|
- { path: '/mnt/etc/pam.d/system-auth',
|
||||||
path:
|
content: auth required pam_faillock.so onerr=fail audit silent deny=5 unlock_time=900 }
|
||||||
'/mnt/etc/{{ "pam.d/common-auth" if os in ["debian11", "debian12", "ubuntu", "ubuntu-lts"]
|
- { path: '/mnt/etc/pam.d/system-auth', content: account required pam_faillock.so }
|
||||||
else "authselect/system-auth" if os == "fedora" else "pam.d/system-auth" }}',
|
- { path: '/mnt/etc/pam.d/passwd',
|
||||||
content: auth required pam_faillock.so onerr=fail audit silent deny=5 unlock_time=900,
|
content: "password [success=1 default=ignore] pam_unix.so obscure sha512 remember=5" }
|
||||||
}
|
|
||||||
- {
|
|
||||||
path:
|
|
||||||
'/mnt/etc/{{ "pam.d/common-account" if os in ["debian11", "debian12", "ubuntu", "ubuntu-lts"] else "authselect/system-auth"
|
|
||||||
if os == "fedora" else "pam.d/system-auth" }}',
|
|
||||||
content: account required pam_faillock.so,
|
|
||||||
}
|
|
||||||
- {
|
|
||||||
path: '/mnt/etc/pam.d/{{ "common-password" if os in ["debian11", "debian12", "ubuntu", "ubuntu-lts"] else "passwd" }}',
|
|
||||||
content: "password [success=1 default=ignore] pam_unix.so obscure sha512 remember=5",
|
|
||||||
}
|
|
||||||
- { path: /mnt/etc/hosts.deny, content: "ALL: ALL" }
|
- { path: /mnt/etc/hosts.deny, content: "ALL: ALL" }
|
||||||
- { path: /mnt/etc/hosts.allow, content: "sshd: ALL" }
|
- { path: /mnt/etc/hosts.allow, content: "sshd: ALL" }
|
||||||
|
|
||||||
@@ -188,10 +120,10 @@
|
|||||||
{ "path": "/mnt/etc/cron.d", "mode": "0700" },
|
{ "path": "/mnt/etc/cron.d", "mode": "0700" },
|
||||||
{ "path": "/mnt/etc/crontab", "mode": "0600" },
|
{ "path": "/mnt/etc/crontab", "mode": "0600" },
|
||||||
{ "path": "/mnt/etc/logrotate.conf", "mode": "0644" },
|
{ "path": "/mnt/etc/logrotate.conf", "mode": "0644" },
|
||||||
{ "path": "/mnt/usr/sbin/pppd", "mode": "0754" } if os not in ["rhel8", "rhel9", "rhel10"] else None,
|
{ "path": "/mnt/usr/sbin/pppd", "mode": "0754" },
|
||||||
{ "path": "/mnt/usr/bin/" + ("fusermount3" if os in ["almalinux", "archlinux", "debian12", "fedora", "rhel9", "rhel10", "rocky"]
|
{ "path": "/mnt/usr/bin/" + ("fusermount3" if os in ["rhel9"]
|
||||||
else "fusermount"), "mode": "755" },
|
else "fusermount"), "mode": "755" },
|
||||||
{ "path": "/mnt/usr/bin/" + ("write.ul" if os == "debian11" else "write"), "mode": "755" }
|
{ "path": "/mnt/usr/bin/write", "mode": "755" }
|
||||||
] | reject("none") }}
|
] | reject("none") }}
|
||||||
|
|
||||||
- name: Adjust SSHD config
|
- name: Adjust SSHD config
|
||||||
@@ -221,7 +153,7 @@
|
|||||||
- { option: X11Forwarding, value: "no" }
|
- { option: X11Forwarding, value: "no" }
|
||||||
- { option: PermitUserEnvironment, value: "no" }
|
- { option: PermitUserEnvironment, value: "no" }
|
||||||
- { option: ClientAliveInterval, value: "300" }
|
- { option: ClientAliveInterval, value: "300" }
|
||||||
- { option: ClientAliveCountMax, value: "1" }
|
- { option: ClientAliveCountMax, value: "0" }
|
||||||
- { option: PermitTunnel, value: "no" }
|
- { option: PermitTunnel, value: "no" }
|
||||||
- { option: Banner, value: /etc/issue.net }
|
- { option: Banner, value: /etc/issue.net }
|
||||||
|
|
||||||
@@ -235,10 +167,9 @@
|
|||||||
|
|
||||||
### Ciphers and keying ###
|
### Ciphers and keying ###
|
||||||
RekeyLimit 512M 6h
|
RekeyLimit 512M 6h
|
||||||
KexAlgorithms mlkem768x25519-sha256,curve25519-sha256@libssh.org,ecdh-sha2-nistp521,ecdh-sha2-nistp384,ecdh-sha2-nistp256
|
KexAlgorithms curve25519-sha256,curve25519-sha256@libssh.org,diffie-hellman-group14-sha256,diffie-hellman-group16-sha512,diffie-hellman-group18-sha512,ecdh-sha2-nistp521,ecdh-sha2-nistp384,ecdh-sha2-nistp256,diffie-hellman-group-exchange-sha256
|
||||||
Ciphers aes256-gcm@openssh.com,aes128-gcm@openssh.com,aes256-ctr,aes192-ctr,aes128-ctr
|
Ciphers chacha20-poly1305@openssh.com,aes256-gcm@openssh.com,aes128-gcm@openssh.com,aes256-ctr,aes192-ctr,aes128-ctr
|
||||||
MACs hmac-sha2-512-etm@openssh.com,hmac-sha2-256-etm@openssh.com,umac-128-etm@openssh.com
|
MACs hmac-sha2-512-etm@openssh.com,hmac-sha2-256-etm@openssh.com,hmac-sha2-512,hmac-sha2-256
|
||||||
|
|
||||||
###########################
|
###########################
|
||||||
|
|
||||||
AllowStreamLocalForwarding no
|
AllowStreamLocalForwarding no
|
||||||
|
|||||||
@@ -1,62 +1,10 @@
|
|||||||
---
|
---
|
||||||
- name: Unmount Disks
|
|
||||||
vars:
|
|
||||||
ansible_connection: ssh
|
|
||||||
block:
|
|
||||||
- name: Disable Swap
|
|
||||||
ansible.builtin.command: swapoff -a
|
|
||||||
register: swapoff_result
|
|
||||||
changed_when: swapoff_result.rc == 0
|
|
||||||
|
|
||||||
- name: Unmount /mnt if mounted
|
|
||||||
ansible.builtin.command: umount -R /mnt
|
|
||||||
register: unmount_result
|
|
||||||
changed_when: unmount_result.rc == 0
|
|
||||||
|
|
||||||
- name: Verify /mnt is no longer mounted
|
|
||||||
ansible.builtin.command: grep ' /mnt ' /proc/mounts
|
|
||||||
register: verify_unmount
|
|
||||||
retries: 5
|
|
||||||
delay: 5
|
|
||||||
until: verify_unmount.rc != 0
|
|
||||||
when: unmount_result.rc == 0
|
|
||||||
changed_when: false
|
|
||||||
failed_when: verify_unmount.rc not in [0, 1]
|
|
||||||
|
|
||||||
- name: Shutdown the VM
|
- name: Shutdown the VM
|
||||||
community.general.shutdown:
|
community.general.shutdown:
|
||||||
vars:
|
vars:
|
||||||
ansible_connection: ssh
|
ansible_connection: ssh
|
||||||
|
|
||||||
- name: Setup Cleanup
|
|
||||||
when: hypervisor == "proxmox"
|
|
||||||
delegate_to: localhost
|
|
||||||
become: false
|
|
||||||
block:
|
|
||||||
- name: Cleanup Setup Disks
|
|
||||||
community.general.proxmox_disk:
|
|
||||||
api_host: "{{ hypervisor_url }}"
|
|
||||||
api_user: "{{ hypervisor_username }}"
|
|
||||||
api_password: "{{ hypervisor_password }}"
|
|
||||||
name: "{{ hostname }}"
|
|
||||||
vmid: "{{ vm_id }}"
|
|
||||||
disk: "{{ item }}"
|
|
||||||
state: absent
|
|
||||||
loop:
|
|
||||||
- ide0
|
|
||||||
- ide2
|
|
||||||
|
|
||||||
- name: Start the VM
|
|
||||||
community.general.proxmox_kvm:
|
|
||||||
api_host: "{{ hypervisor_url }}"
|
|
||||||
api_user: "{{ hypervisor_username }}"
|
|
||||||
api_password: "{{ hypervisor_password }}"
|
|
||||||
node: "{{ hypervisor_node }}"
|
|
||||||
vmid: "{{ vm_id }}"
|
|
||||||
state: restarted
|
|
||||||
|
|
||||||
- name: Clean vCenter VM
|
- name: Clean vCenter VM
|
||||||
when: hypervisor == "vmware"
|
|
||||||
delegate_to: localhost
|
delegate_to: localhost
|
||||||
become: false
|
become: false
|
||||||
block:
|
block:
|
||||||
@@ -94,39 +42,3 @@
|
|||||||
datacenter: "{{ hypervisor_cluster }}"
|
datacenter: "{{ hypervisor_cluster }}"
|
||||||
name: "{{ hostname }}"
|
name: "{{ hostname }}"
|
||||||
state: powered-on
|
state: powered-on
|
||||||
|
|
||||||
- name: Remove Archiso and cloud-init disks
|
|
||||||
when: hypervisor == "libvirt"
|
|
||||||
delegate_to: localhost
|
|
||||||
become: false
|
|
||||||
block:
|
|
||||||
- name: Remove cloud-init disk
|
|
||||||
ansible.builtin.file:
|
|
||||||
path: "{{ vm_path | default('/var/lib/libvirt/images/') }}{{ hostname }}-cloudinit.iso"
|
|
||||||
state: absent
|
|
||||||
|
|
||||||
- name: Get list of CD-ROM devices
|
|
||||||
ansible.builtin.shell: set -o pipefail && virsh --connect qemu:///system domblklist {{ hostname }} --details | grep 'cdrom' | awk '{print $3}'
|
|
||||||
changed_when: false
|
|
||||||
register: cdrom_devices
|
|
||||||
|
|
||||||
- name: Wait for VM to spin down
|
|
||||||
ansible.builtin.wait_for:
|
|
||||||
timeout: 15
|
|
||||||
|
|
||||||
- name: Remove CD-ROM devices
|
|
||||||
when: cdrom_devices.stdout_lines | length > 0
|
|
||||||
ansible.builtin.command: virsh --connect qemu:///system detach-disk {{ hostname }} {{ item }} --persistent
|
|
||||||
with_items: "{{ cdrom_devices.stdout_lines | select('ne', 'sdc') | list }}"
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
|
|
||||||
- name: Start the VM
|
|
||||||
community.libvirt.virt:
|
|
||||||
name: "{{ hostname }}"
|
|
||||||
state: running
|
|
||||||
|
|
||||||
- name: Wait for VM to boot up
|
|
||||||
delegate_to: "{{ inventory_hostname }}"
|
|
||||||
ansible.builtin.wait_for_connection:
|
|
||||||
timeout: 300
|
|
||||||
|
|||||||
@@ -6,26 +6,17 @@
|
|||||||
changed_when: result.rc == 0
|
changed_when: result.rc == 0
|
||||||
register: result
|
register: result
|
||||||
|
|
||||||
- name: Remove depricated attr2 and disable large extent
|
|
||||||
when: os in ["almalinux", "rhel8", "rhel9", "rhel10", "rocky"] and filesystem == "xfs"
|
|
||||||
ansible.builtin.replace:
|
|
||||||
path: /mnt/etc/fstab
|
|
||||||
regexp: "(xfs.*?)(attr2)"
|
|
||||||
replace: '\1allocsize=64m'
|
|
||||||
|
|
||||||
- name: Replace ISO UUID entry with /dev/sr0 in fstab
|
- name: Replace ISO UUID entry with /dev/sr0 in fstab
|
||||||
when: os in ["rhel8", "rhel9", "rhel10"]
|
when: os in ["rhel8", "rhel9"]
|
||||||
ansible.builtin.lineinfile:
|
ansible.builtin.lineinfile:
|
||||||
path: /mnt/etc/fstab
|
path: /mnt/etc/fstab
|
||||||
regexp: '^.*\/dvd.*$'
|
regexp: '^.*\/dvd.*$'
|
||||||
line:
|
line: "{{ '/usr/local/install/redhat/rhel.iso /usr/local/install/redhat/dvd iso9660 loop,nofail 0 0' if hypervisor == 'vmware'
|
||||||
"{{ '/usr/local/install/redhat/rhel.iso /usr/local/install/redhat/dvd iso9660 loop,nofail 0 0' if hypervisor == 'vmware'
|
|
||||||
else '/dev/sr0 /usr/local/install/redhat/dvd iso9660 ro,relatime,nojoliet,check=s,map=n,nofail 0 0' }}"
|
else '/dev/sr0 /usr/local/install/redhat/dvd iso9660 ro,relatime,nojoliet,check=s,map=n,nofail 0 0' }}"
|
||||||
state: present
|
state: present
|
||||||
backrefs: true
|
backrefs: true
|
||||||
|
|
||||||
- name: Write image from RHEL ISO to the target machine
|
- name: Write image from RHEL ISO to the target machine
|
||||||
when: os in ["rhel8", "rhel9", "rhel10"] and hypervisor == 'vmware'
|
|
||||||
ansible.builtin.command: dd if=/dev/sr1 of=/mnt/usr/local/install/redhat/rhel.iso bs=4M
|
ansible.builtin.command: dd if=/dev/sr1 of=/mnt/usr/local/install/redhat/rhel.iso bs=4M
|
||||||
changed_when: result.rc == 0
|
changed_when: result.rc == 0
|
||||||
register: result
|
register: result
|
||||||
@@ -40,7 +31,7 @@
|
|||||||
- "# TempFS"
|
- "# TempFS"
|
||||||
- tmpfs /tmp tmpfs defaults,nosuid,nodev,noexec 0 0
|
- tmpfs /tmp tmpfs defaults,nosuid,nodev,noexec 0 0
|
||||||
- tmpfs /var/tmp tmpfs defaults,nosuid,nodev,noexec 0 0
|
- tmpfs /var/tmp tmpfs defaults,nosuid,nodev,noexec 0 0
|
||||||
- tmpfs /dev/shm tmpfs defaults,nosuid,nodev,noexec 0 0
|
- tmpfs /dev/shm tmpfs defaults,noexec 0 0
|
||||||
|
|
||||||
- name: Set local timezone
|
- name: Set local timezone
|
||||||
ansible.builtin.command: "{{ item }}"
|
ansible.builtin.command: "{{ item }}"
|
||||||
@@ -52,44 +43,29 @@
|
|||||||
|
|
||||||
- name: Setup locales
|
- name: Setup locales
|
||||||
block:
|
block:
|
||||||
- name: Configure locale.gen
|
|
||||||
when: os | lower not in ['almalinux', 'fedora', 'rhel8', 'rhel9', 'rhel10', 'rocky']
|
|
||||||
ansible.builtin.lineinfile:
|
|
||||||
dest: /mnt/etc/locale.gen
|
|
||||||
regexp: "{{ item.regex }}"
|
|
||||||
line: "{{ item.line }}"
|
|
||||||
loop:
|
|
||||||
- { regex: en_US\.UTF-8 UTF-8, line: en_US.UTF-8 UTF-8 }
|
|
||||||
|
|
||||||
- name: Generate locales
|
|
||||||
when: os | lower not in ['almalinux', 'fedora', 'rhel8', 'rhel9', 'rhel10', 'rocky']
|
|
||||||
ansible.builtin.command: arch-chroot /mnt /usr/sbin/locale-gen
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
|
|
||||||
- name: Set hostname
|
- name: Set hostname
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
content: "{{ hostname }}{% if vm_dns_search is defined and vm_dns_search | length %}.{{ vm_dns_search }}{% endif %}"
|
content: "{{ hostname }}"
|
||||||
dest: /mnt/etc/hostname
|
dest: /mnt/etc/hostname
|
||||||
mode: "0644"
|
mode: '0644'
|
||||||
|
|
||||||
- name: Add host entry to /etc/hosts
|
- name: Add host entry to /etc/hosts
|
||||||
ansible.builtin.lineinfile:
|
ansible.builtin.lineinfile:
|
||||||
path: /mnt/etc/hosts
|
path: /mnt/etc/hosts
|
||||||
line: "{{ ansible_host }} {{ hostname }}{% if vm_dns_search is defined and vm_dns_search | length %} {{ hostname }}.{{ vm_dns_search }}{% endif %}"
|
line: "{{ ansible_host }} {{ hostname }}"
|
||||||
state: present
|
state: present
|
||||||
|
|
||||||
- name: Create vconsole.conf
|
- name: Create vconsole.conf
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
content: KEYMAP=us
|
content: KEYMAP=us
|
||||||
dest: /mnt/etc/vconsole.conf
|
dest: /mnt/etc/vconsole.conf
|
||||||
mode: "0644"
|
mode: '0644'
|
||||||
|
|
||||||
- name: Create locale.conf
|
- name: Create locale.conf
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
content: LANG=en_US.UTF-8
|
content: LANG=en_US.UTF-8
|
||||||
dest: /mnt/etc/locale.conf
|
dest: /mnt/etc/locale.conf
|
||||||
mode: "0644"
|
mode: '0644'
|
||||||
|
|
||||||
- name: SSH permit Password
|
- name: SSH permit Password
|
||||||
ansible.builtin.replace:
|
ansible.builtin.replace:
|
||||||
@@ -104,71 +80,27 @@
|
|||||||
replace: "PermitRootLogin yes"
|
replace: "PermitRootLogin yes"
|
||||||
|
|
||||||
- name: Enable Systemd Services
|
- name: Enable Systemd Services
|
||||||
ansible.builtin.command: >
|
ansible.builtin.command: arch-chroot /mnt systemctl enable NetworkManager sshd
|
||||||
arch-chroot /mnt systemctl enable NetworkManager
|
|
||||||
{{
|
|
||||||
' ssh' if os | lower in ['ubuntu', 'ubuntu-lts'] else
|
|
||||||
(' sshd' if os | lower not in ['debian11', 'debian12', 'debian13'] else '')
|
|
||||||
}}
|
|
||||||
{{
|
|
||||||
'logrotate systemd-resolved systemd-timesyncd systemd-networkd'
|
|
||||||
if os | lower == 'archlinux' else ''
|
|
||||||
}}
|
|
||||||
changed_when: result.rc == 0
|
changed_when: result.rc == 0
|
||||||
register: result
|
register: result
|
||||||
|
|
||||||
- name: Configure grub
|
|
||||||
when: os | lower not in ['almalinux', 'fedora', 'rhel8', 'rhel9', 'rhel10', 'rocky']
|
|
||||||
block:
|
|
||||||
- name: Add commandline information to grub config
|
|
||||||
ansible.builtin.lineinfile:
|
|
||||||
dest: /mnt/etc/default/grub
|
|
||||||
regexp: ^GRUB_CMDLINE_LINUX_DEFAULT=
|
|
||||||
line: GRUB_CMDLINE_LINUX_DEFAULT="loglevel=3"
|
|
||||||
|
|
||||||
- name: Change Grub time
|
|
||||||
ansible.builtin.lineinfile:
|
|
||||||
dest: /mnt/etc/default/grub
|
|
||||||
regexp: ^GRUB_TIMEOUT=
|
|
||||||
line: GRUB_TIMEOUT=1
|
|
||||||
|
|
||||||
- name: Configure Bootloader
|
- name: Configure Bootloader
|
||||||
block:
|
block:
|
||||||
- name: Install Bootloader
|
- name: Install Bootloader
|
||||||
ansible.builtin.command: arch-chroot /mnt
|
ansible.builtin.command: arch-chroot /mnt /usr/sbin/efibootmgr -c -L '{{ os }}'
|
||||||
{% if os | lower not in ["archlinux", "debian11", "debian12", "debian13", "ubuntu", "ubuntu-lts"] %} /usr/sbin/efibootmgr
|
-d "{{ install_drive }}" -p 1
|
||||||
-c -L '{{ os }}' -d "{{ install_drive }}" -p 1
|
-l '\efi\EFI\redhat\shimx64.efi'
|
||||||
-l '\efi\EFI\{% if os | lower in ["rhel8", "rhel9", "rhel10"] %}redhat{% else %}{{ os | lower }}{% endif %}\shimx64.efi'
|
|
||||||
{% else %}/usr/sbin/grub-install --target=x86_64-efi --efi-directory={{ "/boot/efi" if os | lower in ["ubuntu", "ubuntu-lts"] else "/boot" }}
|
|
||||||
--bootloader-id={{ "ubuntu" if os | lower in ["ubuntu", "ubuntu-lts"] else os }}
|
|
||||||
{% endif %}
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
|
|
||||||
- name: Ensure lvm2 for non btrfs filesystems
|
|
||||||
when: os | lower == "archlinux" and filesystem != "btrfs"
|
|
||||||
ansible.builtin.lineinfile:
|
|
||||||
path: /mnt/etc/mkinitcpio.conf
|
|
||||||
regexp: "^(HOOKS=.*block)(?!.*lvm2)(.*)"
|
|
||||||
line: '\1 lvm2\2'
|
|
||||||
backrefs: true
|
|
||||||
|
|
||||||
- name: Regenerate initramfs
|
|
||||||
when: os | lower not in ["debian11", "debian12", "debian13", "ubuntu", "ubuntu-lts"]
|
|
||||||
ansible.builtin.command: arch-chroot /mnt
|
|
||||||
{% if os | lower == "archlinux" %} /usr/sbin/mkinitcpio -P
|
|
||||||
{% else %} /usr/bin/dracut --regenerate-all --force
|
|
||||||
{% endif %}
|
|
||||||
changed_when: result.rc == 0
|
changed_when: result.rc == 0
|
||||||
register: result
|
register: result
|
||||||
|
|
||||||
- name: Generate grub config
|
- name: Generate grub config
|
||||||
ansible.builtin.command: arch-chroot /mnt
|
ansible.builtin.command: arch-chroot /mnt /usr/sbin/grub2-mkconfig -o /boot/efi/EFI/redhat/grub.cfg
|
||||||
{% if os | lower not in ["archlinux", "debian11", "debian12", "debian13", "ubuntu", "ubuntu-lts"] %}
|
changed_when: result.rc == 0
|
||||||
/usr/sbin/grub2-mkconfig -o /boot/efi/EFI/{% if os | lower in ["rhel8", "rhel9", "rhel10"] %}redhat{% else %}{{ os | lower }}{% endif %}/grub.cfg
|
register: result
|
||||||
{% else %}
|
|
||||||
/usr/sbin/grub-mkconfig -o {{ "/boot/efi/EFI/ubuntu/grub.cfg" if os | lower in ["ubuntu", "ubuntu-lts"] else "/boot/grub/grub.cfg" }}
|
- name: Regenerate initramfs
|
||||||
{% endif %}
|
when: os | lower not in ["debian11", "debian12", "ubuntu", "ubuntu-lts"]
|
||||||
|
ansible.builtin.command: arch-chroot /mnt /usr/bin/dracut --regenerate-all --force
|
||||||
changed_when: result.rc == 0
|
changed_when: result.rc == 0
|
||||||
register: result
|
register: result
|
||||||
|
|
||||||
@@ -177,9 +109,7 @@
|
|||||||
- name: Append vim configurations to vimrc
|
- name: Append vim configurations to vimrc
|
||||||
failed_when: false
|
failed_when: false
|
||||||
ansible.builtin.blockinfile:
|
ansible.builtin.blockinfile:
|
||||||
path:
|
path: "/mnt/etc/vimrc"
|
||||||
"{{ '/mnt/etc/vim/vimrc' if os | lower in ['debian11', 'debian12', 'debian13', 'ubuntu', 'ubuntu-lts']
|
|
||||||
else '/mnt/etc/vimrc' }}"
|
|
||||||
block: |
|
block: |
|
||||||
set encoding=utf-8
|
set encoding=utf-8
|
||||||
set number
|
set number
|
||||||
@@ -200,10 +130,10 @@
|
|||||||
vm.dirty_ratio=10
|
vm.dirty_ratio=10
|
||||||
vm.page-cluster=10
|
vm.page-cluster=10
|
||||||
marker: ""
|
marker: ""
|
||||||
mode: "0644"
|
mode: '0644'
|
||||||
|
|
||||||
- name: Create zram config
|
- name: Create zram config
|
||||||
when: os not in ['debian11', 'rhel8']
|
when: os not in ['rhel8']
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
dest: /mnt/etc/systemd/zram-generator.conf
|
dest: /mnt/etc/systemd/zram-generator.conf
|
||||||
content: |
|
content: |
|
||||||
@@ -212,38 +142,19 @@
|
|||||||
compression-algorithm = zstd
|
compression-algorithm = zstd
|
||||||
swap-priority = 100
|
swap-priority = 100
|
||||||
fs-type = swap
|
fs-type = swap
|
||||||
mode: "0644"
|
mode: '0644'
|
||||||
|
|
||||||
|
- name: Copy FirstRun Script
|
||||||
|
ansible.builtin.template:
|
||||||
|
src: firstrun.sh.j2
|
||||||
|
dest: /mnt/root/firstrun.sh
|
||||||
|
mode: "0755"
|
||||||
|
|
||||||
- name: Copy Custom Shell config
|
- name: Copy Custom Shell config
|
||||||
ansible.builtin.template:
|
ansible.builtin.template:
|
||||||
src: custom.sh.j2
|
src: custom.sh.j2
|
||||||
dest: /mnt/etc/profile.d/custom.sh
|
dest: /mnt/etc/profile.d/custom.sh
|
||||||
mode: "0644"
|
mode: '0644'
|
||||||
|
|
||||||
- name: Create login banner
|
|
||||||
ansible.builtin.copy:
|
|
||||||
dest: "{{ item }}"
|
|
||||||
content: |
|
|
||||||
**************************************************************
|
|
||||||
* WARNING: Unauthorized access to this system is prohibited. *
|
|
||||||
* All activities are monitored and logged. *
|
|
||||||
* Disconnect immediately if you are not an authorized user. *
|
|
||||||
**************************************************************
|
|
||||||
owner: root
|
|
||||||
group: root
|
|
||||||
mode: "0644"
|
|
||||||
loop:
|
|
||||||
- /mnt/etc/issue
|
|
||||||
- /etc/issue.net
|
|
||||||
|
|
||||||
- name: Remove motd files
|
|
||||||
when: os | lower in ["rhel8", "rhel9", "rhel10"]
|
|
||||||
ansible.builtin.file:
|
|
||||||
path: "{{ item }}"
|
|
||||||
state: absent
|
|
||||||
loop:
|
|
||||||
- /etc/motd.d/cockpit
|
|
||||||
- /etc/motd.d/insights-client
|
|
||||||
|
|
||||||
- name: Setup Network
|
- name: Setup Network
|
||||||
block:
|
block:
|
||||||
@@ -268,20 +179,12 @@
|
|||||||
dest: /mnt/etc/NetworkManager/system-connections/LAN.nmconnection
|
dest: /mnt/etc/NetworkManager/system-connections/LAN.nmconnection
|
||||||
mode: "0600"
|
mode: "0600"
|
||||||
|
|
||||||
- name: Fix Ubuntu unmanaged devices
|
|
||||||
when: os | lower in ["ubuntu", "ubuntu-lts"]
|
|
||||||
ansible.builtin.file:
|
|
||||||
path: /mnt/etc/NetworkManager/conf.d/10-globally-managed-devices.conf
|
|
||||||
state: touch
|
|
||||||
mode: "0644"
|
|
||||||
|
|
||||||
- name: Setup user account
|
- name: Setup user account
|
||||||
block:
|
block:
|
||||||
- name: Create user account
|
- name: Create user account
|
||||||
ansible.builtin.command: "{{ item }}"
|
ansible.builtin.command: "{{ item }}"
|
||||||
with_items:
|
with_items:
|
||||||
- arch-chroot /mnt /usr/sbin/useradd --create-home --user-group --groups
|
- arch-chroot /mnt /usr/sbin/useradd --create-home --user-group --groups wheel
|
||||||
{{ "sudo" if os | lower in ["debian11", "debian12", "debian13", "ubuntu", "ubuntu-lts"] else "wheel" }}
|
|
||||||
{{ user_name }} --password {{ user_password | password_hash('sha512') }} --shell /bin/bash
|
{{ user_name }} --password {{ user_password | password_hash('sha512') }} --shell /bin/bash
|
||||||
- arch-chroot /mnt /usr/sbin/usermod --password '{{ root_password | password_hash('sha512') }}' root --shell /bin/bash
|
- arch-chroot /mnt /usr/sbin/usermod --password '{{ root_password | password_hash('sha512') }}' root --shell /bin/bash
|
||||||
changed_when: result.rc == 0
|
changed_when: result.rc == 0
|
||||||
@@ -299,26 +202,12 @@
|
|||||||
|
|
||||||
- name: Give sudo access to wheel group
|
- name: Give sudo access to wheel group
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
content: "{{ '%sudo ALL=(ALL) ALL' if os | lower in ['debian11', 'debian12', 'debian13', 'ubuntu', 'ubuntu-lts'] else '%wheel ALL=(ALL) ALL' }}"
|
content: "%wheel ALL=(ALL) ALL"
|
||||||
dest: /mnt/etc/sudoers.d/01-wheel
|
dest: /mnt/etc/sudoers.d/01-wheel
|
||||||
mode: "0440"
|
mode: "0440"
|
||||||
validate: /usr/sbin/visudo --check --file=%s
|
validate: /usr/sbin/visudo --check --file=%s
|
||||||
|
|
||||||
- name: Fix SELinux
|
- name: Fix SELinux
|
||||||
when: os | lower in ['almalinux', 'fedora', 'rhel8', 'rhel9', 'rhel10', 'rocky']
|
ansible.builtin.command: "arch-chroot /mnt /sbin/fixfiles onboot"
|
||||||
block:
|
changed_when: result.rc == 0
|
||||||
- name: Fix SELinux by pre-labeling the filesystem before first boot
|
register: result
|
||||||
when: os | lower in ['almalinux', 'rhel8', 'rhel9', 'rhel10', 'rocky'] and (selinux | default(true) | bool)
|
|
||||||
ansible.builtin.command: >
|
|
||||||
arch-chroot /mnt /sbin/setfiles -v -F
|
|
||||||
-e /dev -e /proc -e /sys -e /run
|
|
||||||
/etc/selinux/targeted/contexts/files/file_contexts /
|
|
||||||
register: setfiles_result
|
|
||||||
changed_when: setfiles_result.rc == 0
|
|
||||||
|
|
||||||
- name: Disable SELinux
|
|
||||||
when: os | lower == "fedora" or not (selinux | default(true) | bool)
|
|
||||||
ansible.builtin.lineinfile:
|
|
||||||
path: /mnt/etc/selinux/config
|
|
||||||
regexp: ^SELINUX=
|
|
||||||
line: SELINUX=permissive
|
|
||||||
|
|||||||
@@ -2,16 +2,14 @@
|
|||||||
id=LAN
|
id=LAN
|
||||||
uuid={{ net_uuid.stdout }}
|
uuid={{ net_uuid.stdout }}
|
||||||
type=ethernet
|
type=ethernet
|
||||||
|
interface-name={{ net_inf.stdout }}
|
||||||
|
|
||||||
[ethernet]
|
[ethernet]
|
||||||
mac-address={{ net_mac.stdout }}
|
mac-address={{ net_mac.stdout }}
|
||||||
|
|
||||||
[ipv4]
|
[ipv4]
|
||||||
address={{ vm_ip }}/{{ vm_nms | default (24) }},{{ vm_gw }}
|
address={{ vm_ip }},{{ vm_gw }}
|
||||||
dns={{ vm_dns }}
|
dns={{ vm_dns }}
|
||||||
{% if vm_dns_search is defined %}
|
|
||||||
dns-search={{ vm_dns_search }}
|
|
||||||
{% endif %}
|
|
||||||
method=manual
|
method=manual
|
||||||
|
|
||||||
[ipv6]
|
[ipv6]
|
||||||
|
|||||||
@@ -20,20 +20,17 @@
|
|||||||
msg: This host is not booted from the Arch install media!
|
msg: This host is not booted from the Arch install media!
|
||||||
when: not archiso_stat.stat.exists
|
when: not archiso_stat.stat.exists
|
||||||
|
|
||||||
- name: Register Network Interface
|
- name: Setect Interface
|
||||||
when: hypervisor == "vmware"
|
|
||||||
ansible.builtin.shell: "set -o pipefail && ip l | awk -F': ' '!/lo/{print $2; exit}'"
|
ansible.builtin.shell: "set -o pipefail && ip l | awk -F': ' '!/lo/{print $2; exit}'"
|
||||||
changed_when: interface_name.rc == 0
|
changed_when: interface_name.rc == 0
|
||||||
register: interface_name
|
register: interface_name
|
||||||
|
|
||||||
- name: Set IP-Address
|
- name: Set IP-Address
|
||||||
when: hypervisor == "vmware"
|
|
||||||
ansible.builtin.command: "ip addr replace {{ ansible_host }}/{{ vm_nms | default(24) }} dev {{ interface_name.stdout }}"
|
ansible.builtin.command: "ip addr replace {{ ansible_host }}/{{ vm_nms | default(24) }} dev {{ interface_name.stdout }}"
|
||||||
changed_when: result.rc == 0
|
changed_when: result.rc == 0
|
||||||
register: result
|
register: result
|
||||||
|
|
||||||
- name: Set Default Gateway
|
- name: Set Default Gateway
|
||||||
when: hypervisor == "vmware"
|
|
||||||
ansible.builtin.command: "ip route replace default via {{ vm_gw }}"
|
ansible.builtin.command: "ip route replace default via {{ vm_gw }}"
|
||||||
changed_when: result.rc == 0
|
changed_when: result.rc == 0
|
||||||
register: result
|
register: result
|
||||||
@@ -44,7 +41,7 @@
|
|||||||
register: result
|
register: result
|
||||||
|
|
||||||
- name: Configure SSH for root login
|
- name: Configure SSH for root login
|
||||||
when: hypervisor == "vmware" and (vmware_ssh is defined and vmware_ssh | bool)
|
when: vmware_ssh | bool
|
||||||
block:
|
block:
|
||||||
- name: Allow empty passwords temporarily
|
- name: Allow empty passwords temporarily
|
||||||
ansible.builtin.replace:
|
ansible.builtin.replace:
|
||||||
@@ -69,7 +66,7 @@
|
|||||||
ansible_user: "root"
|
ansible_user: "root"
|
||||||
ansible_password: ""
|
ansible_password: ""
|
||||||
ansible_become_password: ""
|
ansible_become_password: ""
|
||||||
ansible_ssh_extra_args: "-o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no"
|
ansible_ssh_extra_args: '-o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no'
|
||||||
|
|
||||||
- name: Speed-up Bootstrap process
|
- name: Speed-up Bootstrap process
|
||||||
ansible.builtin.lineinfile:
|
ansible.builtin.lineinfile:
|
||||||
@@ -85,46 +82,41 @@
|
|||||||
community.general.pacman:
|
community.general.pacman:
|
||||||
update_cache: true
|
update_cache: true
|
||||||
force: true
|
force: true
|
||||||
name: "{{ item.name }}"
|
name: "{{ item }}"
|
||||||
state: latest
|
state: latest
|
||||||
loop:
|
loop:
|
||||||
- { name: glibc }
|
- glibc
|
||||||
- { name: dnf, os: [almalinux, fedora, rhel8, rhel9, rhel10, rocky] }
|
- dnf
|
||||||
- { name: debootstrap, os: [debian11, debian12, debian13, ubuntu, ubuntu-lts] }
|
|
||||||
- { name: debian-archive-keyring, os: [debian11, debian12, debian13] }
|
|
||||||
- { name: ubuntu-keyring, os: [ubuntu, ubuntu-lts] }
|
|
||||||
when: "'os' not in item or os in item.os"
|
|
||||||
retries: 4
|
retries: 4
|
||||||
delay: 15
|
delay: 15
|
||||||
|
|
||||||
- name: Prepare /iso mount and repository for RHEL-based systems
|
- name: Prepare /iso mount and repository for RHEL-based systems
|
||||||
when: os | lower in ["rhel8", "rhel9", "rhel10"]
|
when: os | lower in ["rhel8", "rhel9"]
|
||||||
block:
|
block:
|
||||||
- name: Create /iso directory
|
- name: Create /iso directory
|
||||||
ansible.builtin.file:
|
ansible.builtin.file:
|
||||||
path: /usr/local/install/redhat/dvd
|
path: /usr/local/install/redhat/dvd
|
||||||
state: directory
|
state: directory
|
||||||
mode: "0755"
|
mode: '0755'
|
||||||
|
|
||||||
- name: Mount RHEL ISO
|
- name: Mount RHEL ISO
|
||||||
ansible.posix.mount:
|
ansible.posix.mount:
|
||||||
src: "{{ '/dev/sr1' if hypervisor == 'vmware' else '/dev/sr2' }}"
|
src: "/dev/sr1"
|
||||||
path: /usr/local/install/redhat/dvd
|
path: /usr/local/install/redhat/dvd
|
||||||
fstype: iso9660
|
fstype: iso9660
|
||||||
opts: "ro,loop"
|
opts: "ro,loop"
|
||||||
state: mounted
|
state: mounted
|
||||||
|
|
||||||
- name: Configure RHEL Repos for installation
|
- name: Configure RHEL Repos for installation
|
||||||
when: os | lower in ["almalinux", "fedora", "rhel8", "rhel9", "rhel10", "rocky"]
|
|
||||||
block:
|
block:
|
||||||
- name: Create directories for repository files and RPM GPG keys
|
- name: Create directories for repository files and RPM GPG keys
|
||||||
ansible.builtin.file:
|
ansible.builtin.file:
|
||||||
path: /etc/yum.repos.d
|
path: /etc/yum.repos.d
|
||||||
state: directory
|
state: directory
|
||||||
mode: "0755"
|
mode: '0755'
|
||||||
|
|
||||||
- name: Create RHEL repository file
|
- name: Create RHEL repository file
|
||||||
ansible.builtin.template:
|
ansible.builtin.template:
|
||||||
src: "{{ os | lower }}.repo.j2"
|
src: "{{ os | lower }}.repo.j2"
|
||||||
dest: /etc/yum.repos.d/{{ os | lower }}.repo
|
dest: /etc/yum.repos.d/{{ os | lower }}.repo
|
||||||
mode: "0644"
|
mode: '0644'
|
||||||
|
|||||||
@@ -1,56 +0,0 @@
|
|||||||
---
|
|
||||||
- name: Setup BTRFS
|
|
||||||
block:
|
|
||||||
- name: Create btrfs filesystem in main volume
|
|
||||||
community.general.filesystem:
|
|
||||||
dev: "{{ install_drive }}{{ main_partition_suffix }}"
|
|
||||||
fstype: btrfs
|
|
||||||
force: true
|
|
||||||
|
|
||||||
- name: Prepare BTRFS Subvolume
|
|
||||||
ansible.posix.mount:
|
|
||||||
path: /mnt
|
|
||||||
src: "{{ install_drive }}{{ main_partition_suffix }}"
|
|
||||||
fstype: btrfs
|
|
||||||
opts: rw,relatime,compress=zstd:15,ssd,space_cache=v2,discard=async
|
|
||||||
state: mounted
|
|
||||||
|
|
||||||
- name: Enable quotas on Btrfs filesystem
|
|
||||||
ansible.builtin.command: btrfs quota enable /mnt
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
|
|
||||||
- name: Make root subvolumes
|
|
||||||
when: cis | bool or item.subvol not in ['var_log_audit']
|
|
||||||
ansible.builtin.command: btrfs su cr /mnt/{{ '@' if item.subvol == 'root' else '@' + item.subvol }}
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
loop:
|
|
||||||
- { subvol: root }
|
|
||||||
- { subvol: swap }
|
|
||||||
- { subvol: home }
|
|
||||||
- { subvol: var }
|
|
||||||
- { subvol: var_log }
|
|
||||||
- { subvol: var_log_audit }
|
|
||||||
|
|
||||||
- name: Set quotas for subvolumes
|
|
||||||
when: cis | bool or item.subvol not in ['var_log_audit']
|
|
||||||
ansible.builtin.command: btrfs qgroup limit {{ item.quota }} /mnt/{{ '@' if item.subvol == 'root' else '@' + item.subvol }}
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
loop:
|
|
||||||
- { subvol: home, quota: 2G }
|
|
||||||
|
|
||||||
- name: Create a Btrfs swap file
|
|
||||||
ansible.builtin.command: >-
|
|
||||||
btrfs filesystem mkswapfile --size {{ ((vm_memory | float / 1024 >= 16.0) | ternary((vm_memory
|
|
||||||
| float / 2048) | int, [vm_memory | float / 1024, 4.0] | max) | int) }}g --uuid clear /mnt/@swap/swapfile
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
|
|
||||||
- name: Unmount Partition
|
|
||||||
ansible.posix.mount:
|
|
||||||
path: /mnt
|
|
||||||
src: "{{ install_drive }}{{ main_partition_suffix }}"
|
|
||||||
fstype: btrfs
|
|
||||||
state: unmounted
|
|
||||||
@@ -11,15 +11,3 @@
|
|||||||
- { lv: var }
|
- { lv: var }
|
||||||
- { lv: var_log }
|
- { lv: var_log }
|
||||||
- { lv: var_log_audit }
|
- { lv: var_log_audit }
|
||||||
|
|
||||||
- name: Remove Unsupported features for older Systems
|
|
||||||
when: (os | lower in ['almalinux', 'debian11', 'rhel8', 'rhel9', 'rocky']) and (cis | bool or item.lv not in ['home', 'var', 'var_log', 'var_log_audit'])
|
|
||||||
ansible.builtin.command: tune2fs -O "^orphan_file,^metadata_csum_seed" "/dev/sys/{{ item.lv }}"
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
loop:
|
|
||||||
- { lv: root }
|
|
||||||
- { lv: home }
|
|
||||||
- { lv: var }
|
|
||||||
- { lv: var_log }
|
|
||||||
- { lv: var_log_audit }
|
|
||||||
|
|||||||
@@ -9,9 +9,7 @@
|
|||||||
loop:
|
loop:
|
||||||
- { cmd: umount -l /mnt }
|
- { cmd: umount -l /mnt }
|
||||||
- { cmd: vgremove -f sys }
|
- { cmd: vgremove -f sys }
|
||||||
- {
|
- { cmd: 'find /dev -wholename "{{ install_drive }}*" -exec wipefs --force --all {} \;' }
|
||||||
cmd: 'find /dev -wholename "{{ install_drive }}*" -exec wipefs --force --all {} \;',
|
|
||||||
}
|
|
||||||
loop_control:
|
loop_control:
|
||||||
label: "{{ item.cmd }}"
|
label: "{{ item.cmd }}"
|
||||||
|
|
||||||
@@ -30,7 +28,6 @@
|
|||||||
- { number: 2, part_start: 500MiB, name: root }
|
- { number: 2, part_start: 500MiB, name: root }
|
||||||
|
|
||||||
- name: Create LVM logical volumes
|
- name: Create LVM logical volumes
|
||||||
when: filesystem != 'btrfs'
|
|
||||||
block:
|
block:
|
||||||
- name: Create LVM volume group
|
- name: Create LVM volume group
|
||||||
community.general.lvg:
|
community.general.lvg:
|
||||||
@@ -47,25 +44,42 @@
|
|||||||
loop:
|
loop:
|
||||||
- lv: root
|
- lv: root
|
||||||
size: >-
|
size: >-
|
||||||
{{ [(((((vm_size | float) - 0.5 - ((cis | bool) | ternary(7.5, 0)) - (((vm_memory | float / 1024) > 16.0)
|
{{ (
|
||||||
| ternary(((vm_memory | float / 2048) | int), (vm_memory | float / 1024)))) < 4)
|
(vm_size | float -
|
||||||
| ternary(4,((((vm_size | float) - 0.5 - ((cis | bool) | ternary(7.5, 0)) -
|
((vm_memory | float / 1024 >= 16.0) | ternary(
|
||||||
(((vm_memory | float / 1024) > 16.0)| ternary(((vm_memory | float / 2048) | int), (vm_memory | float / 1024)))) > 12)
|
(vm_memory | float / 2048) | int,
|
||||||
| ternary(((vm_size | float) * 0.4) | round(0, 'ceil'),((vm_size | float) - 0.5 - ((cis | bool)
|
[vm_memory | float / 1024, 4.0] | max
|
||||||
| ternary(7.5, 0)) - (((vm_memory | float / 1024) > 16.0)
|
)) - 0.5 -
|
||||||
| ternary(((vm_memory | float / 2048) | int), (vm_memory | float / 1024))))))))), 4 ] | max | string + 'G' }}
|
(cis | bool | ternary(0, 7.5))
|
||||||
|
) > 12.0
|
||||||
|
) | ternary(
|
||||||
|
(vm_size | float * 0.4) | round(0, 'ceil'),
|
||||||
|
vm_size | float -
|
||||||
|
((vm_memory | float / 1024 >= 16.0) | ternary(
|
||||||
|
(vm_memory | float / 2048) | int,
|
||||||
|
[vm_memory | float / 1024, 4.0] | max
|
||||||
|
)) - 0.5 -
|
||||||
|
(cis | bool | ternary(7.5, 0))
|
||||||
|
) | string + 'G' }}
|
||||||
|
|
||||||
- lv: swap
|
- lv: swap
|
||||||
size: >-
|
size: >-
|
||||||
{{ ((((vm_size | float) - 0.5 - ((cis | bool) | ternary(7.5, 0))) - (((vm_memory | float / 1024) > 16.0)
|
{{ ((vm_memory | float / 1024 >= 16.0) | ternary(
|
||||||
| ternary(((vm_memory | float / 2048) | int), (vm_memory | float / 1024)))) < 4)
|
(vm_memory | float / 2048) | int,
|
||||||
| ternary((((vm_size | float) - 0.5 - ((cis | bool) | ternary(7.5, 0))) - 4), (((vm_memory | float / 1024) > 16.0)
|
[vm_memory | float / 1024, 4.0] | max
|
||||||
| ternary(((vm_memory | float / 2048) | int), (vm_memory | float / 1024)))) | string + 'G' }}
|
)) | string + 'G' }}
|
||||||
- lv: home
|
|
||||||
size: "{{ ([([(((vm_size | float) - 20) * 0.1), 2] | max), 20] | min) | string + 'G' }}"
|
|
||||||
|
|
||||||
- { lv: var, size: "2G" }
|
- lv: home
|
||||||
- { lv: var_log, size: "2G" }
|
size: "2G"
|
||||||
- { lv: var_log_audit, size: "1.5G" }
|
|
||||||
|
- lv: var
|
||||||
|
size: "2G"
|
||||||
|
|
||||||
|
- lv: var_log
|
||||||
|
size: "2G"
|
||||||
|
|
||||||
|
- lv: var_log_audit
|
||||||
|
size: "1.5G"
|
||||||
|
|
||||||
- name: Create filesystems
|
- name: Create filesystems
|
||||||
block:
|
block:
|
||||||
@@ -77,7 +91,6 @@
|
|||||||
force: true
|
force: true
|
||||||
|
|
||||||
- name: Create swap filesystem
|
- name: Create swap filesystem
|
||||||
when: filesystem != 'btrfs'
|
|
||||||
community.general.filesystem:
|
community.general.filesystem:
|
||||||
fstype: swap
|
fstype: swap
|
||||||
dev: /dev/sys/swap
|
dev: /dev/sys/swap
|
||||||
@@ -96,7 +109,7 @@
|
|||||||
register: main_uuid
|
register: main_uuid
|
||||||
|
|
||||||
- name: Get UUIDs for LVM filesystems
|
- name: Get UUIDs for LVM filesystems
|
||||||
when: filesystem != 'btrfs' and (cis | bool or item not in ['home', 'var', 'var_log', 'var_log_audit'])
|
when: cis | bool or item not in ['home', 'var', 'var_log', 'var_log_audit']
|
||||||
ansible.builtin.command: blkid -s UUID -o value /dev/sys/{{ item }}
|
ansible.builtin.command: blkid -s UUID -o value /dev/sys/{{ item }}
|
||||||
changed_when: false
|
changed_when: false
|
||||||
register: uuid_result
|
register: uuid_result
|
||||||
@@ -109,7 +122,6 @@
|
|||||||
- var_log_audit
|
- var_log_audit
|
||||||
|
|
||||||
- name: Assign UUIDs to Variables
|
- name: Assign UUIDs to Variables
|
||||||
when: filesystem != 'btrfs'
|
|
||||||
ansible.builtin.set_fact:
|
ansible.builtin.set_fact:
|
||||||
uuid_root: "{{ uuid_result.results[0].stdout_lines }}"
|
uuid_root: "{{ uuid_result.results[0].stdout_lines }}"
|
||||||
uuid_swap: "{{ uuid_result.results[1].stdout_lines }}"
|
uuid_swap: "{{ uuid_result.results[1].stdout_lines }}"
|
||||||
@@ -124,7 +136,6 @@
|
|||||||
when:
|
when:
|
||||||
- cis | bool or (not cis and (item.path == '/var/log' and filesystem == 'btrfs')
|
- cis | bool or (not cis and (item.path == '/var/log' and filesystem == 'btrfs')
|
||||||
or (item.path not in ['/home', '/var', '/var/log', '/var/log/audit']))
|
or (item.path not in ['/home', '/var', '/var/log', '/var/log/audit']))
|
||||||
- not (item.path == '/swap' and filesystem != 'btrfs')
|
|
||||||
ansible.posix.mount:
|
ansible.posix.mount:
|
||||||
path: /mnt{{ item.path }}
|
path: /mnt{{ item.path }}
|
||||||
src: "{{ 'UUID=' + (main_uuid.stdout if filesystem == 'btrfs' else item.uuid) }}"
|
src: "{{ 'UUID=' + (main_uuid.stdout if filesystem == 'btrfs' else item.uuid) }}"
|
||||||
@@ -134,25 +145,20 @@
|
|||||||
loop:
|
loop:
|
||||||
- path: ""
|
- path: ""
|
||||||
uuid: "{{ uuid_root[0] | default(omit) }}"
|
uuid: "{{ uuid_root[0] | default(omit) }}"
|
||||||
opts: "{{ 'defaults' if filesystem != 'btrfs' else 'rw,relatime,compress=zstd:15,ssd,space_cache=v2,discard=async,subvol=@' }}"
|
opts: "defaults"
|
||||||
- path: /swap
|
|
||||||
opts: "rw,nosuid,nodev,relatime,compress=zstd:15,ssd,space_cache=v2,discard=async,subvol=@swap"
|
|
||||||
- path: /home
|
- path: /home
|
||||||
uuid: "{{ uuid_home[0] | default(omit) }}"
|
uuid: "{{ uuid_home[0] | default(omit) }}"
|
||||||
opts: "{{ 'defaults,nosuid,nodev' if filesystem != 'btrfs'
|
opts: "{{ 'defaults,nosuid,nodev' if filesystem != 'btrfs'
|
||||||
else 'rw,nosuid,nodev,relatime,compress=zstd:15,ssd,space_cache=v2,discard=async,subvol=@home' }}"
|
else 'rw,nosuid,nodev,relatime,compress=zstd:15,ssd,space_cache=v2,discard=async,subvol=@home' }}"
|
||||||
- path: /var
|
- path: /var
|
||||||
uuid: "{{ uuid_var[0] | default(omit) }}"
|
uuid: "{{ uuid_var[0] | default(omit) }}"
|
||||||
opts: "{{ 'defaults,nosuid,nodev' if filesystem != 'btrfs'
|
opts: "defaults,nosuid,nodev"
|
||||||
else 'rw,nosuid,nodev,relatime,compress=zstd:15,ssd,space_cache=v2,discard=async,subvol=@var' }}"
|
|
||||||
- path: /var/log
|
- path: /var/log
|
||||||
uuid: "{{ uuid_var_log[0] | default(omit) }}"
|
uuid: "{{ uuid_var_log[0] | default(omit) }}"
|
||||||
opts: "{{ 'defaults,nosuid,nodev,noexec' if filesystem != 'btrfs'
|
opts: "defaults,nosuid,nodev,noexec"
|
||||||
else 'rw,nosuid,nodev,noexec,relatime,compress=zstd:15,ssd,space_cache=v2,discard=async,subvol=@var_log' }}"
|
|
||||||
- path: /var/log/audit
|
- path: /var/log/audit
|
||||||
uuid: "{{ uuid_var_log_audit[0] | default(omit) }}"
|
uuid: "{{ uuid_var_log_audit[0] | default(omit) }}"
|
||||||
opts: "{{ 'defaults,nosuid,nodev,noexec' if filesystem != 'btrfs'
|
opts: "defaults,nosuid,nodev,noexec"
|
||||||
else 'rw,nosuid,nodev,noexec,relatime,compress=zstd:15,ssd,space_cache=v2,discard=async,subvol=@var_log_audit' }}"
|
|
||||||
|
|
||||||
- name: Mount tmp and var_tmp filesystems
|
- name: Mount tmp and var_tmp filesystems
|
||||||
ansible.posix.mount:
|
ansible.posix.mount:
|
||||||
@@ -167,12 +173,12 @@
|
|||||||
|
|
||||||
- name: Mount boot filesystem
|
- name: Mount boot filesystem
|
||||||
ansible.posix.mount:
|
ansible.posix.mount:
|
||||||
path: "{{ '/mnt/boot/efi' if os | lower in ['rhel8', 'ubuntu', 'ubuntu-lts'] else '/mnt/boot' }}"
|
path: "{{ '/mnt/boot/efi' if os | lower in ['rhel8'] else '/mnt/boot' }}"
|
||||||
src: UUID={{ boot_uuid.stdout }}
|
src: UUID={{ boot_uuid.stdout }}
|
||||||
fstype: vfat
|
fstype: vfat
|
||||||
state: mounted
|
state: mounted
|
||||||
|
|
||||||
- name: Activate swap
|
- name: Activate swap
|
||||||
ansible.builtin.command: "{{ 'swapon /mnt/swap/swapfile' if filesystem == 'btrfs' else 'swapon -U ' + uuid_swap[0] }}"
|
ansible.builtin.command: "{{ 'swapon -U ' + uuid_swap[0] }}"
|
||||||
changed_when: result.rc == 0
|
changed_when: result.rc == 0
|
||||||
register: result
|
register: result
|
||||||
|
|||||||
@@ -1,50 +0,0 @@
|
|||||||
---
|
|
||||||
- name: Check if VM disk exists
|
|
||||||
delegate_to: localhost
|
|
||||||
ansible.builtin.stat:
|
|
||||||
path: "{{ vm_path | default('/var/lib/libvirt/images/') }}{{ hostname }}.qcow2"
|
|
||||||
register: vm_disk_stat
|
|
||||||
|
|
||||||
- name: Create VM disk
|
|
||||||
when: not vm_disk_stat.stat.exists
|
|
||||||
delegate_to: localhost
|
|
||||||
ansible.builtin.command: qemu-img create -f qcow2 {{ vm_path | default('/var/lib/libvirt/images/') }}{{ hostname }}.qcow2 {{ vm_size }}G
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
|
|
||||||
- name: Generate Random MAC Address
|
|
||||||
delegate_to: localhost
|
|
||||||
ansible.builtin.shell: set -o pipefail && openssl rand -hex 5 | sed 's/\(..\)/\1:/g; s/.$//' | sed 's/^/02:/'
|
|
||||||
changed_when: false
|
|
||||||
register: mac_address_output
|
|
||||||
|
|
||||||
- name: Render cloud config templates
|
|
||||||
delegate_to: localhost
|
|
||||||
ansible.builtin.template:
|
|
||||||
src: "{{ item.src }}"
|
|
||||||
dest: /tmp/{{ item.dest_prefix }}-{{ hostname }}.yml
|
|
||||||
mode: '0644'
|
|
||||||
loop:
|
|
||||||
- { src: cloud-user-data.yml.j2, dest_prefix: cloud-user-data }
|
|
||||||
- { src: cloud-network-config.yml.j2, dest_prefix: cloud-network-config }
|
|
||||||
|
|
||||||
- name: Create cloud-init disk
|
|
||||||
delegate_to: localhost
|
|
||||||
ansible.builtin.command: >
|
|
||||||
cloud-localds {{ vm_path | default('/var/lib/libvirt/images/') }}/{{ hostname }}-cloudinit.iso
|
|
||||||
/tmp/cloud-user-data-{{ hostname }}.yml
|
|
||||||
-N /tmp/cloud-network-config-{{ hostname }}.yml
|
|
||||||
changed_when: result.rc == 0
|
|
||||||
register: result
|
|
||||||
|
|
||||||
- name: Create VM using libvirt
|
|
||||||
delegate_to: localhost
|
|
||||||
community.libvirt.virt:
|
|
||||||
command: define
|
|
||||||
xml: "{{ lookup('template', 'vm.xml.j2') }}"
|
|
||||||
|
|
||||||
- name: Start vm
|
|
||||||
delegate_to: localhost
|
|
||||||
community.libvirt.virt:
|
|
||||||
name: "{{ hostname }}"
|
|
||||||
state: running
|
|
||||||
@@ -1,51 +0,0 @@
|
|||||||
---
|
|
||||||
- name: Deploy VM on Proxmox
|
|
||||||
delegate_to: localhost
|
|
||||||
community.general.proxmox_kvm:
|
|
||||||
api_host: "{{ hypervisor_url }}"
|
|
||||||
api_user: "{{ hypervisor_username }}"
|
|
||||||
api_password: "{{ hypervisor_password }}"
|
|
||||||
ciuser: "{{ user_name }}"
|
|
||||||
cipassword: "{{ user_password }}"
|
|
||||||
ciupgrade: false
|
|
||||||
node: "{{ hypervisor_node }}"
|
|
||||||
vmid: "{{ vm_id }}"
|
|
||||||
name: "{{ hostname }}"
|
|
||||||
cpu: host
|
|
||||||
cores: "{{ vm_cpus }}"
|
|
||||||
memory: "{{ vm_memory }}"
|
|
||||||
balloon: "{{ vm_ballo | default(omit) }}"
|
|
||||||
numa_enabled: true
|
|
||||||
hotplug: network,disk
|
|
||||||
bios: ovmf
|
|
||||||
boot: ac
|
|
||||||
scsihw: virtio-scsi-single
|
|
||||||
scsi:
|
|
||||||
scsi0: "{{ hypervisor_storage }}:{{ vm_size }}"
|
|
||||||
efidisk0:
|
|
||||||
efitype: 4m
|
|
||||||
format: raw
|
|
||||||
pre_enrolled_keys: false
|
|
||||||
storage: "{{ hypervisor_storage }}"
|
|
||||||
ide:
|
|
||||||
ide0: "{{ boot_iso }},media=cdrom"
|
|
||||||
ide1: "{{ rhel_iso + ',media=cdrom' if rhel_iso is defined else omit }}"
|
|
||||||
ide2: "{{ hypervisor_storage }}:cloudinit"
|
|
||||||
net:
|
|
||||||
net0: virtio,bridge={{ vm_nif }}{% if vlan_name is defined and vlan_name %},tag={{ vlan_name }}{% endif %}
|
|
||||||
ipconfig:
|
|
||||||
ipconfig0: ip={{ vm_ip }}/{{ vm_nms | default(24) }},gw={{ vm_gw }}
|
|
||||||
nameservers: "{{ vm_dns }}"
|
|
||||||
onboot: true
|
|
||||||
state: present
|
|
||||||
|
|
||||||
- name: Start VM on Proxmox
|
|
||||||
delegate_to: localhost
|
|
||||||
community.general.proxmox_kvm:
|
|
||||||
api_host: "{{ hypervisor_url }}"
|
|
||||||
api_user: "{{ hypervisor_username }}"
|
|
||||||
api_password: "{{ hypervisor_password }}"
|
|
||||||
node: "{{ hypervisor_node }}"
|
|
||||||
name: "{{ hostname }}"
|
|
||||||
vmid: "{{ vm_id }}"
|
|
||||||
state: started
|
|
||||||
@@ -5,13 +5,11 @@
|
|||||||
username: "{{ hypervisor_username }}"
|
username: "{{ hypervisor_username }}"
|
||||||
password: "{{ hypervisor_password }}"
|
password: "{{ hypervisor_password }}"
|
||||||
validate_certs: false
|
validate_certs: false
|
||||||
datacenter: "{{ hypervisor_datacenter }}"
|
datacenter: "{{ hypervisor_cluster }}"
|
||||||
cluster: "{{ hypervisor_cluster }}"
|
cluster: "{{ hypervisor_node }}"
|
||||||
folder: "{{ vm_path }}"
|
folder: "{{ vm_path }}"
|
||||||
name: "{{ hostname }}"
|
name: "{{ hostname }}"
|
||||||
guest_id: otherLinux64Guest
|
guest_id: otherGuest64
|
||||||
annotation: |
|
|
||||||
{{ note | default('') }}
|
|
||||||
state: poweredon
|
state: poweredon
|
||||||
disk:
|
disk:
|
||||||
- size_gb: "{{ vm_size }}"
|
- size_gb: "{{ vm_size }}"
|
||||||
@@ -22,26 +20,13 @@
|
|||||||
num_cpus: "{{ vm_cpus }}"
|
num_cpus: "{{ vm_cpus }}"
|
||||||
boot_firmware: efi
|
boot_firmware: efi
|
||||||
secure_boot: false
|
secure_boot: false
|
||||||
cdrom: >-
|
cdrom:
|
||||||
{{
|
- controller_number: 0
|
||||||
[ {
|
unit_number: 0
|
||||||
"controller_number": 0,
|
controller_type: sata
|
||||||
"unit_number": 0,
|
state: present
|
||||||
"controller_type": "sata",
|
type: iso
|
||||||
"state": "present",
|
iso_path: "{{ boot_iso }}"
|
||||||
"type": "iso",
|
|
||||||
"iso_path": boot_iso
|
|
||||||
} ]
|
|
||||||
+
|
|
||||||
( [ {
|
|
||||||
"controller_number": 0,
|
|
||||||
"unit_number": 1,
|
|
||||||
"controller_type": "sata",
|
|
||||||
"state": "present",
|
|
||||||
"type": "iso",
|
|
||||||
"iso_path": rhel_iso
|
|
||||||
} ] if rhel_iso is defined and rhel_iso|length > 0 else [] )
|
|
||||||
}}
|
|
||||||
networks:
|
networks:
|
||||||
- name: "{{ vm_nif }}"
|
- name: "{{ vm_nif }}"
|
||||||
type: dhcp
|
type: dhcp
|
||||||
|
|||||||
@@ -1,11 +0,0 @@
|
|||||||
network:
|
|
||||||
version: 2
|
|
||||||
ethernets:
|
|
||||||
id0:
|
|
||||||
match:
|
|
||||||
macaddress: "{{ mac_address_output.stdout }}"
|
|
||||||
addresses:
|
|
||||||
- "{{ vm_ip }}"
|
|
||||||
gateway4: "{{ vm_gw }}"
|
|
||||||
nameservers:
|
|
||||||
addresses: ['1.1.1.1', '1.0.0.1']
|
|
||||||
@@ -1,12 +0,0 @@
|
|||||||
#cloud-config
|
|
||||||
hostname: "archiso"
|
|
||||||
ssh_pwauth: true
|
|
||||||
package_update: false
|
|
||||||
package_upgrade: false
|
|
||||||
users:
|
|
||||||
- name: "{{ user_name }}"
|
|
||||||
primary_group: "{{ user_name }}"
|
|
||||||
groups: users
|
|
||||||
sudo: ALL=(ALL) NOPASSWD:ALL
|
|
||||||
passwd: "{{ user_password | password_hash('sha512') }}"
|
|
||||||
lock_passwd: False
|
|
||||||
@@ -1,62 +0,0 @@
|
|||||||
<domain type='kvm'>
|
|
||||||
<name>{{ hostname }}</name>
|
|
||||||
<memory>{{ vm_memory | int * 1024 }}</memory>
|
|
||||||
{% if vm_ballo is defined %}<currentMemory>{{ vm_ballo | int * 1024 }}</currentMemory>{% endif %}
|
|
||||||
<vcpu placement='static'>{{ vm_cpus }}</vcpu>
|
|
||||||
<os>
|
|
||||||
<type arch='x86_64' machine="pc-q35-8.0">hvm</type>
|
|
||||||
<bootmenu enable='no'/>
|
|
||||||
<boot dev='hd'/>
|
|
||||||
<boot dev='cdrom'/>
|
|
||||||
<loader readonly="yes" type="pflash">/usr/share/edk2/x64/OVMF_CODE.secboot.4m.fd</loader>
|
|
||||||
<nvram template="/usr/share/edk2/x64/OVMF_VARS.4m.fd"/>
|
|
||||||
</os>
|
|
||||||
<features>
|
|
||||||
<acpi/>
|
|
||||||
<apic/>
|
|
||||||
<pae/>
|
|
||||||
</features>
|
|
||||||
<cpu mode="host-passthrough" check="none" migratable="on"/>
|
|
||||||
<clock offset="utc"/>
|
|
||||||
<on_poweroff>destroy</on_poweroff>
|
|
||||||
<on_reboot>restart</on_reboot>
|
|
||||||
<on_crash>destroy</on_crash>
|
|
||||||
<devices>
|
|
||||||
<disk type='file' device='disk'>
|
|
||||||
<driver name='qemu' type='qcow2'/>
|
|
||||||
<source file='{{ vm_path | default('/var/lib/libvirt/images/') }}{{ hostname }}.qcow2'/>
|
|
||||||
<target dev='vda' bus='virtio'/>
|
|
||||||
</disk>
|
|
||||||
<disk type="file" device="cdrom">
|
|
||||||
<driver name="qemu" type="raw"/>
|
|
||||||
<source file="{{ boot_iso }}"/>
|
|
||||||
<target dev="sda" bus="sata"/>
|
|
||||||
</disk>
|
|
||||||
<disk type="file" device="cdrom">
|
|
||||||
<driver name="qemu" type="raw"/>
|
|
||||||
<source file="{{ vm_path | default('/var/lib/libvirt/images/') }}{{ hostname }}-cloudinit.iso"/>
|
|
||||||
<target dev="sdb" bus="sata"/>
|
|
||||||
</disk>
|
|
||||||
{% if rhel_iso is defined %}
|
|
||||||
<disk type="file" device="cdrom">
|
|
||||||
<driver name="qemu" type="raw"/>
|
|
||||||
<source file="{{ rhel_iso }}"/>
|
|
||||||
<target dev="sdc" bus="sata"/>
|
|
||||||
</disk>
|
|
||||||
{% endif %}
|
|
||||||
<interface type='network'>
|
|
||||||
<mac address="{{ mac_address_output.stdout }}"/>
|
|
||||||
<source network='default'/>
|
|
||||||
<model type='virtio'/>
|
|
||||||
</interface>
|
|
||||||
<input type="tablet" bus="usb"/>
|
|
||||||
<input type="mouse" bus="ps2"/>
|
|
||||||
<input type="keyboard" bus="ps2"/>
|
|
||||||
<graphics type='spice' autoport="yes">
|
|
||||||
<listen type="address"/>
|
|
||||||
</graphics>
|
|
||||||
<video>
|
|
||||||
<model type="virtio" heads="1" primary="yes"/>
|
|
||||||
</video>
|
|
||||||
</devices>
|
|
||||||
</domain>
|
|
||||||
@@ -1,43 +0,0 @@
|
|||||||
[alma-appstream]
|
|
||||||
name=AlmaLinux $releasever - AppStream
|
|
||||||
mirrorlist=https://mirrors.almalinux.org/mirrorlist/$releasever/appstream
|
|
||||||
# baseurl=https://repo.almalinux.org/almalinux/$releasever/AppStream/$basearch/os/
|
|
||||||
enabled=1
|
|
||||||
gpgcheck=1
|
|
||||||
countme=1
|
|
||||||
gpgkey=https://repo.almalinux.org/almalinux/RPM-GPG-KEY-AlmaLinux-$releasever
|
|
||||||
metadata_expire=86400
|
|
||||||
enabled_metadata=1
|
|
||||||
|
|
||||||
[alma-baseos]
|
|
||||||
name=AlmaLinux $releasever - BaseOS
|
|
||||||
mirrorlist=https://mirrors.almalinux.org/mirrorlist/$releasever/baseos
|
|
||||||
# baseurl=https://repo.almalinux.org/almalinux/$releasever/BaseOS/$basearch/os/
|
|
||||||
enabled=1
|
|
||||||
gpgcheck=1
|
|
||||||
countme=1
|
|
||||||
gpgkey=https://repo.almalinux.org/almalinux/RPM-GPG-KEY-AlmaLinux-$releasever
|
|
||||||
metadata_expire=86400
|
|
||||||
enabled_metadata=1
|
|
||||||
|
|
||||||
[alma-extras]
|
|
||||||
name=AlmaLinux $releasever - Extras
|
|
||||||
mirrorlist=https://mirrors.almalinux.org/mirrorlist/$releasever/extras
|
|
||||||
# baseurl=https://repo.almalinux.org/almalinux/$releasever/extras/$basearch/os/
|
|
||||||
enabled=1
|
|
||||||
gpgcheck=1
|
|
||||||
countme=1
|
|
||||||
gpgkey=https://repo.almalinux.org/almalinux/RPM-GPG-KEY-AlmaLinux-$releasever
|
|
||||||
metadata_expire=86400
|
|
||||||
enabled_metadata=0
|
|
||||||
|
|
||||||
[alma-highavailability]
|
|
||||||
name=AlmaLinux $releasever - HighAvailability
|
|
||||||
mirrorlist=https://mirrors.almalinux.org/mirrorlist/$releasever/highavailability
|
|
||||||
# baseurl=https://repo.almalinux.org/almalinux/$releasever/HighAvailability/$basearch/os/
|
|
||||||
enabled=1
|
|
||||||
gpgcheck=1
|
|
||||||
countme=1
|
|
||||||
gpgkey=https://repo.almalinux.org/almalinux/RPM-GPG-KEY-AlmaLinux-$releasever
|
|
||||||
metadata_expire=86400
|
|
||||||
enabled_metadata=0
|
|
||||||
@@ -1,25 +0,0 @@
|
|||||||
[fedora]
|
|
||||||
name=Fedora $releasever - $basearch
|
|
||||||
#baseurl=http://download.example/pub/fedora/linux/releases/$releasever/Everything/$basearch/os/
|
|
||||||
metalink=https://mirrors.fedoraproject.org/metalink?repo=fedora-$releasever&arch=$basearch
|
|
||||||
enabled=1
|
|
||||||
countme=1
|
|
||||||
metadata_expire=86400
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=https://fedoraproject.org/fedora.gpg
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[fedora-updates]
|
|
||||||
name=Fedora $releasever - $basearch - Updates
|
|
||||||
#baseurl=http://download.example/pub/fedora/linux/updates/$releasever/Everything/$basearch/
|
|
||||||
metalink=https://mirrors.fedoraproject.org/metalink?repo=updates-released-f$releasever&arch=$basearch
|
|
||||||
enabled=1
|
|
||||||
countme=1
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
metadata_expire=86400
|
|
||||||
gpgkey=https://fedoraproject.org/fedora.gpg
|
|
||||||
skip_if_unavailable=False
|
|
||||||
@@ -1,13 +0,0 @@
|
|||||||
[rhel10-baseos]
|
|
||||||
name=RHEL 10 BaseOS
|
|
||||||
baseurl=file:///usr/local/install/redhat/dvd/BaseOS
|
|
||||||
enabled=1
|
|
||||||
gpgcheck=0
|
|
||||||
gpgkey=file:///usr/local/install/redhat/dvd/RPM-GPG-KEY-redhat-release
|
|
||||||
|
|
||||||
[rhel10-appstream]
|
|
||||||
name=RHEL 10 AppStream
|
|
||||||
baseurl=file:///usr/local/install/redhat/dvd/AppStream
|
|
||||||
enabled=1
|
|
||||||
gpgcheck=0
|
|
||||||
gpgkey=file:///usr/local/install/redhat/dvd/RPM-GPG-KEY-redhat-release
|
|
||||||
@@ -1,10 +0,0 @@
|
|||||||
[rocky-baseos]
|
|
||||||
name=Rocky Linux $releasever - BaseOS
|
|
||||||
mirrorlist=https://mirrors.rockylinux.org/mirrorlist?arch=$basearch&repo=BaseOS-$releasever
|
|
||||||
#baseurl=http://dl.rockylinux.org/$contentdir/$releasever/BaseOS/$basearch/os/
|
|
||||||
gpgcheck=1
|
|
||||||
enabled=1
|
|
||||||
countme=1
|
|
||||||
gpgkey=https://dl.rockylinux.org/pub/rocky/RPM-GPG-KEY-Rocky-$releasever
|
|
||||||
metadata_expire=86400
|
|
||||||
enabled_metadata=1
|
|
||||||
@@ -1,11 +1,13 @@
|
|||||||
vm_ip: "{{ inventory_hostname }}"
|
vm_ip: "{{ inventory_hostname }}/{{ vm_nms }}"
|
||||||
install_type: "virtual"
|
install_type: "virtual"
|
||||||
|
cis: false
|
||||||
|
|
||||||
hypervisor_url: "192.168.0.2"
|
hypervisor_url: "192.168.0.2"
|
||||||
hypervisor_username: "root@pam"
|
hypervisor_username: "root@pam"
|
||||||
hypervisor_password: "SomePassword"
|
hypervisor_password: "SomePassword"
|
||||||
hypervisor_node: "NodeName"
|
hypervisor_node: "NodeName"
|
||||||
hypervisor_storage: "local-btrfs"
|
hypervisor_storage: "local-btrfs"
|
||||||
|
boot_iso: "local-btrfs:rhel-9.4-x86_64-dvd.iso"
|
||||||
|
|
||||||
# For VMware-Tools
|
# For VMware-Tools
|
||||||
ansible_vmware_host: "{{ hypervisor_url }}"
|
ansible_vmware_host: "{{ hypervisor_url }}"
|
||||||
|
|||||||
Reference in New Issue
Block a user