146 lines
3.0 KiB
YAML
146 lines
3.0 KiB
YAML
---
|
|
- hosts: all
|
|
handlers:
|
|
- import_tasks: global_handlers/global_handlers.yml
|
|
connection: local
|
|
vars:
|
|
- import_vars: "os_vars/{{ ansible_distribution | lower }}.yml"
|
|
become: true
|
|
|
|
pre_tasks:
|
|
- name: pre-run | update apt repository (debian, ubuntu, etc.)
|
|
apt: update_cache=yes
|
|
changed_when: false
|
|
when: ansible_distribution in ["Debian", "Ubuntu"]
|
|
- name: pre-run | upgrade system (debian, ubuntu, etc.)
|
|
apt: upgrade=dist
|
|
changed_when: false
|
|
when: ansible_distribution in ["Debian", "Ubuntu"]
|
|
- name: pre-run | update pacman repository (arch)
|
|
pacman: update_cache=yes
|
|
changed_when: false
|
|
when: ansible_distribution == 'Archlinux'
|
|
- name: pre-run |update portage repository (gentoo)
|
|
portage:
|
|
sync: yes
|
|
when: ansible_distribution == 'Gentoo'
|
|
|
|
# run roles
|
|
- hosts: all
|
|
tags: base
|
|
become: true
|
|
roles:
|
|
- base
|
|
|
|
# - hosts: workstation
|
|
# tags: workstation
|
|
# become: true
|
|
# roles:
|
|
# - workstation
|
|
|
|
- hosts: server
|
|
tags: server
|
|
become: true
|
|
roles:
|
|
- server
|
|
|
|
- hosts: webserver
|
|
tags: server,webserver
|
|
become: true
|
|
roles:
|
|
- webserver
|
|
|
|
# - hosts: mailserver
|
|
# tags: server,mailserver
|
|
# become: true
|
|
# roles:
|
|
# - mailserver
|
|
|
|
# - hosts: database
|
|
# tags: server,database
|
|
# become: true
|
|
# roles:
|
|
# - database
|
|
|
|
# - hosts: dhcpserver
|
|
# tags: server,dhcpserver
|
|
# become: true
|
|
# roles:
|
|
# - dhcpserver
|
|
|
|
# - hosts: fileserver
|
|
# tags: server,fileserver
|
|
# become: true
|
|
# roles:
|
|
# - fileserver
|
|
|
|
- hosts: mastodon
|
|
tags: server,mastodon
|
|
become: true
|
|
roles:
|
|
- mastodon
|
|
|
|
- hosts: nameserver
|
|
tags: server,nameserver
|
|
become: true
|
|
roles:
|
|
- nameserver
|
|
|
|
# - hosts: printspooler
|
|
# tags: server,printspooler
|
|
# become: true
|
|
# roles:
|
|
# - printspooler
|
|
|
|
- hosts: jitsimeet
|
|
tags: server,jitsimeet,webserver
|
|
become: true
|
|
roles:
|
|
- jitsimeet
|
|
|
|
# - hosts: proxyserver
|
|
# tags: server,proxyserver
|
|
# become: true
|
|
# roles:
|
|
# - proxyserver
|
|
|
|
# end of roles; cleanup and reporting
|
|
- hosts: all
|
|
become: true
|
|
tasks:
|
|
- name: cleanup package cache (debian and ubuntu)
|
|
tags: always
|
|
apt:
|
|
autoclean: yes
|
|
changed_when: false
|
|
when: ansible_distribution in ["Debian", "Pop!_OS", "Ubuntu"]
|
|
|
|
- name: autoremove orphan packages (debian and ubuntu)
|
|
tags: always
|
|
apt:
|
|
autoremove: yes
|
|
purge: yes
|
|
when: ansible_distribution in ["Debian", "Pop!_OS", "Ubuntu"]
|
|
|
|
- name: cleanup package cache (arch)
|
|
tags: always
|
|
pacman:
|
|
autoclean: yes
|
|
changed_when: false
|
|
when: ansible_distribution == "Archlinux"
|
|
|
|
# - name: send completion alert
|
|
# include_tasks: playbooks/send_completion_alert.yml
|
|
# tags: always
|
|
# when:
|
|
# - task_failed is not defined
|
|
|
|
# - name: send failure alert
|
|
# include_tasks: playbooks/send_failure_alert.yml
|
|
# tags: always
|
|
# when:
|
|
# - task_failed is defined
|
|
# - task_failed == true
|
|
|
|
# vim: ts=2 sw=2 fdm=indent
|