version: "3.9" services: powerdns: image: ${PDNS_IMAGE:-powerdns/pdns:latest} container_name: ${PDNS_CONTAINER_NAME:-powerdns} restart: unless-stopped # Die Umgebungsvariablen dienen jetzt nur noch als Futter für das Script environment: PDNS_API_KEY: ${PDNS_API_KEY:-changeme} PDNS_API_ALLOW_FROM: ${PDNS_API_ALLOW_FROM:-0.0.0.0/0,::/0} PDNS_LAUNCH: ${PDNS_LAUNCH:-gsqlite3} PDNS_GSQLITE3_DATABASE: ${PDNS_GSQLITE3_DATABASE:-/data/pdns.sqlite3} PDNS_GPGSQL_HOST: ${PDNS_GPGSQL_HOST:-} PDNS_GPGSQL_PORT: ${PDNS_GPGSQL_PORT:-5432} PDNS_GPGSQL_USER: ${PDNS_GPGSQL_USER:-} PDNS_GPGSQL_PASSWORD: ${PDNS_GPGSQL_PASSWORD:-} PDNS_GPGSQL_DBNAME: ${PDNS_GPGSQL_DBNAME:-} PDNS_LOG_LEVEL: ${PDNS_LOG_LEVEL:-6} entrypoint: ["/bin/sh","-lc"] command: - | set -eu mkdir -p /etc/powerdns/pdns.d # Versuche Verzeichnis-Rechte zu setzen, ignoriere Fehler (Operation not permitted) chmod 777 /data || echo "Could not change /data permissions, hoping for the best..." PDNS_BIN=$$(which pdns_server || echo "/usr/local/sbin/pdns_server") DB_FILE="$${PDNS_GSQLITE3_DATABASE}" if [ "$${PDNS_LAUNCH}" = "gsqlite3" ] && [ ! -f "$$DB_FILE" ]; then echo "Initialisierung der Datenbank in $$DB_FILE" # Wir versuchen die Datei direkt zu erzeugen # Wenn das fehlschlägt, liegt es am Host-Mount if touch "$$DB_FILE" 2>/dev/null; then chmod 666 "$$DB_FILE" # Schema suchen SCHEMA=$$(find /usr -name schema.sqlite3.sql | head -n 1) if [ -n "$$SCHEMA" ]; then sqlite3 "$$DB_FILE" < "$$SCHEMA" echo "Schema erfolgreich importiert." fi else echo "FATAL: Keine Schreibrechte in /data. Bitte auf dem Host 'chmod 777' auf das Verzeichnis ausführen!" exit 1 fi fi # Config schreiben cat > /etc/powerdns/pdns.d/99-env.conf <