- name: "Create {{ vaultwarden_project_dir }} project directory" file: path: "{{ vaultwarden_project_dir }}" state: directory - name: Template docker-compose.yaml to project directory template: src: docker-compose.yaml dest: "{{ vaultwarden_project_dir }}/docker-compose.yaml" owner: "{{ ansible_env['USER'] }}" group: "{{ ansible_env['USER'] }}" mode: '640' - name: "Create directory {{ volumes['vaultwarden_datadir'] }} with correct permissions" file: path: "{{ volumes['vaultwarden_datadir'] }}" state: directory owner: "{{ users['vaultwarden'] + uid_shift }}" group: "{{ users['vaultwarden'] + uid_shift }}" mode: '770' become: true - name: Pull project services community.docker.docker_compose: project_src: "{{ vaultwarden_project_dir }}" recreate: never pull: true debug: true when: docker_pull_images | bool register: vaultwarden_docker_compose_pull_result - name: Display pulled image(s) name set_fact: vaultwarden_pulled_images: "{{ vaultwarden_pulled_images | default([]) + [item.pulled_image.name] }}" loop: "{{ vaultwarden_docker_compose_pull_result['actions'] | default([]) | selectattr('pulled_image', 'defined') }}" - name: Include backup tasks include_tasks: file: backup.yml # Make a backup if we didn't already make one and we pulled a new image when: not run_backup and vaultwarden_pulled_images is defined - name: Create/Restart project services community.docker.docker_compose: project_src: "{{ vaultwarden_project_dir }}"