--- - name: "Configure authelia application" hosts: all vars_files: - vars/ports.yml - vars/vars.yml vars: app_name: "authelia" app_user: "{{ app_name }}" base_dir: "/home/{{ app_user }}" config_dir: "{{ (base_dir, 'config') | path_join }}" tasks: - name: "Create user and environment" ansible.builtin.import_role: name: owner vars: owner_name: "{{ app_user }}" owner_extra_groups: ["docker"] - name: "Create internal application directories" ansible.builtin.file: path: "{{ item }}" state: "directory" owner: "{{ app_user }}" group: "{{ app_user }}" mode: "0700" loop: - "{{ config_dir }}" - name: "Copy configuration files" ansible.builtin.copy: src: "files/{{ app_name }}/{{ item }}" dest: "{{ (config_dir, item) | path_join }}" owner: "{{ app_user }}" group: "{{ app_user }}" mode: "0600" loop: - "configuration.yml" - "users.yml" - name: "Copy docker compose file" ansible.builtin.template: src: "./files/{{ app_name }}/docker-compose.yml.j2" dest: "{{ base_dir }}/docker-compose.yml" owner: "{{ app_user }}" group: "{{ app_user }}" mode: "0640" - name: "Run application with docker compose" community.docker.docker_compose_v2: project_src: "{{ base_dir }}" state: "present" remove_orphans: true - name: "Restart application with docker compose" community.docker.docker_compose_v2: project_src: "{{ base_dir }}" state: "restarted"