repo: Move ansible setup to root dir
This commit is contained in:
parent
ff718b46ef
commit
6a1e01575c
41 changed files with 0 additions and 172 deletions
337
roles/arr/templates/docker-compose.yaml.j2
Normal file
337
roles/arr/templates/docker-compose.yaml.j2
Normal file
|
|
@ -0,0 +1,337 @@
|
|||
services:
|
||||
sonarr:
|
||||
container_name: sonarr
|
||||
image: lscr.io/linuxserver/sonarr:latest
|
||||
networks:
|
||||
- caddy
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/config/sonarr:/config"
|
||||
- "{{ arrstack_serve_dir }}/media/tv:/data/media/tv"
|
||||
- "{{ arrstack_serve_dir }}/files/usenet:/data/usenet"
|
||||
- "{{ arrstack_serve_dir }}/files/torrent:/data/torrent"
|
||||
restart: unless-stopped
|
||||
labels:
|
||||
caddy: "http://sonarr.pichi.berlin"
|
||||
caddy.reverse_proxy: "{{ '{{' }}upstreams 8989{{ '}}'}}"
|
||||
|
||||
radarr:
|
||||
container_name: radarr
|
||||
image: lscr.io/linuxserver/radarr:latest
|
||||
networks:
|
||||
- caddy
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/config/radarr:/config"
|
||||
- "/mnt/ext/data/media/movies:/data/media/movies" # FIXME: Find solution
|
||||
- "{{ arrstack_serve_dir }}/files/usenet:/data/usenet"
|
||||
- "{{ arrstack_serve_dir }}/files/torrent:/data/torrent"
|
||||
restart: unless-stopped
|
||||
labels:
|
||||
caddy: "http://radarr.pichi.berlin"
|
||||
caddy.reverse_proxy: "{{ '{{' }}upstreams 7878{{ '}}'}}"
|
||||
|
||||
lidarr:
|
||||
container_name: lidarr
|
||||
image: lscr.io/linuxserver/lidarr:latest
|
||||
networks:
|
||||
- caddy
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
- MB_USER={{ arrstack_mb_user }}
|
||||
- MB_PASS={{ arrstack_mb_pass }}
|
||||
environment:
|
||||
- DOCKER_MODS=linuxserver/mods:universal-docker
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/config/lidarr:/config"
|
||||
- "/var/run/docker.sock:/var/run/docker.sock:ro"
|
||||
- "{{ arrstack_serve_dir }}/media/music:/data/media/music"
|
||||
- "{{ arrstack_serve_dir }}/files/usenet:/data/usenet"
|
||||
- "{{ arrstack_serve_dir }}/files/torrent:/data/torrent"
|
||||
restart: unless-stopped
|
||||
labels:
|
||||
caddy: "http://lidarr.pichi.berlin"
|
||||
caddy.reverse_proxy: "{{ '{{' }}upstreams 8686{{ '}}'}}"
|
||||
|
||||
readarr:
|
||||
container_name: readarr
|
||||
image: lscr.io/linuxserver/readarr:develop
|
||||
networks:
|
||||
- caddy
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/config/readarr:/config"
|
||||
- "{{ arrstack_serve_dir }}/media/audiobooks:/data/media/audiobooks"
|
||||
- "{{ arrstack_serve_dir }}/files/usenet:/data/usenet"
|
||||
- "{{ arrstack_serve_dir }}/files/torrent:/data/torrent"
|
||||
restart: unless-stopped
|
||||
labels:
|
||||
caddy: "http://readarr.pichi.berlin"
|
||||
caddy.reverse_proxy: "{{ '{{' }}upstreams 8787{{ '}}'}}"
|
||||
|
||||
prowlarr:
|
||||
container_name: prowlarr
|
||||
image: lscr.io/linuxserver/prowlarr:develop
|
||||
networks:
|
||||
- caddy
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/config/prowlarr:/config"
|
||||
restart: unless-stopped
|
||||
labels:
|
||||
caddy: "http://prowlarr.pichi.berlin"
|
||||
caddy.reverse_proxy: "{{ '{{' }}upstreams 9696{{ '}}'}}"
|
||||
|
||||
beets:
|
||||
image: lscr.io/linuxserver/beets:latest
|
||||
container_name: beets
|
||||
networks:
|
||||
- caddy
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
- MB_USER={{ arrstack_mb_user }}
|
||||
- MB_PASS={{ arrstack_mb_pass }}
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/config/beets:/config"
|
||||
- "{{ arrstack_serve_dir }}/media/music:/music"
|
||||
- "{{ arrstack_serve_dir }}/files/music-unsorted:/downloads"
|
||||
restart: unless-stopped
|
||||
labels:
|
||||
caddy: "http://prowlarr.pichi.berlin"
|
||||
caddy.reverse_proxy: "{{ '{{' }}upstreams 8337{{ '}}'}}"
|
||||
|
||||
sabnzbd:
|
||||
container_name: sabnzbd
|
||||
image: lscr.io/linuxserver/sabnzbd:latest
|
||||
networks:
|
||||
- caddy
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/config/sabnzbd:/config"
|
||||
- "{{ arrstack_serve_dir }}/files/usenet:/data/usenet:rw"
|
||||
restart: unless-stopped
|
||||
labels:
|
||||
caddy: "http://usenet.pichi.berlin"
|
||||
caddy.reverse_proxy: "{{ '{{' }}upstreams 8080{{ '}}'}}"
|
||||
|
||||
vpn:
|
||||
container_name: vpn
|
||||
image: qmcgaw/gluetun:v3
|
||||
networks:
|
||||
- caddy
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
- VPN_PORT_FORWARDING_STATUS_FILE=/gluetun/forwarded_port
|
||||
- FIREWALL_OUTBOUND_SUBNETS=172.18.0.0/24
|
||||
- BLOCK_SURVEILLANCE=on
|
||||
- VPN_SERVICE_PROVIDER={{ arrstack_vpn_provider }}
|
||||
- OPENVPN_USER={{ arrstack_vpn_user }}
|
||||
- OPENVPN_PASSWORD={{ arrstack_vpn_pass }}
|
||||
- SERVER_REGIONS={{ arrstack_vpn_regions }}
|
||||
- PORT_FORWARD_ONLY=true
|
||||
- VPN_PORT_FORWARDING=on
|
||||
- VPN_PORT_FORWARDING_PROVIDER={{ arrstack_vpn_provider }}
|
||||
- QBITTORRENT_USER={{ arrstack_qbit_user }}
|
||||
- QBITTORRENT_PASS={{ arrstack_qbit_pass }}
|
||||
cap_add:
|
||||
- NET_ADMIN
|
||||
devices:
|
||||
- /dev/net/tun:/dev/net/tun
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/config/gluetun:/gluetun"
|
||||
#ports: # TODO: should this be exposed?
|
||||
# - 8000:8000 # gluetun http control
|
||||
restart: unless-stopped
|
||||
labels:
|
||||
caddy: "http://torrent.pichi.berlin"
|
||||
caddy.reverse_proxy: "{{ '{{' }}upstreams 8888{{ '}}'}}"
|
||||
qbittorrent:
|
||||
image: linuxserver/qbittorrent
|
||||
container_name: qbittorrent
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
- WEBUI_PORT=8888
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/config/piaqbit:/config"
|
||||
- "{{ arrstack_env_dir }}/config/gluetun:/gluetun"
|
||||
- "{{ arrstack_serve_dir }}/files/torrent:/downloads"
|
||||
depends_on:
|
||||
- vpn
|
||||
network_mode: "service:vpn"
|
||||
restart: unless-stopped
|
||||
gluetun-qbittorrent-port-manager:
|
||||
image: patrickaclark/gluetun-qbittorrent-port-manager:latest
|
||||
container_name: qbit-port-manager
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
- WEBUI_PORT=8888
|
||||
- QBITTORRENT_SERVER=qbittorrent # IP Address of qbittorrent
|
||||
- QBITTORRENT_PORT=8888
|
||||
- PORT_FORWARDED=/gluetun/forwarded_port
|
||||
- HTTP_S=http # Select 'http' or 'https' depending on if you use certificates.
|
||||
- GLUETUN_HOST=vpn # IP or FQDN of gluetun control server
|
||||
- GLUETUN_PORT=8000 # port of gluetun control server
|
||||
- RECHECK_TIME=60 # number of seconds between checks to gluetun server for port
|
||||
- VPN_SERVICE_PROVIDER={{ arrstack_vpn_provider }}
|
||||
- OPENVPN_USER={{ arrstack_vpn_user }}
|
||||
- OPENVPN_PASSWORD={{ arrstack_vpn_pass }}
|
||||
- SERVER_REGIONS={{ arrstack_vpn_regions }}
|
||||
- PORT_FORWARD_ONLY=true
|
||||
- VPN_PORT_FORWARDING=on
|
||||
- VPN_PORT_FORWARDING_PROVIDER={{ arrstack_vpn_provider }}
|
||||
- QBITTORRENT_USER={{ arrstack_qbit_user }}
|
||||
- QBITTORRENT_PASS={{ arrstack_qbit_pass }}
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/config/gluetun:/gluetun"
|
||||
depends_on:
|
||||
- vpn
|
||||
network_mode: "service:vpn"
|
||||
restart: unless-stopped
|
||||
healthcheck:
|
||||
test: ["CMD", "curl", "-H", "Authorization: $controlServerAuthKey", "-s", "http://localhost:8000/v1/openvpn/status", "|", "grep", "-q", '{"status":"running"}']
|
||||
interval: 30s
|
||||
timeout: 10s
|
||||
start_period: 60s
|
||||
retries: 3
|
||||
|
||||
homarr:
|
||||
image: ghcr.io/ajnart/homarr:latest
|
||||
container_name: homarr
|
||||
networks:
|
||||
- caddy
|
||||
volumes:
|
||||
- {{ arrstack_env_dir }}/config/homarr/configs:/app/data/configs
|
||||
- {{ arrstack_env_dir }}/config/homarr/icons:/app/public/icons
|
||||
- {{ arrstack_env_dir }}/config/homarr/data:/data
|
||||
- /var/run/docker.sock:/var/run/docker.sock # Optional, only if you want docker integration
|
||||
restart: unless-stopped
|
||||
labels:
|
||||
caddy: "http://pichi.berlin"
|
||||
caddy.reverse_proxy: "{{ '{{' }}upstreams 7575{{ '}}'}}"
|
||||
|
||||
jellyseerr:
|
||||
image: fallenbagel/jellyseerr:latest
|
||||
container_name: jellyseerr
|
||||
networks:
|
||||
- caddy
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/config/jellyseerr:/app/config"
|
||||
restart: unless-stopped
|
||||
labels:
|
||||
caddy: "http://get.pichi.berlin"
|
||||
caddy.reverse_proxy: "{{ '{{' }}upstreams 5055{{ '}}'}}"
|
||||
|
||||
audiobookshelf:
|
||||
container_name: audiobookshelf
|
||||
image: ghcr.io/advplyr/audiobookshelf:latest
|
||||
networks:
|
||||
- caddy
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/config/audiobookshelf:/config"
|
||||
- "{{ arrstack_env_dir }}/data/audiobookshelf:/metadata"
|
||||
- "{{ arrstack_serve_dir }}/media/audiobooks:/audiobooks"
|
||||
# - "{{ arrstack_serve_dir }}/media/podcasts:/podcasts" # TODO: If integrating podcasts
|
||||
restart: unless-stopped
|
||||
labels:
|
||||
caddy: "http://books.pichi.berlin"
|
||||
caddy.reverse_proxy: "{{ '{{' }}upstreams 80{{ '}}'}}"
|
||||
|
||||
jellyfin:
|
||||
image: lscr.io/linuxserver/jellyfin:latest
|
||||
container_name: jellyfin
|
||||
networks:
|
||||
- caddy
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
devices:
|
||||
- /dev/dri:/dev/dri
|
||||
#environment:
|
||||
#- JELLYFIN_PublishedServerUrl=192.168.0.5 #optional
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/config/jellyfin:/config"
|
||||
- "{{ arrstack_env_dir }}/data/jellyfin:/config/data"
|
||||
- "/mnt/ext/data/media/movies:/media/movies" # FIXME: To be changed?
|
||||
- "{{ arrstack_serve_dir }}/media/tv:/media/tv"
|
||||
- "{{ arrstack_serve_dir }}/media/music:/media/music"
|
||||
ports: # FIXME: how to enable discovery behind proxies?
|
||||
- 7359:7359/udp #optional - network discovery
|
||||
- 1900:1900/udp #optional - dlna discovery
|
||||
restart: unless-stopped
|
||||
labels:
|
||||
caddy: "http://media.pichi.berlin"
|
||||
caddy.reverse_proxy: "{{ '{{' }}upstreams 8096{{ '}}'}}"
|
||||
|
||||
gonic:
|
||||
image: sentriz/gonic:latest
|
||||
networks:
|
||||
- caddy
|
||||
environment:
|
||||
- PUID={{ arrstack_puid }}
|
||||
- PGID={{ arrstack_pgid }}
|
||||
- TZ={{ arrstack_tz }}
|
||||
- UMASK_SET={{ arrstack_umask_set }}
|
||||
volumes:
|
||||
- "{{ arrstack_env_dir }}/data/gonic:/data"
|
||||
- "{{ arrstack_env_dir }}/data/gonic_playlists:/playlists"
|
||||
- "/srv/media/music:/music:ro"
|
||||
- "/srv/media/podcasts:/podcasts"
|
||||
#- /path/to/cache:/cache # transcode / covers / etc cache dir
|
||||
labels:
|
||||
caddy: "http://music.pichi.berlin"
|
||||
caddy.reverse_proxy: "{{ '{{' }}upstreams 80{{ '}}'}}"
|
||||
|
||||
|
||||
networks:
|
||||
caddy:
|
||||
external: true
|
||||
|
||||
volumes:
|
||||
caddy_data: {}
|
||||
Loading…
Add table
Add a link
Reference in a new issue