--- - name: Create vaultwarden directory ansible.builtin.file: path: "{{ node['home_path'] }}/{{ item }}" state: "directory" owner: "{{ ansible_user }}" group: "svadmins" mode: "0770" loop: - "data/containers/vaultwarden" - "containers/vaultwarden" - "containers/vaultwarden/ssl" - name: Deploy root certificate ansible.builtin.copy: content: | {{ hostvars['console']['ca']['root']['crt'] }} dest: "{{ node['home_path'] }}/containers/vaultwarden/ssl/{{ root_cert_filename }}" owner: "{{ ansible_user }}" group: "svadmins" mode: "0440" become: true notify: "notification_restart_vaultwarden" no_log: true - name: Register secret value to podman secret containers.podman.podman_secret: name: "{{ item.name }}" data: "{{ item.value }}" state: "present" force: true loop: - name: "VW_ADMIN_TOKEN" value: "{{ hostvars['console']['vaultwarden']['admin']['hash'] }}" - name: "VW_DATABASE_URL" value: "postgresql://vaultwarden:{{ hostvars['console']['postgresql']['password']['vaultwarden'] | urlencode | replace('/', '%2F') }}\ @{{ services['postgresql']['domain'] }}.{{ domain['internal'] }}/vaultwarden_db?sslmode=verify-full&\ sslrootcert=/etc/ssl/vaultwarden/{{ root_cert_filename }}" notify: "notification_restart_vaultwarden" no_log: true - name: Deploy container file ansible.builtin.template: src: "{{ hostvars['console']['node']['config_path'] }}/services/containers/app/vaultwarden/vaultwarden.container.j2" dest: "{{ node['home_path'] }}/.config/containers/systemd/vaultwarden.container" owner: "{{ ansible_user }}" group: "svadmins" mode: "0644" notify: "notification_restart_vaultwarden" - name: Enable vaultwarden.service ansible.builtin.systemd: name: "vaultwarden.service" state: "started" enabled: true daemon_reload: true scope: "user" - name: Check container archive images ansible.builtin.stat: path: "{{ node['home_path'] }}/archives/containers/docker.io_vaultwarden_server_{{ version['containers']['vaultwarden'] }}.tar" register: container_archive_images - name: Save container archive images containers.podman.podman_save: image: - "docker.io/vaultwarden/server:{{ version['containers']['vaultwarden'] }}" dest: "{{ node['home_path'] }}/archives/containers/docker.io_vaultwarden_server_{{ version['containers']['vaultwarden'] }}.tar" format: "oci-archive" force: false when: not container_archive_images.stat.exists - name: Fetch container archive images ansible.builtin.fetch: src: "{{ node['home_path'] }}/archives/containers/docker.io_vaultwarden_server_{{ version['containers']['vaultwarden'] }}.tar" dest: "{{ hostvars['console']['node']['data_path'] }}/images/containers/" flat: true