dockerhost/deploy.yml

125 lines
3.4 KiB
YAML
Raw Normal View History

2025-03-10 19:04:20 +01:00
---
2025-03-10 21:13:19 +01:00
# - hosts: all
# tasks:
# - name: Print message
# debug:
# msg: Hello Ansible World
2025-03-10 19:04:20 +01:00
- hosts: all
2025-03-10 21:13:19 +01:00
become: true
2025-03-10 19:04:20 +01:00
tasks:
2025-03-10 21:13:19 +01:00
## Docker
2025-03-19 19:46:19 +01:00
- name: Add Docker GPG apt Key (new)
ansible.builtin.get_url:
# Docker Release (CE deb) <docker@docker.com>
2025-03-19 20:02:43 +01:00
url: "https://keyserver.ubuntu.com/pks/lookup?op=get&search=0x8d81803c0ebfcd88"
2025-03-19 19:46:19 +01:00
dest: /etc/apt/keyrings/docker_rel_ce_deb.asc
2025-03-10 21:13:19 +01:00
- name: Add Docker Repository
apt_repository:
2025-03-19 21:08:16 +01:00
repo: "deb [signed-by=/etc/apt/keyrings/docker_rel_ce_deb.asc] https://download.docker.com/linux/ubuntu {{ ansible_distribution_release }} stable"
2025-03-10 21:13:19 +01:00
state: present
- name: Update apt and install docker-ce
apt:
name: docker-ce
state: latest
update_cache: true
- name: install pip3
apt:
name: python3-pip
state: latest
2025-03-10 21:55:16 +01:00
2025-03-19 21:08:16 +01:00
# - name: Container present test
# community.docker.docker_container:
# name: ansible_deployed
# state: absent
2025-03-12 10:42:15 +01:00
2025-03-13 10:44:27 +01:00
- name: Registry cache
community.docker.docker_container:
name: registry_cache
state: started
restart_policy: unless-stopped
2025-03-13 10:50:50 +01:00
image: mirror.gcr.io/registry:2
2025-03-13 11:23:14 +01:00
ports:
2025-03-13 11:16:52 +01:00
- "5000:5000"
2025-03-13 11:03:08 +01:00
volumes:
- /var/lib/registry:/var/lib/registry
2025-03-13 10:44:27 +01:00
env:
REGISTRY_PROXY_REMOTEURL: https://registry-1.docker.io
REGISTRY_PROXY_USERNAME: stelb
REGISTRY_PROXY_PASSWORD: "{{ DOCKER_IO_PASSWORD }}"
2025-03-10 21:55:16 +01:00
- name: add docker rules to ufw
blockinfile:
path: /etc/ufw/after.rules
marker_begin: BEGIN UFW AND DOCKER
marker_end: END UFW AND DOCKER
state: present
block: "{{ lookup('ansible.builtin.file', 'ufw-docker.rules') }}"
tags:
- ufw
2025-03-12 21:57:34 +01:00
- name: allow OpenSSH
community.general.ufw:
2025-03-12 22:01:57 +01:00
rule: allow
2025-03-12 21:57:34 +01:00
app: OpenSSH
2025-03-12 19:48:29 +01:00
- name: enable ufw
community.general.ufw:
state: enabled
policy: reject
tags:
- ufw
2025-03-10 22:39:48 +01:00
- name: open ports
community.general.ufw:
rule: allow
proto: "{{ item[1] }}"
port: "{{ item[0] }}"
route: "{{ item[2] | default(omit) }}"
loop:
- [ 80, 'tcp', true ] # traefik
- [ 443, 'tcp', true ] # traefik
- [ 25, 'tcp', true ] # smtp ntfy
- [ 51820, 'udp', true ] # wireguard
- [ 53, 'udp', true ] # technitium, dns
- [ 53, 'tcp', true ] # technitium, dns
# - [ 1935, 'udp', true ] # owncast
# - [ 1935, 'tcp', true ] # owncast
- [ 2222, 'tcp', true ] # forgejo
- [ 22, 'tcp', true ] # forgejo
tags:
- ufw
2025-03-19 21:08:16 +01:00
- name: open network for own hosts
2025-03-10 22:39:48 +01:00
community.general.ufw:
rule: allow
from: "{{ item }}"
2025-03-12 21:48:09 +01:00
loop: "{{ anyops_trusted_hosts }}"
2025-03-10 22:39:48 +01:00
tags:
- ufw
2025-03-17 18:17:11 +01:00
- name: autoupgrade
ansible.builtin.include_role:
name: anyops_autoupgrade
2025-03-25 14:25:01 +01:00
# kanidm
- name: Add kanidm GPG apt key
ansible.builtin.get_url:
url: https://kanidm.github.io/kanidm_ppa/kanidm_ppa.asc
dest: /etc/apt/keyrings/kanidm_ppa.asc
- name: Add kanidm repo
apt_repository:
repo: "deb [signed-by=/etc/apt/keyrings/kanidm_ppa.asc] https://kanidm.github.io/kanidm_ppa {{ ansible_distribution_release }} stable"
state: present
- name: install kanidm
apt:
name:
- kanidm
- kanidm-unixd