mirror of
https://github.com/kevinveenbirkenbach/computer-playbook.git
synced 2025-12-02 07:38:22 +00:00
- Replace legacy utils/run_once.yml with the new helpers utils/once_flag.yml and utils/once_finalize.yml - Introduce utils/compose_up.yml to ensure docker-compose stacks are up and to flush handlers safely without coupling to run-once flags - Migrate all affected roles (desk-*, dev-*, sys-ctl-*, sys-svc-*, web-app-*, web-svc-*, util-*) to the new run-once helpers - Rework sys-svc-msmtp to auto-load Mailu once per deploy, check reachability, and reuse the running stack instead of requiring multiple playbook passes - Adjust web-app-mailu to integrate cert deployment, handler flushing, and run-once handling so Mailu is fully initialized in a single deploy - Improve Matomo, CDN, logout and CSP/health-check related roles to cooperate with the new compose_up / once_* pattern - Simplify alarm/backup/timer/service orchestration (sys-ctl-alm-*, sys-bkp-provider, sys-timer-cln-bkps, etc.) by moving run-once logic into dedicated 01_core.yml files - Update integration tests so utils/once_flag.yml and utils/once_finalize.yml are recognised as valid run-once providers, keeping the global run_once_* guarantees consistent - Align frontend injection and service dependencies so Mastodon- and Mailu-related services can be brought up coherently within a single deployment cycle rather than several iterations
46 lines
1.8 KiB
YAML
46 lines
1.8 KiB
YAML
- block:
|
|
- name: Include dependency 'sys-svc-webserver-https'
|
|
include_role:
|
|
name: sys-svc-webserver-https
|
|
when: run_once_sys_svc_webserver_https is not defined
|
|
- include_tasks: utils/once_finalize.yml
|
|
when: run_once_sys_svc_certs is not defined
|
|
|
|
- name: "Include flavor '{{ CERTBOT_FLAVOR }}' for '{{ domain }}'"
|
|
include_tasks: "{{ [role_path, 'tasks/flavors', CERTBOT_FLAVOR ~'.yml'] | path_join }}"
|
|
|
|
#- name: "Cleanup dedicated cert for '{{ domain }}'"
|
|
# command: >-
|
|
# certbot delete --cert-name {{ domain }} --non-interactive
|
|
# when:
|
|
# - MODE_CLEANUP | bool
|
|
# # Cleanup mode is enabled
|
|
# - CERTBOT_FLAVOR != 'dedicated'
|
|
# # Wildcard certificate is enabled
|
|
# - domain.split('.') | length == (PRIMARY_DOMAIN.split('.') | length + 1) and domain.endswith(PRIMARY_DOMAIN)
|
|
# # AND: The domain is a direct first-level subdomain of the primary domain
|
|
# - domain != PRIMARY_DOMAIN
|
|
# # The domain is not the primary domain
|
|
# register: certbot_result
|
|
# failed_when: certbot_result.rc != 0 and ("No certificate found with name" not in certbot_result.stderr)
|
|
# changed_when: certbot_result.rc == 0 and ("No certificate found with name" not in certbot_result.stderr)
|
|
|
|
- name: "Find SSL cert folder for '{{ domain }}'"
|
|
cert_folder_find:
|
|
domain: "{{ domain }}"
|
|
cert_base_path: "{{ LETSENCRYPT_LIVE_PATH }}"
|
|
debug: "{{ MODE_DEBUG | bool }}"
|
|
register: cert_folder_result
|
|
delegate_to: "{{ inventory_hostname }}"
|
|
changed_when: false
|
|
|
|
- name: "Set ssl_cert_folder fact to '{{ cert_folder_result.folder }}'"
|
|
set_fact:
|
|
ssl_cert_folder: "{{ cert_folder_result.folder }}"
|
|
changed_when: false
|
|
|
|
- name: "Ensure ssl_cert_folder is set for domain {{ domain }}"
|
|
fail:
|
|
msg: "No certificate folder found for domain {{ domain }}"
|
|
when: ssl_cert_folder is undefined or ssl_cert_folder is none
|