ansible/all/playbook.yaml

278 lines
8.5 KiB
YAML
Raw Normal View History

- name: Playbook to Provision / Re-configure Node
2023-05-13 09:14:40 +08:00
hosts: all
vars:
users:
- name: arya
2024-01-06 22:42:02 +05:30
password: "{{arya_encrypted_pass}}"
- name: devrand
2024-01-06 22:42:02 +05:30
password: "{{devrand_encrypted_pass}}"
- name: midou
2024-01-06 22:42:02 +05:30
password: "{{midou_encrypted_pass}}"
- name: ansiblerunner
2024-01-06 22:42:02 +05:30
password: "{{ansiblerunner_encrypted_pass}}"
2023-05-13 09:14:40 +08:00
tasks:
- name: Enable backports
ansible.builtin.apt_repository:
repo: deb http://deb.debian.org/debian bookworm-backports main contrib
state: present
- name: Get Knot GPG keys
ansible.builtin.get_url:
url: https://deb.knot-dns.cz/apt.gpg
dest: /usr/share/keyrings/knot.gpg
mode: '0644'
- name: Enable knot repo
ansible.builtin.apt_repository:
repo: deb [signed-by=/usr/share/keyrings/knot.gpg] https://deb.knot-dns.cz/knot-latest/ bookworm main
state: present
2024-04-11 13:25:19 +05:30
- name: Get GoAccess GPG keys
ansible.builtin.get_url:
2024-04-11 13:41:51 +05:30
url: https://deb.goaccess.io/gnugpg.key
2024-04-11 14:10:42 +05:30
dest: /usr/share/keyrings/goaccess.asc
2024-04-11 13:25:19 +05:30
mode: '0644'
- name: Enable goaccess repo
ansible.builtin.apt_repository:
2024-04-11 14:17:20 +05:30
repo: deb [signed-by=/usr/share/keyrings/goaccess.asc arch=amd64] https://deb.goaccess.io/ bookworm main
2024-04-11 13:25:19 +05:30
state: present
- name: Install Required Programs / APT
2023-07-07 22:40:54 +05:30
ansible.builtin.apt:
name:
# Misc
- sudo
- chrony
- tmux
- nala
- apt-file
2024-01-10 19:13:09 +05:30
- fail2ban
2024-02-24 16:43:52 +05:30
- tree
2024-06-19 21:06:44 +05:30
- perl
# Monitoring
2023-08-12 11:01:24 +05:30
- htop
- gdu
- btop
- iotop
- vnstat
- neofetch
- prometheus-node-exporter
- goaccess
# Text Editing
2023-07-07 22:40:54 +05:30
- vim
- neovim
2023-07-07 22:40:54 +05:30
- curl
- wget
# Backups
- borgbackup
- rsync
# Basic Networking
2023-07-07 22:40:54 +05:30
- net-tools
- nmap
# Python3
2023-07-07 22:40:54 +05:30
- python3-pip
- python3-passlib # Ansible User Creation
- python3-pyroute2 # for smart-ipv6-rotator
- python3-requests # for smart-ipv6-rotator
# Speed Tests
2023-08-12 11:01:24 +05:30
- iperf3
- speedtest-cli
# Security
- ufw
2023-07-07 22:40:54 +05:30
- name: Enable VNStat service
ansible.builtin.service:
name: vnstat
enabled: true
state: started
- name: Enable Chrony (NTP) service
ansible.builtin.service:
name: chrony
enabled: true
state: started
- name: Enable Prometheus Node Exporter service
ansible.builtin.service:
name: prometheus-node-exporter
enabled: true
state: started
- name: Enable UFW service
ansible.builtin.service:
name: ufw
enabled: true
state: started
2024-01-10 19:13:09 +05:30
- name: Enable Fail2Ban service
ansible.builtin.service:
name: fail2ban
enabled: true
state: started
2023-07-07 22:40:54 +05:30
- name: Disable dmesg logging to console
ansible.posix.sysctl:
2023-06-10 23:28:18 +05:30
name: kernel.printk
2023-07-21 13:19:35 +01:00
value: "3 4 1 3"
2023-06-10 23:28:18 +05:30
state: present
2023-07-07 22:40:54 +05:30
sysctl_set: true
- name: Allow binding to non-local IPs / IPv6
ansible.posix.sysctl:
name: net.ipv6.ip_nonlocal_bind
value: "1"
state: present
sysctl_set: true
- name: Allow IP forwarding / IPv4
ansible.posix.sysctl:
name: net.ipv4.ip_forward
value: "1"
state: present
sysctl_set: true
- name: Allow IP forwarding / IPv6
ansible.posix.sysctl:
name: net.ipv6.conf.all.forwarding
value: "1"
state: present
sysctl_set: true
- name: Swappiness
ansible.posix.sysctl:
name: vm.swappiness
value: "60"
state: present
sysctl_set: true
2023-07-07 22:40:54 +05:30
- name: Bashrc skel
ansible.builtin.template:
2023-05-13 09:14:40 +08:00
src: templates/bashrc.j2
dest: /etc/skel/.bashrc
2023-07-07 22:40:54 +05:30
mode: preserve
- name: Profile skel
ansible.builtin.template:
2023-05-13 09:14:40 +08:00
src: templates/profile.j2
dest: /etc/skel/.profile
2023-07-07 22:40:54 +05:30
mode: preserve
- name: Bash_aliases skel
ansible.builtin.template:
2023-05-13 09:14:40 +08:00
src: templates/bash_aliases.j2
dest: /etc/skel/.bash_aliases
2023-07-07 22:40:54 +05:30
mode: preserve
- name: Prompt skel
ansible.builtin.template:
2023-05-13 09:14:40 +08:00
src: templates/prompt.j2
dest: /etc/skel/.prompt
2023-07-07 22:40:54 +05:30
mode: preserve
- name: Bashrc root
ansible.builtin.template:
2023-05-13 09:14:40 +08:00
src: templates/bashrc.j2
dest: /root/.bashrc
2023-07-07 22:40:54 +05:30
mode: preserve
- name: Profile root
ansible.builtin.template:
2023-05-13 09:14:40 +08:00
src: templates/profile.j2
dest: /root/.profile
2023-07-07 22:40:54 +05:30
mode: preserve
- name: Bash_aliases root
ansible.builtin.template:
2023-05-13 09:14:40 +08:00
src: templates/bash_aliases.j2
dest: /root/.bash_aliases
2023-07-07 22:40:54 +05:30
mode: preserve
- name: Prompt root
ansible.builtin.template:
2023-05-13 09:14:40 +08:00
src: templates/prompt.j2
dest: /root/.prompt
2023-07-07 22:40:54 +05:30
mode: preserve
2023-05-13 09:14:40 +08:00
- name: Add user
2023-07-07 22:40:54 +05:30
ansible.builtin.user:
name: "{{ item.name }}"
2023-05-13 09:14:40 +08:00
group: users
groups: users,sudo
password: "{{ item.password }}"
2023-05-13 09:14:40 +08:00
shell: /bin/bash
2024-01-06 23:42:59 +05:30
update_password: always
2023-07-07 22:40:54 +05:30
with_items:
2023-05-13 09:14:40 +08:00
- "{{ users }}"
- name: "Add authorized keys"
2023-07-07 22:40:54 +05:30
ansible.posix.authorized_key:
user: "{{ item.name }}"
2024-01-06 23:42:59 +05:30
key: "{{ lookup('file', 'files/' + item.name + '.pub') }}"
2023-05-13 09:14:40 +08:00
with_items:
- "{{ users }}"
- name: "Allow admin users to sudo without a password"
2023-07-07 22:40:54 +05:30
ansible.builtin.lineinfile:
2023-05-13 09:14:40 +08:00
dest: "/etc/sudoers" # path: in version 2.3
state: "present"
regexp: "^%sudo"
line: "%sudo ALL=(ALL) NOPASSWD: ALL"
2024-01-08 11:58:59 +05:30
- name: "Sshd configuration file update"
2023-07-07 22:40:54 +05:30
ansible.builtin.template:
2023-05-13 09:14:40 +08:00
src: templates/sshd_config.j2
dest: /etc/ssh/sshd_config
2023-07-07 22:40:54 +05:30
backup: true
2023-05-13 09:14:40 +08:00
owner: 0
group: 0
2023-07-07 22:40:54 +05:30
mode: "0644"
2023-07-21 13:19:35 +01:00
validate: "/usr/sbin/sshd -T -f %s"
2023-05-13 09:14:40 +08:00
notify:
- Restart sshd
2024-01-08 11:58:59 +05:30
- name: "Remove useless passphrase line (runs after borgmatic role)"
ansible.builtin.lineinfile:
dest: "/etc/borgmatic/config.yaml"
state: "absent"
regexp: "^.*encryption_passphrase"
2023-05-13 09:14:40 +08:00
handlers:
2023-07-07 22:40:54 +05:30
- name: Restart sshd
ansible.builtin.service:
name: ssh
2023-07-07 22:40:54 +05:30
enabled: true
state: restarted
roles:
- role: geerlingguy.docker
docker_install_compose_plugin: true
docker_compose_package: docker-compose-plugin
docker_compose_package_state: present
- role: artis3n.tailscale
# Future Sysadmin seeing this: if this fails; it is because the key is only valid for 365 days (from Jan 6 2024)
tailscale_authkey: "{{tailscale_authkey}}"
tailscale_args: "--login-server https://hs.projectsegfau.lt --accept-dns=false"
- role: borgbase.ansible_role_borgbackup
borg_repository:
- ssh://zh3117@zh3117.rsync.net/data1/home/zh3117/backups/{{rsyncnet_slug}}
2024-01-06 22:42:02 +05:30
borg_source_directories: "{{bkp_source_directories}}"
borg_exclude_patterns: "{{bkp_exclude_patterns}}"
borg_remote_path: /usr/local/bin/borg_1.2.4/borg1
borgmatic_hooks:
2024-01-06 22:42:02 +05:30
postgresql_databases: "{{bkp_postgresql_databases}}"
healthchecks:
ping_url: https://healthchecks.projectsegfau.lt/ping/{{bkp_hc_uuid}}
states:
- finish
borg_retention_policy:
keep_daily: 7
keep_weekly: 4
keep_monthly: 3
2024-01-06 22:42:02 +05:30
# very secure I know; it has to be plain text anyway for automated backups, unless there is a better way (in which case please email me@aryak.me)
borg_encryption_passcommand: "cat /etc/borgmatic/passphrase"
- name: UFW Firewall Configuration
hosts: eu,us # IN is behind router so no f/w is needed
tasks:
- name: Enable UFW
community.general.ufw:
state: enabled
policy: deny
- name: Allow all in from tailscale
community.general.ufw:
rule: allow
interface: tailscale0
direction: in
- name: Allow all in from wg (if its there)
community.general.ufw:
rule: allow
interface: wg0
direction: in
2024-01-10 18:05:41 +05:30
# For some reason in order for a docker container to connect to postgres on host it needs this
- name: Allow all in from bogon ranges
community.general.ufw:
rule: allow
src: "{{ item }}"
direction: in
loop:
- 10.0.0.0/8
- 172.16.0.0/12
- 192.168.0.0/16
- name: Deny rules
community.general.ufw:
rule: allow
2024-01-06 22:42:02 +05:30
port: "{{ item.port }}"
proto: "{{ item.proto }}"
with_items:
2024-01-06 19:33:33 +01:00
- "{{ ufw_allow_rules }}"