57 lines
1.4 KiB
YAML
57 lines
1.4 KiB
YAML
# vim: ft=yaml.ansible
|
|
---
|
|
- name: create mailu volume folders
|
|
file:
|
|
name: "{{ services.mailu.volume_folder }}/{{ volume }}"
|
|
state: directory
|
|
loop:
|
|
- redis
|
|
- certs
|
|
- data
|
|
- dkim
|
|
- mail
|
|
- mailqueue
|
|
- filter
|
|
- postgres
|
|
- webmail
|
|
- overrides
|
|
- overrides/nginx
|
|
- overrides/dovecot
|
|
- overrides/postfix
|
|
- overrides/rspamd
|
|
- overrides/rainloop
|
|
loop_control:
|
|
loop_var: volume
|
|
|
|
- name: upload mailu.env file
|
|
template:
|
|
src: mailu/env.j2
|
|
dest: "{{ services.mailu.volume_folder }}/mailu.env"
|
|
|
|
- name: hard link to Let's Encrypt TLS certificate
|
|
file:
|
|
src: "{{ services.nginx_proxy.volume_folder }}/certs/{{ services.mailu.domain }}/fullchain.pem"
|
|
dest: "{{ services.mailu.volume_folder }}/certs/cert.pem"
|
|
state: hard
|
|
force: true
|
|
when: letsencrypt_enabled
|
|
|
|
- name: hard link to Let's Encrypt TLS key
|
|
file:
|
|
src: "{{ services.nginx_proxy.volume_folder }}/certs/{{ services.mailu.domain }}/key.pem"
|
|
dest: "{{ services.mailu.volume_folder }}/certs/key.pem"
|
|
state: hard
|
|
force: true
|
|
when: letsencrypt_enabled
|
|
|
|
- name: Upload Compose file for for Mailu
|
|
template:
|
|
src: compose-files/mailu.yml.j2
|
|
dest: "{{ services.mailu.volume_folder }}/docker-compose.yml"
|
|
|
|
- name: Deploy Mailu
|
|
docker_compose:
|
|
project_src: "{{ services.mailu.volume_folder }}"
|
|
pull: true
|
|
state: present
|