1 Commits

Author SHA1 Message Date
00a12a2164 add cron job to download extra dns json file 2026-04-07 04:18:39 -07:00
7 changed files with 48 additions and 5 deletions

View File

@ -25,3 +25,6 @@ ENABLE_DERP=false
# See https://git.coopcloud.tech/coop-cloud/backup-bot-two
ENABLE_BACKUPS=true
## allow cron updater
#COMPOSE_FILE="$COMPOSE_FILE:compose.dns.yml"
#DNS_REPO=owner/repo

View File

@ -1,3 +1,5 @@
# Set any config versions here
# Docs: https://docs.coopcloud.tech/maintainers/handbook/#manage-configs
export CONFIG_YAML_VERSION=v4
export CONFIG_YAML_VERSION=v5
export EXTRA_RECORDS_VERSION=v1
export DNS_DOWNLOADER_VERSION=v1

24
compose.dns.yml Normal file
View File

@ -0,0 +1,24 @@
---
services:
cron:
image: alpine:3.23.3
volumes:
- data:/data
configs:
- source: extra_dns_downloader
target: /entrypoint.sh
entrypoint: ["/entrypoint.sh"]
deploy:
mode: replicated
replicas: 0
labels:
- "swarm.cronjob.enable=true"
- "swarm.cronjob.schedule=0 * * * *"
restart_policy:
condition: none
configs:
extra_dns_downloader:
name: ${STACK_NAME}_dns_downloader_${DNS_DOWNLOADER_VERSION}
file: extra-downloader.sh
template_driver: golang

View File

@ -11,6 +11,8 @@ services:
configs:
- source: config_yaml
target: /etc/headscale/config.yaml
- source: extra_dns_records
target: /var/lib/headscale/extra-records.json
deploy:
restart_policy:
condition: on-failure
@ -20,7 +22,7 @@ services:
- "traefik.http.routers.${STACK_NAME}.rule=Host(`${DOMAIN}`${EXTRA_DOMAINS})"
- "traefik.http.routers.${STACK_NAME}.entrypoints=web-secure"
- "traefik.http.routers.${STACK_NAME}.tls.certresolver=${LETS_ENCRYPT_ENV}"
- "coop-cloud.${STACK_NAME}.version=0.3.0+v0.28"
- "coop-cloud.${STACK_NAME}.version=0.1.0+v0.28"
# Enable backups: https://docs.coopcloud.tech/maintainers/handbook/#how-do-i-configure-backuprestore
- "backupbot.backup=${ENABLE_BACKUPS:-true}"
- "backupbot.backup.path=/var/lib/headscale"
@ -32,7 +34,7 @@ services:
start_period: 1m
ui:
image: ghcr.io/gurucomputing/headscale-ui:2026.03.17
image: ghcr.io/gurucomputing/headscale-ui:2025.08.23
deploy:
labels:
- traefik.enable=true
@ -43,6 +45,7 @@ services:
networks:
- proxy
networks:
proxy:
external: true
@ -55,3 +58,7 @@ configs:
name: ${STACK_NAME}_config_yaml_${CONFIG_YAML_VERSION}
file: config.yaml.tmpl
template_driver: golang
extra_dns_records:
name: ${STACK_NAME}_extra_records_${EXTRA_RECORDS_VERSION}
file: extra-records.json

View File

@ -308,7 +308,7 @@ dns:
# Extra DNS records
# so far only A and AAAA records are supported (on the tailscale side)
# See: docs/ref/dns.md
extra_records: []
# extra_records: []
# - name: "grafana.myvpn.example.com"
# type: "A"
# value: "100.64.0.3"
@ -318,7 +318,7 @@ dns:
#
# Alternatively, extra DNS records can be loaded from a JSON file.
# Headscale processes this file on each change.
# extra_records_path: /var/lib/headscale/extra-records.json
extra_records_path: /var/lib/headscale/extra-records.json
# Unix socket used for the CLI to connect without authentication
# Note: for production you will want to set this to something like:

6
extra-downloader.sh Executable file
View File

@ -0,0 +1,6 @@
apk add --no-cache --quiet wget
apk add --no-cache --quiet curl
apk add --no-cache --quiet jq
version=$(curl https://git.coopcloud.tech/api/v1/repos/{{ env "DNS_REPO" }}/tags | jq -r '.[0].name')
wget https://git.coopcloud.tech/{{ env "DNS_REPO" }}/raw/tag/$version/headscale-records.json -O /data/extra-records.json

1
extra-records.json Normal file
View File

@ -0,0 +1 @@
[]