--- - name: Ensure data directory is present ansible.builtin.file: path: '/mnt/data1/site' state: directory mode: '0755' owner: 'root' group: 'root' - name: Ensure data subvolumes are present community.general.btrfs_subvolume: name: '/site/{{ item }}' loop: - 'data' - name: Ensure subvolume permissions are correct ansible.builtin.file: path: "/mnt/data1/site/{{ item }}" state: directory mode: '0755' owner: '82' group: '82' loop: - 'data' - name: Ensure configuration directory is present ansible.builtin.file: path: '/etc/site' state: directory mode: '0755' - name: Ensure environment file is present ansible.builtin.template: src: 'site.env.j2' dest: '/etc/site/site.env' mode: '0644' owner: 'root' group: 'root' notify: 'restart site' - name: Ensure backup scripts are present ansible.builtin.copy: src: "site.{{ item }}.backup.sh" dest: "/etc/backups/site.{{ item }}.backup.sh" owner: 'root' group: 'root' mode: '0644' loop: - 'data' - name: Ensure Container unit files are present ansible.builtin.copy: src: "{{ item }}" dest: "/etc/containers/systemd/{{ item }}" mode: '0644' owner: 'root' group: 'root' loop: - 'site.container' register: res - name: systemd-reload ansible.builtin.systemd_service: daemon_reload: true when: 'res.changed' - name: Ensure Caddyfile is present ansible.builtin.copy: src: 'site.Caddyfile' dest: '/etc/caddy/site.Caddyfile' mode: '0644' owner: 'root' group: 'root' notify: 'reload caddy' - name: Ensure site service is enabled ansible.builtin.service: name: 'site' enabled: true state: 'started'