From 5cf152a114ef88c31b003a7ab555bfd1b0f2cc5c Mon Sep 17 00:00:00 2001 From: alcapone1933 Date: Sun, 27 Nov 2022 01:08:36 +0100 Subject: [PATCH 1/2] update --- README.md | 59 +++++++++++++++++++++++++++---------------------------- 1 file changed, 29 insertions(+), 30 deletions(-) diff --git a/README.md b/README.md index d00d17c..77183e6 100644 --- a/README.md +++ b/README.md @@ -7,13 +7,13 @@ [![Website](https://shields.cosanostra-cloud.de/website?down_color=red&down_message=down&label=Status%20Webseite%20IPV64.NET&style=plastic&up_color=green&up_message=ready&url=https%3A%2F%2Fipv64.net%2F)](https://ipv64.net/)   -# DDNS Updater in Docker für Free DynDNS [IPv64.net](https://ipv64.net/) -NUR FÜR IPV4- +# DDNS Updater in Docker für Free DynDNS [IPv64.net](https://ipv64.net/) - NUR FÜR IPV4 - Dieser Docker Container ist ein DDNS Updater für Free DynDNS - ipv64.net. -Bei Änderung der ipv4 Adresse am Standort, wird die neue ipv4 Adresse als A-Record an ipv64.net geschickt. +Bei einer Änderung der ipv4 Adresse am Standort wird die neue ipv4 Adresse als A-Record an ipv64.net geschickt. -Wenn sie dieses Docker Projekt nutzen möchten, ändern sie die Environments vor dem starten des Docker Containers. +Wenn Du dieses Docker Projekt nutzen möchtest, ändere bitte die Environments vor dem Starten des Docker Containers.   @@ -23,11 +23,11 @@ Wenn sie dieses Docker Projekt nutzen möchten, ändern sie die Environments vor ### Domain - * Hier bitte deine DOMAIN eintragen (ersetzen) die unter https://ipv64.net/dyndns.php erstellt wurde Z.B "deine-domain.ipv64.net" + * Hier bitte deine DOMAIN eintragen (ersetzen), die unter https://ipv64.net/dyndns.php erstellt wurde, z.B "deine-domain.ipv64.net" `-e "DOMAIN_IPV64=deine-domain.ipv64.net"` - * Wenn sie mehrer DOMAINS eintragen wollen bitte mit Komma trennen + * Wenn Du mehrere DOMAINS eintragen willst, bitte mit Komma trennen: `-e "DOMAIN_IPV64=deine-domain.ipv64.net,deine-domain.ipv64.de"` @@ -35,19 +35,19 @@ Wenn sie dieses Docker Projekt nutzen möchten, ändern sie die Environments vor ### Domain Praefix - * Wenn sie einen DOMAIN PRAEFIX verwenden wollen, dann benutzen sie die Variable ***DOMAIN_PRAEFIX_YES=yes*** und ***DOMAIN_PRAEFIX*** + * Wenn Du einen DOMAIN PRAEFIX verwenden willst, dann benutze die Variablen ***DOMAIN_PRAEFIX_YES=yes*** und ***DOMAIN_PRAEFIX*** `-e "DOMAIN_PRAEFIX_YES=yes"` - * Hier bitte nur ein DOMAIN PRAEFIX eintragen (ersetzen) der unter https://ipv64.net/dyndns.php erstellt wurde. + * Hier bitte nur ein DOMAIN PRAEFIX (subdomain) eintragen (ersetzen), das unter https://ipv64.net/dyndns.php erstellt wurde: `-e "DOMAIN_PRAEFIX=ddns"` -⚠️ ***Sollten sie mehrer DOMAINS verwenden bitte nur ein PRAEFIX eintragen (ersetzen)*** ⚠️ +⚠️ ***Solltest Du mehrere DOMAINS verwenden, dann bitte nur ein PRAEFIX eintragen (ersetzen)*** ⚠️ -***Bei mehrern Domains würde es so ausehen, dass immer der selbe PRAEFIX werwendet wird.*** +***Bei mehreren Domains wird immer derselbe PRAEFIX verwendet.*** -***z.B für die domains würde es so ausehen ddns.deine-domain.ipv64.net und ddns.deine-domain.ipv64.de*** +***Beispiel: ddns.deine-domain.ipv64.net und ddns.deine-domain.ipv64.de***   @@ -76,7 +76,7 @@ docker run -d \ -e "DOMAIN_IPV64=deine-domain.ipv64.net,deine-domain.ipv64.de" \ -e "DOMAIN_PRAEFIX_YES=yes" \ - "⚠️ Hier bitte nur ein DOMAIN PRAEFIX eintragen (ersetzen) ⚠️" + "⚠️ Hier bitte nur ein DOMAIN PRAEFIX (subdomain) eintragen (ersetzen) ⚠️" -e "DOMAIN_PRAEFIX=ddns" \ ``` @@ -91,19 +91,19 @@ services: restart: always environment: - "TZ=Europe/Berlin" - # Standard Abfrage Alle 15 Minuten nach der aktuellen ip + # Standard Abfrage alle 15 Minuten nach der aktuellen ip - "CRON_TIME=*/15 * * * *" - # Standard Abfrage Alle 30 Minuten für die Domain Adresse + # Standard Abfrage alle 30 Minuten für die Domain Adresse - "CRON_TIME_DIG=*/30 * * * *" - # Hier bitte deine DOMAIN eintragen (ersetzen) die unter https://ipv64.net/dyndns.php erstellt wurde Z.B "deine-domain.ipv64.net" + # Hier bitte deine DOMAIN eintragen (ersetzen), die unter https://ipv64.net/dyndns.php erstellt wurde, z.B "deine-domain.ipv64.net" - "DOMAIN_IPV64=deine-domain.ipv64.net" - # Wenn sie mehrer DOMAINS eintragen wollen bitte mit Komma trennen + # Wenn Du mehrere DOMAINS eintragen willst, bitte mit Komma trennen: # "DOMAIN_IPV64=deine-domain.ipv64.net,deine-domain.ipv64.de" - # Damit wird der Domain PRAEFIX aktiv genutzt + # Damit wird das Domain PRAEFIX aktiv genutzt # - "DOMAIN_PRAEFIX_YES=yes" - # ⚠️ Hier bitte nur ein DOMAIN PRAEFIX eintragen (ersetzen) der unter https://ipv64.net/dyndns.php erstellt wurde ⚠️ + # ⚠️ Hier bitte nur ein DOMAIN PRAEFIX (subdomain) eintragen (ersetzen), das unter https://ipv64.net/dyndns.php erstellt wurde. Gilt auch bei mehreren Domains ⚠️ # - "DOMAIN_PRAEFIX=ddns" - # Hier bitte dein DOMAIN KEY bzw. DynDNS Updatehash eintragen (ersetzen). Zu finden ist dieser unter https://ipv64.net/dyndns.php z.B "1234567890abcdefghijklmn" + # Hier bitte dein DOMAIN KEY bzw. DynDNS Updatehash eintragen (ersetzen). Zu finden ist dieser unter https://ipv64.net/dyndns.php z.B "1234567890abcdefghijklmn" - "DOMAIN_KEY=1234567890abcdefghijklmn" ``` @@ -116,23 +116,23 @@ services: | Name (Beschreibung) #Optional | Wert | Standard | | ----------------------------- | ------- | --------------------- | -| Speicherort logs und Script | volume | ddns-ipv64_data:/data | +| Speicherort logs und script | volume | ddns-ipv64_data:/data | | | | /dein Pfad:/data |   ## Env Parameter -| Name (Beschreibung) | Wert | Standard | Beispiel | -| ---------------------------------------------------------------------------------------------- | ------------------ | ------------------ | -------------------------------------------- | -| Zeitzone | TZ | Europe/Berlin | Europe/Berlin | -| Zeitliche Abfrage für die aktuelle IP | CRON_TIME | */15 * * * * | */15 * * * * | -| Zeitliche Abfrage auf die Domain (dig DOMAIN_IPV64 A) | CRON_TIME_DIG | */30 * * * * | */30 * * * * | -| DOMAIN KEY: DEIN DOMAIN KEY bzw. DynDNS Updatehash zu fiden unter https://ipv64.net/dyndns.php | DOMAIN_KEY | ------------------ | 1234567890abcdefghijklmn | -| DEINE DOMAIN: z.b. deine-domain.ipv64.net zu fiden unter https://ipv64.net/dyndns.php | DOMAIN_IPV64 | ------------------ | deine-domain.ipv64.net | -| DEINE DOMAINS: z.b. deine-domain.ipv64.net,deine-domain.ipv64.de | DOMAIN_IPV64 | ------------------ | deine-domain.ipv64.net,deine-domain.ipv64.de | -| DOMAIN PRAEFIX YES: Damit wird der Domain PRAEFIX aktiv genutzt | DOMAIN_PRAEFIX_YES | no | yes | -| DEIN DOMAIN PRAEFIX: ⚠️ Nur ein Praefix verwenden ⚠️ z.b. ddns | DOMAIN_PRAEFIX | ------------------ | ddns | +| Name (Beschreibung) | Wert | Standard | Beispiel | +| ----------------------------------------------------------------------------------------------- | ------------------ | ------------------ | -------------------------------------------- | +| Zeitzone | TZ | Europe/Berlin | Europe/Berlin | +| Zeitliche Abfrage für die aktuelle IP | CRON_TIME | */15 * * * * | */15 * * * * | +| Zeitliche Abfrage auf die Domain (dig DOMAIN_IPV64 A) | CRON_TIME_DIG | */30 * * * * | */30 * * * * | +| DOMAIN KEY: DEIN DOMAIN KEY bzw. DynDNS Updatehash zu finden unter https://ipv64.net/dyndns.php | DOMAIN_KEY | ------------------ | 1234567890abcdefghijklmn | +| DEINE DOMAIN: z.b. deine-domain.ipv64.net zu finden unter https://ipv64.net/dyndns.php | DOMAIN_IPV64 | ------------------ | deine-domain.ipv64.net | +| DEINE DOMAINS: z.b. deine-domain.ipv64.net, deine-domain.ipv64.de | DOMAIN_IPV64 | ------------------ | deine-domain.ipv64.net,deine-domain.ipv64.de | +| DOMAIN PRAEFIX YES: Damit wird das Domain PRAEFIX aktiv genutzt | DOMAIN_PRAEFIX_YES | no | yes | +| DEIN DOMAIN PRAEFIX (subdomain) : ⚠️ Nur ein Praefix verwenden ⚠️ z.b. ddns | DOMAIN_PRAEFIX | ------------------ | ddns | * * * @@ -142,4 +142,3 @@ services: ## DEMO - From 0ce80be3dc1f28259f95323f9564c737b862cc24 Mon Sep 17 00:00:00 2001 From: alcapone1933 Date: Tue, 29 Nov 2022 16:54:10 +0100 Subject: [PATCH 2/2] v0.0.8 --- .drone.yml | 4 +-- Dockerfile | 8 ++--- README.md | 16 +++++++-- data/ddns-update-dkey-praefix.sh | 59 +++++++++++++++++++++++++++++++ data/ddns-update-dkey.sh | 60 ++++++++++++++++++++++++++++++++ data/ddns-update-praefix.sh | 8 ++--- data/ddns-update.sh | 8 ++--- data/entrypoint.sh | 43 ++++++++++++++++++++--- docker-compose.yml | 3 +- 9 files changed, 187 insertions(+), 22 deletions(-) create mode 100644 data/ddns-update-dkey-praefix.sh create mode 100644 data/ddns-update-dkey.sh diff --git a/.drone.yml b/.drone.yml index eae244b..d809971 100644 --- a/.drone.yml +++ b/.drone.yml @@ -37,7 +37,7 @@ steps: repo: alcapone1933/ddns-ipv64 # tags: latest auto_tag: true - auto_tag_suffix: v0.0.7 + auto_tag_suffix: v0.0.8 trigger: branch: @@ -68,7 +68,7 @@ steps: repo: ghcr.io/alcapone1933/ddns-ipv64 # tags: latest auto_tag: true - auto_tag_suffix: v0.0.7 + auto_tag_suffix: v0.0.8 trigger: branch: diff --git a/Dockerfile b/Dockerfile index e0b3917..e54ba3f 100644 --- a/Dockerfile +++ b/Dockerfile @@ -4,7 +4,7 @@ LABEL maintainer="alcapone1933 " \ org.opencontainers.image.created="$(date +%Y-%m-%d\ %H:%M)" \ org.opencontainers.image.authors="alcapone1933 " \ org.opencontainers.image.url="https://hub.docker.com/r/alcapone1933/ddns-ipv64" \ - org.opencontainers.image.version="v0.0.7" \ + org.opencontainers.image.version="v0.0.8" \ org.opencontainers.image.ref.name="alcapone1933/ddns-ipv64" \ org.opencontainers.image.title="DDNS Updater ipv64.net" \ org.opencontainers.image.description="Community DDNS Updater fuer ipv64.net" @@ -12,7 +12,7 @@ LABEL maintainer="alcapone1933 " \ ENV TZ=Europe/Berlin ENV CRON_TIME="*/15 * * * *" ENV CRON_TIME_DIG="*/30 * * * *" -ENV VERSION="v0.0.7" +ENV VERSION="v0.0.8" ENV CURL_USER_AGENT="docker-ddns-ipv64/version=$VERSION github.com/alcapone1933/docker-ddns-ipv64" RUN apk add --update --no-cache tzdata curl bash tini bind-tools jq && \ rm -rf /var/cache/apk/* @@ -21,8 +21,8 @@ RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone RUN mkdir -p /data /usr/local/bin/ /etc/cron.d/ COPY data /data RUN mv /data/entrypoint.sh /usr/local/bin/entrypoint.sh && mv /data/cronjob /etc/cron.d/container_cronjob && mv /data/healthcheck.sh /usr/local/bin/healthcheck.sh && \ - chmod 755 /data/ddns-update.sh && chmod 755 /data/ddns-update-praefix.sh && chmod 755 /usr/local/bin/entrypoint.sh && chmod 755 /usr/local/bin/healthcheck.sh && \ - chmod 755 /etc/cron.d/container_cronjob && touch /var/log/cron.log + chmod 755 /data/ddns-update.sh && chmod 755 /data/ddns-update-praefix.sh && chmod 755 /data/ddns-update-dkey.sh && chmod 755 /data/ddns-update-dkey-praefix.sh && \ + chmod 755 /usr/local/bin/entrypoint.sh && chmod 755 /usr/local/bin/healthcheck.sh && chmod 755 /etc/cron.d/container_cronjob && touch /var/log/cron.log # VOLUME [ "/data" ] ENTRYPOINT ["/sbin/tini", "--", "/usr/local/bin/entrypoint.sh"] diff --git a/README.md b/README.md index 77183e6..cc440f0 100644 --- a/README.md +++ b/README.md @@ -53,10 +53,17 @@ Wenn Du dieses Docker Projekt nutzen möchtest, ändere bitte die Environments v ### Domain Key - * Hier bitte dein DOMAIN KEY bzw. DynDNS Updatehash eintragen (ersetzen). Zu finden ist dieser unter https://ipv64.net/dyndns.php z.B "1234567890abcdefghijklmn" + * Hier bitte dein DOMAIN KEY bzw. DynDNS Updatehash eintragen (ersetzen) oder den dkey.\ + Zu finden ist dieser unter https://ipv64.net/dyndns.php z.B "1234567890abcdefghijklmn" `-e "DOMAIN_KEY=1234567890abcdefghijklmn"` + * Es gibt auch die Möglichkeit den DNS-Update Befehl für eine bestimmte Domain durchzuführen. \ + Dann benutze die Variable ***DOMAIN_KEY_TYPE=dkey*** einfach anstatt Standard key. \ + Der dkey ist zu fiden im unter https://ipv64.net/dyndns.php wenn man auf eine Domain klickt. + + `-e "DOMAIN_KEY_TYPE=dkey"` +   *** @@ -78,6 +85,7 @@ docker run -d \ -e "DOMAIN_PRAEFIX_YES=yes" \ "⚠️ Hier bitte nur ein DOMAIN PRAEFIX (subdomain) eintragen (ersetzen) ⚠️" -e "DOMAIN_PRAEFIX=ddns" \ + -e "DOMAIN_KEY_TYPE=dkey" \ ``` ## Docker Compose @@ -98,13 +106,15 @@ services: # Hier bitte deine DOMAIN eintragen (ersetzen), die unter https://ipv64.net/dyndns.php erstellt wurde, z.B "deine-domain.ipv64.net" - "DOMAIN_IPV64=deine-domain.ipv64.net" # Wenn Du mehrere DOMAINS eintragen willst, bitte mit Komma trennen: - # "DOMAIN_IPV64=deine-domain.ipv64.net,deine-domain.ipv64.de" + # - "DOMAIN_IPV64=deine-domain.ipv64.net,deine-domain.ipv64.de" # Damit wird das Domain PRAEFIX aktiv genutzt # - "DOMAIN_PRAEFIX_YES=yes" # ⚠️ Hier bitte nur ein DOMAIN PRAEFIX (subdomain) eintragen (ersetzen), das unter https://ipv64.net/dyndns.php erstellt wurde. Gilt auch bei mehreren Domains ⚠️ # - "DOMAIN_PRAEFIX=ddns" # Hier bitte dein DOMAIN KEY bzw. DynDNS Updatehash eintragen (ersetzen). Zu finden ist dieser unter https://ipv64.net/dyndns.php z.B "1234567890abcdefghijklmn" - "DOMAIN_KEY=1234567890abcdefghijklmn" + # Der KEY TYPE ist für eine Domain oder mehrere Domains zuständig und gültig + # - "DOMAIN_KEY_TYPE=dkey" ``` @@ -129,12 +139,12 @@ services: | Zeitliche Abfrage für die aktuelle IP | CRON_TIME | */15 * * * * | */15 * * * * | | Zeitliche Abfrage auf die Domain (dig DOMAIN_IPV64 A) | CRON_TIME_DIG | */30 * * * * | */30 * * * * | | DOMAIN KEY: DEIN DOMAIN KEY bzw. DynDNS Updatehash zu finden unter https://ipv64.net/dyndns.php | DOMAIN_KEY | ------------------ | 1234567890abcdefghijklmn | +| DOMAIN KEY TYPE: Der KEY TYPE ist für eine Domain oder mehrere Domains zuständig und gültig | DOMAIN_KEY_TYPE | key | dkey | | DEINE DOMAIN: z.b. deine-domain.ipv64.net zu finden unter https://ipv64.net/dyndns.php | DOMAIN_IPV64 | ------------------ | deine-domain.ipv64.net | | DEINE DOMAINS: z.b. deine-domain.ipv64.net, deine-domain.ipv64.de | DOMAIN_IPV64 | ------------------ | deine-domain.ipv64.net,deine-domain.ipv64.de | | DOMAIN PRAEFIX YES: Damit wird das Domain PRAEFIX aktiv genutzt | DOMAIN_PRAEFIX_YES | no | yes | | DEIN DOMAIN PRAEFIX (subdomain) : ⚠️ Nur ein Praefix verwenden ⚠️ z.b. ddns | DOMAIN_PRAEFIX | ------------------ | ddns | - * * *   diff --git a/data/ddns-update-dkey-praefix.sh b/data/ddns-update-dkey-praefix.sh new file mode 100644 index 0000000..1e7dcff --- /dev/null +++ b/data/ddns-update-dkey-praefix.sh @@ -0,0 +1,59 @@ +#!/usr/bin/env bash +DATUM=$(date +%Y-%m-%d\ %H:%M:%S) +if ! curl -sSL --user-agent "${CURL_USER_AGENT}" --fail "https://ipv64.net" > /dev/null; then + echo "$DATUM FEHLER !!! - 404 Sie haben kein Netzwerk oder Internetzugang oder die Webseite ipv64.net ist nicht erreichbar" + exit 0 +fi +PFAD="/data" +IP=$(curl -4ssL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php?howismyip" | jq -r 'to_entries[] | "\(.value)"') +UPDIP=$(cat $PFAD/updip.txt) + +sleep 1 + +if [ "$IP" == "$UPDIP" ]; then + echo "$DATUM KEIN UPDATE - Aktuelle IP=$UPDIP" +else + echo "$DATUM UPDATE !!! ..." + echo "$DATUM UPDATE !!! - Update IP=$IP - Alte-IP=$UPDIP" + sleep 1 + echo "$IP" > $PFAD/updip.txt + # curl -4sSL "https://ipv64.net/update.php?dkey=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&ip=${IP}&output=min" + UPDATE_IP=$(curl -4sSL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php?dkey=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&ip=${IP}&output=min") + # if [ "$UPDATE_IP" = "ok" ] ; then + if [[ "$UPDATE_IP" =~ (nochg|good|ok) ]] ; then + echo "$DATUM UPDATE !!! - UPDATE IP=$IP AN IPV64.NET GESENDET" + else + echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET" + fi + # curl -4sSL https://ipv64.net/update.php?dkey=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&ip=&ip6=&output=min +fi +sleep 5 +# Nachpruefung ob der DOMAIN Eintrag richtig gesetzt ist +function CHECK_A_DOMAIN() { +DATUM=$(date +%Y-%m-%d\ %H:%M:%S) +UPDIP=$(cat $PFAD/updip.txt) +# IP=$(curl -4s https://ipv64.net/wieistmeineip.php | grep -o '[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}' | tail -n 1) +IP=$(curl -4ssL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php?howismyip" | jq -r 'to_entries[] | "\(.value)"') +DOMAIN_CHECK=$(dig +short ${DOMAIN_PRAEFIX}.${DOMAIN_IPV64} A @ns1.ipv64.net) +sleep 1 +if [ "$IP" == "$DOMAIN_CHECK" ]; then + echo "$DATUM CHECK - DOMAIN mit PRAEFIX HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN_PRAEFIX}.${DOMAIN_IPV64} A @ns1.ipv64.net`" +else + echo "$DATUM UPDATE !!! ..." + echo "$DATUM UPDATE !!! - NACHEINTRAG DIE IP WIRD NOCH EINMAL GESETZT" + echo "$DATUM UPDATE !!! - Update IP=$IP - Alte-IP=$UPDIP" + sleep 5 + # curl -4sSL "https://ipv64.net/update.php?dkey=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&ip=${IP}&output=min" + UPDATE_IP=$(curl -4sSL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php?dkey=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&ip=${IP}&output=min") + # if [ "$UPDATE_IP" = "ok" ] ; then + if [[ "$UPDATE_IP" =~ (nochg|good|ok) ]] ; then + echo "$DATUM UPDATE !!! - UPDATE IP=$IP AN IPV64.NET GESENDET" + else + echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET" + fi + # curl -4sSL https://ipv64.net/update.php?dkey=${DOMAIN_KEY}=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&ip=&ip6=&output=min + sleep 15 + echo "$DATUM NACHEINTRAG - DOMAIN mit PRAEFIX HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN_PRAEFIX}.${DOMAIN_IPV64} A @ns1.ipv64.net`" +fi +} +CHECK_A_DOMAIN diff --git a/data/ddns-update-dkey.sh b/data/ddns-update-dkey.sh new file mode 100644 index 0000000..72c1254 --- /dev/null +++ b/data/ddns-update-dkey.sh @@ -0,0 +1,60 @@ +#!/usr/bin/env bash +DATUM=$(date +%Y-%m-%d\ %H:%M:%S) +if ! curl -sSL --user-agent "${CURL_USER_AGENT}" --fail "https://ipv64.net" > /dev/null; then + echo "$DATUM FEHLER !!! - 404 Sie haben kein Netzwerk oder Internetzugang oder die Webseite ipv64.net ist nicht erreichbar" + exit 0 +fi +PFAD="/data" +# IP=$(curl -4s https://ipv64.net/wieistmeineip.php | grep -o '[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}' | tail -n 1) +IP=$(curl -4ssL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php?howismyip" | jq -r 'to_entries[] | "\(.value)"') +UPDIP=$(cat $PFAD/updip.txt) + +sleep 1 + +if [ "$IP" == "$UPDIP" ]; then + echo "$DATUM KEIN UPDATE - Aktuelle IP=$UPDIP" +else + echo "$DATUM UPDATE !!! ..." + echo "$DATUM UPDATE !!! - Update IP=$IP - Alte-IP=$UPDIP" + sleep 1 + echo "$IP" > $PFAD/updip.txt + # curl -4sSL "https://ipv64.net/update.php?dkey=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&ip=${IP}&output=min" + UPDATE_IP=$(curl -4sSL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php?dkey=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&ip=${IP}&output=min") + # if [ "$UPDATE_IP" = "ok" ] ; then + if [[ "$UPDATE_IP" =~ (nochg|good|ok) ]] ; then + echo "$DATUM UPDATE !!! - UPDATE IP=$IP AN IPV64.NET GESENDET" + else + echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET" + fi + # curl -4sSL https://ipv64.net/update.php?dkey=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&ip=&ip6=&output=min +fi +sleep 5 +# Nachpruefung ob der DOMAIN Eintrag richtig gesetzt ist +function CHECK_A_DOMAIN() { +DATUM=$(date +%Y-%m-%d\ %H:%M:%S) +UPDIP=$(cat $PFAD/updip.txt) +# IP=$(curl -4s https://ipv64.net/wieistmeineip.php | grep -o '[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}' | tail -n 1) +IP=$(curl -4ssL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php?howismyip" | jq -r 'to_entries[] | "\(.value)"') +DOMAIN_CHECK=$(dig +short ${DOMAIN_IPV64} A @ns1.ipv64.net) +sleep 1 +if [ "$IP" == "$DOMAIN_CHECK" ]; then + echo "$DATUM CHECK - DOMAIN HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN_IPV64} A @ns1.ipv64.net`" +else + echo "$DATUM UPDATE !!! ..." + echo "$DATUM UPDATE !!! - NACHEINTRAG DIE IP WIRD NOCH EINMAL GESETZT" + echo "$DATUM UPDATE !!! - Update IP=$IP - Alte-IP=$UPDIP" + sleep 5 + # curl -4sSL "https://ipv64.net/update.php?dkey=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&ip=${IP}&output=min" + UPDATE_IP=$(curl -4sSL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php?dkey=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&ip=${IP}&output=min") + # if [ "$UPDATE_IP" = "ok" ] ; then + if [[ "$UPDATE_IP" =~ (nochg|good|ok) ]] ; then + echo "$DATUM UPDATE !!! - UPDATE IP=$IP AN IPV64.NET GESENDET" + else + echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET" + fi + # curl -4sSL https://ipv64.net/update.php?dkey=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&ip=&ip6=&output=min + sleep 15 + echo "$DATUM NACHEINTRAG - DOMAIN HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN_IPV64} A @ns1.ipv64.net`" +fi +} +CHECK_A_DOMAIN diff --git a/data/ddns-update-praefix.sh b/data/ddns-update-praefix.sh index f3b9c8a..e9b49fd 100644 --- a/data/ddns-update-praefix.sh +++ b/data/ddns-update-praefix.sh @@ -25,7 +25,7 @@ else else echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET" fi - # curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&praefix=${DOMAIN_PRAEFIX}&ip=&ip6=&output=min + # curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}praefix=${DOMAIN_PRAEFIX}&ip=&ip6=&output=min fi sleep 5 # Nachpruefung ob der DOMAIN Eintrag richtig gesetzt ist @@ -38,7 +38,7 @@ IP=$(curl -4ssL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php? DOMAIN_CHECK=$(for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do dig +short ${DOMAIN_PRAEFIX}.${DOMAIN} A @ns1.ipv64.net; done | tail -n 1) sleep 1 if [ "$IP" == "$DOMAIN_CHECK" ]; then - # echo "$DATUM CHECK - DOMAIN mit PRAEFIX HAT DEN A-RECORD= `dig +noall +answer ${DOMAIN_PRAEFIX}.${DOMAIN_IPV64} A @ns1.ipv64.net`" + # echo "$DATUM CHECK - DOMAIN mit PRAEFIX HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN_PRAEFIX}.${DOMAIN_IPV64} A @ns1.ipv64.net`" for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do echo "$DATUM CHECK - DOMAIN mit PRAEFIX HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN_PRAEFIX}.${DOMAIN} A @ns1.ipv64.net`"; done else echo "$DATUM UPDATE !!! ..." @@ -53,9 +53,9 @@ else else echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET" fi - # curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&ip=&ip6=&output=min + # curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&ip=&ip6=&output=min sleep 15 - # echo "$DATUM NACHEINTRAG - DOMAIN mit PRAEFIX HAT DEN A-RECORD= `dig +noall +answer ${DOMAIN_PRAEFIX}.${DOMAIN_IPV64} A @ns1.ipv64.net`" + # echo "$DATUM NACHEINTRAG - DOMAIN mit PRAEFIX HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN_PRAEFIX}.${DOMAIN_IPV64} A @ns1.ipv64.net`" for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do echo "$DATUM NACHEINTRAG - DOMAIN mit PRAEFIX HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN_PRAEFIX}.${DOMAIN} A @ns1.ipv64.net`"; done fi } diff --git a/data/ddns-update.sh b/data/ddns-update.sh index da28af3..4045a79 100644 --- a/data/ddns-update.sh +++ b/data/ddns-update.sh @@ -26,7 +26,7 @@ else else echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET" fi - # curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}=${DOMAIN_IPV64}&ip=&ip6=&output=min + # curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&ip=&ip6=&output=min fi sleep 5 # Nachpruefung ob der DOMAIN Eintrag richtig gesetzt ist @@ -39,7 +39,7 @@ IP=$(curl -4ssL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php? DOMAIN_CHECK=$(for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do dig +short ${DOMAIN} A @ns1.ipv64.net; done | tail -n 1) sleep 1 if [ "$IP" == "$DOMAIN_CHECK" ]; then - # echo "$DATUM CHECK - DOMAIN HAT DEN A-RECORD= `dig +noall +answer ${DOMAIN_IPV64} A @ns1.ipv64.net`" + # echo "$DATUM CHECK - DOMAIN HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN_IPV64} A @ns1.ipv64.net`" for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do echo "$DATUM CHECK - DOMAIN HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN} A @ns1.ipv64.net`"; done else echo "$DATUM UPDATE !!! ..." @@ -54,9 +54,9 @@ else else echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET" fi - # curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}=${DOMAIN_IPV64}&ip=&ip6=&output=min + # curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&ip=&ip6=&output=min sleep 15 - # echo "$DATUM NACHEINTRAG - DOMAIN HAT DEN A-RECORD= `dig +noall +answer ${DOMAIN_IPV64} A @ns1.ipv64.net`" + # echo "$DATUM NACHEINTRAG - DOMAIN HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN_IPV64} A @ns1.ipv64.net`" for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do echo "$DATUM NACHEINTRAG - DOMAIN HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN} A @ns1.ipv64.net`"; done fi } diff --git a/data/entrypoint.sh b/data/entrypoint.sh index 6d3dadc..e935803 100644 --- a/data/entrypoint.sh +++ b/data/entrypoint.sh @@ -73,7 +73,6 @@ echo "$CRON_TIME_DIG" 'sleep 20 && for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed function Domain_mit_praefix() { CHECK=$(curl -4sSL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php?key=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&ip=${IP}&output=min") -# if [ "$CHECK" = "ok" ] ; then if [[ "$CHECK" =~ (nochg|good|ok) ]] ; then echo "$DATUM CHECK - Die Angaben sind richtig gesetzt: DOMAIN mit PRAEFIX und DOMAIN KEY" sleep 5 @@ -86,10 +85,46 @@ echo "${CRON_TIME} /bin/bash /data/ddns-update-praefix.sh >> /var/log/cron.log 2 echo "$CRON_TIME_DIG" 'sleep 20 && for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do echo "`date +%Y-%m-%d\ %H:%M:%S` IP CHECK - Deine DOMAIN mit PRAEFIX ${DOMAIN_PRAEFIX}.${DOMAIN} HAT DIE IP=`dig +short ${DOMAIN_PRAEFIX}.${DOMAIN} A @ns1.ipv64.net`" >> /var/log/cron.log 2>&1; done' >> /etc/cron.d/container_cronjob } -if [[ "$DOMAIN_PRAEFIX_YES" =~ (YES|yes|Yes) ]] ; then - Domain_mit_praefix +function Domain_dkey() { +CHECK=$(curl -4sSL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php?dkey=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&ip=${IP}&output=min") +if [[ "$CHECK" =~ (nochg|good|ok) ]] ; then + echo "$DATUM CHECK - Die Angaben sind richtig gesetzt: DOMAIN und DOMAIN KEY" + sleep 5 + echo "$DATUM IP CHECK - Deine DOMAIN ${DOMAIN_IPV64} HAT DIE IP=`dig +short ${DOMAIN_IPV64} A @ns1.ipv64.net`" else - Domain_default + echo "$DATUM FEHLER !!! - Die Angaben sind falsch gesetzt: DOMAIN oder DOMAIN KEY" + exit 1 +fi +echo "${CRON_TIME} /bin/bash /data/ddns-update-dkey.sh >> /var/log/cron.log 2>&1" > /etc/cron.d/container_cronjob +echo "$CRON_TIME_DIG" 'sleep 20 && echo "`date +%Y-%m-%d\ %H:%M:%S` IP CHECK - Deine DOMAIN ${DOMAIN_IPV64} HAT DIE IP=`dig +short ${DOMAIN_IPV64} A @ns1.ipv64.net`" >> /var/log/cron.log 2>&1' >> /etc/cron.d/container_cronjob +} + +function Domain_dkey_mit_praefix() { +CHECK=$(curl -4sSL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php?dkey=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&ip=${IP}&output=min") +if [[ "$CHECK" =~ (nochg|good|ok) ]] ; then + echo "$DATUM CHECK - Die Angaben sind richtig gesetzt: DOMAIN mit PRAEFIX und DOMAIN KEY" + sleep 5 + echo "$DATUM IP CHECK - Deine DOMAIN mit PRAEFIX ${DOMAIN_PRAEFIX}.${DOMAIN_IPV64} HAT DIE IP=`dig +short ${DOMAIN_PRAEFIX}.${DOMAIN_IPV64} A @ns1.ipv64.net`" +else + echo "$DATUM FEHLER !!! - Die Angaben sind falsch gesetzt: DOMAIN mit PRAEFIX oder DOMAIN KEY" + exit 1 +fi +echo "${CRON_TIME} /bin/bash /data/ddns-update-dkey-praefix.sh >> /var/log/cron.log 2>&1" > /etc/cron.d/container_cronjob +echo "$CRON_TIME_DIG" 'sleep 20 && echo "`date +%Y-%m-%d\ %H:%M:%S` IP CHECK - Deine DOMAIN mit PRAEFIX ${DOMAIN_PRAEFIX}.${DOMAIN} HAT DIE IP=`dig +short ${DOMAIN_PRAEFIX}.${DOMAIN_IPV64} A @ns1.ipv64.net`" >> /var/log/cron.log 2>&1' >> /etc/cron.d/container_cronjob +} + +if [[ "$DOMAIN_KEY_TYPE" =~ (dkey|DKEY|Dkey) ]] ; then + if [[ "$DOMAIN_PRAEFIX_YES" =~ (YES|yes|Yes) ]] ; then + Domain_dkey_mit_praefix + else + Domain_dkey + fi +else + if [[ "$DOMAIN_PRAEFIX_YES" =~ (YES|yes|Yes) ]] ; then + Domain_mit_praefix + else + Domain_default + fi fi echo "${IP}" > /data/updip.txt diff --git a/docker-compose.yml b/docker-compose.yml index ead83f8..48444c0 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -4,7 +4,7 @@ services: # build: # dockerfile: ./Dockerfile image: alcapone1933/ddns-ipv64:latest - # image: alcapone1933/ddns-ipv64:v0.0.7 + # image: alcapone1933/ddns-ipv64:v0.0.8 container_name: ddns-ipv64 restart: always # volumes: @@ -21,6 +21,7 @@ services: # ⚠️ Nur ein Praefix verwenden ⚠️ # - "DOMAIN_PRAEFIX=ddns" - "DOMAIN_KEY=1234567890abcdefghijklmn" + # - "DOMAIN_KEY_TYPE=dkey" # volumes: # data: # name: ddns-ipv64_data