48 lines
1.6 KiB
YAML
48 lines
1.6 KiB
YAML
- name: "Create {{ vaultwarden_project_dir }} project directory"
|
|
file:
|
|
path: "{{ vaultwarden_project_dir }}"
|
|
state: directory
|
|
|
|
- name: Template docker-compose.yaml & .env to project directory
|
|
template:
|
|
src: "{{ item }}"
|
|
dest: "{{ vaultwarden_project_dir }}/{{ item }}"
|
|
owner: "{{ ansible_env['USER'] }}"
|
|
group: "{{ ansible_env['USER'] }}"
|
|
mode: '640'
|
|
loop:
|
|
- docker-compose.yaml
|
|
- .env
|
|
|
|
- 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 }}"
|