ansible-nas/roles/duplicacy/tasks/main.yml

49 lines
1.9 KiB
YAML
Raw Normal View History

---
2022-09-07 21:37:47 +00:00
- name: Start Duplicacy
block:
- name: Create Duplicacy Directories
2023-04-15 13:11:49 +00:00
ansible.builtin.file:
2022-09-07 21:37:47 +00:00
path: "{{ item }}"
state: directory
with_items:
- "{{ duplicacy_config_directory }}"
- "{{ duplicacy_logs_directory }}"
- "{{ duplicacy_cache_directory }}"
2022-09-07 21:37:47 +00:00
- name: Duplicacy Docker Container
2023-04-15 13:11:49 +00:00
community.docker.docker_container:
2022-09-07 21:37:47 +00:00
name: "{{ duplicacy_container_name }}"
image: saspus/duplicacy-web:mini
hostname: "{{ duplicacy_hostname }}"
pull: true
ports:
- "{{ duplicacy_port }}:3875"
volumes:
- "{{ duplicacy_config_directory }}:/config:rw"
- "{{ duplicacy_logs_directory }}:/logs:rw"
- "{{ duplicacy_cache_directory }}:/cache:rw"
- "{{ samba_shares_root }}:/backuproot:{{ duplicacy_data_permissions }}"
env:
DUPLICACY_WEB_VERSION: "{{ duplicacy_web_version }}"
TZ: "{{ ansible_nas_timezone }}"
USR_ID: "{{ duplicacy_user_id }}"
GRP_ID: "{{ duplicacy_group_id }}"
restart_policy: unless-stopped
memory: "{{ duplicacy_memory }}"
labels:
traefik.enable: "{{ duplicacy_available_externally | string }}"
traefik.http.routers.duplicacy.rule: "Host(`{{ duplicacy_hostname }}.{{ ansible_nas_domain }}`)"
traefik.http.routers.duplicacy.tls.certresolver: "letsencrypt"
traefik.http.routers.duplicacy.tls.domains[0].main: "{{ ansible_nas_domain }}"
traefik.http.routers.duplicacy.tls.domains[0].sans: "*.{{ ansible_nas_domain }}"
traefik.http.services.duplicacy.loadbalancer.server.port: "3875"
when: duplicacy_enabled is true
- name: Stop Duplicacy
block:
- name: Stop Duplicacy
2023-04-15 13:11:49 +00:00
community.docker.docker_container:
2022-09-07 21:37:47 +00:00
name: "{{ duplicacy_container_name }}"
state: absent
when: duplicacy_enabled is false