From cbe20c16f3ca7e481beafe54792467f2cd58c8c1 Mon Sep 17 00:00:00 2001 From: Mike Wilson Date: Fri, 24 Mar 2023 23:46:52 -0400 Subject: [PATCH] Added Navidrome --- ansible/main.yml | 2 ++ ansible/roles/navidrome/tasks/main.yml | 29 +++++++++++++++++++ .../navidrome/templates/docker-compose.yml | 21 ++++++++++++++ 3 files changed, 52 insertions(+) create mode 100644 ansible/roles/navidrome/tasks/main.yml create mode 100644 ansible/roles/navidrome/templates/docker-compose.yml diff --git a/ansible/main.yml b/ansible/main.yml index f5d5e61..fa7b8b3 100644 --- a/ansible/main.yml +++ b/ansible/main.yml @@ -20,3 +20,5 @@ - gitea - unifi-controller - beets + - name: navidrome + tags: test diff --git a/ansible/roles/navidrome/tasks/main.yml b/ansible/roles/navidrome/tasks/main.yml new file mode 100644 index 0000000..5c0fdfc --- /dev/null +++ b/ansible/roles/navidrome/tasks/main.yml @@ -0,0 +1,29 @@ +- name: Create service user + user: + name: "{{ role_name }}" + system: true + register: service_user + become: true + +- name: Create install directory + file: + path: "{{ install_directory }}/{{ role_name }}" + state: directory + owner: "{{ docker_user }}" + mode: "{{ docker_compose_directory_mask }}" + become: true + +- name: Copy docker-compose file to destination + template: + src: docker-compose.yml + dest: "{{ install_directory }}/{{ role_name }}/docker-compose.yml" + owner: "{{ docker_user }}" + mode: "{{ docker_compose_file_mask }}" + validate: docker-compose -f %s config + become: true + +- name: Start docker container + community.docker.docker_compose: + project_src: "{{ install_directory }}/{{ role_name }}" + pull: true + remove_orphans: yes diff --git a/ansible/roles/navidrome/templates/docker-compose.yml b/ansible/roles/navidrome/templates/docker-compose.yml new file mode 100644 index 0000000..3c65474 --- /dev/null +++ b/ansible/roles/navidrome/templates/docker-compose.yml @@ -0,0 +1,21 @@ +version: "{{ docker_compose_version }}" + +networks: + traefik: + external: true + +services: + {{ role_name }}: + container_name: "{{ role_name }}" + image: deluan/navidrome + restart: unless-stopped + user: "{{ service_user.uid }}:{{ service_user.uid }}" + networks: + - traefik + volumes: + - "{{ data_dir }}/{{ role_name }}:/data" + - "{{ media_storage_mnt }}/data/media/music:/music:ro" + labels: + traefik.enable: true + traefik.http.routers.{{ role_name }}.rule: "Host(`music.{{ personal_domain }}`)" + traefik.http.services.navidrome.loadbalancer.server.port: 4533