mirror of
https://github.com/mykitserver/docker-ddns-ipv64.git
synced 2025-12-06 16:39:06 +01:00
v0.0.8
This commit is contained in:
@@ -37,7 +37,7 @@ steps:
|
|||||||
repo: alcapone1933/ddns-ipv64
|
repo: alcapone1933/ddns-ipv64
|
||||||
# tags: latest
|
# tags: latest
|
||||||
auto_tag: true
|
auto_tag: true
|
||||||
auto_tag_suffix: v0.0.7
|
auto_tag_suffix: v0.0.8
|
||||||
|
|
||||||
trigger:
|
trigger:
|
||||||
branch:
|
branch:
|
||||||
@@ -68,7 +68,7 @@ steps:
|
|||||||
repo: ghcr.io/alcapone1933/ddns-ipv64
|
repo: ghcr.io/alcapone1933/ddns-ipv64
|
||||||
# tags: latest
|
# tags: latest
|
||||||
auto_tag: true
|
auto_tag: true
|
||||||
auto_tag_suffix: v0.0.7
|
auto_tag_suffix: v0.0.8
|
||||||
|
|
||||||
trigger:
|
trigger:
|
||||||
branch:
|
branch:
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ LABEL maintainer="alcapone1933 <alcapone1933@cosanostra-cloud.de>" \
|
|||||||
org.opencontainers.image.created="$(date +%Y-%m-%d\ %H:%M)" \
|
org.opencontainers.image.created="$(date +%Y-%m-%d\ %H:%M)" \
|
||||||
org.opencontainers.image.authors="alcapone1933 <alcapone1933@cosanostra-cloud.de>" \
|
org.opencontainers.image.authors="alcapone1933 <alcapone1933@cosanostra-cloud.de>" \
|
||||||
org.opencontainers.image.url="https://hub.docker.com/r/alcapone1933/ddns-ipv64" \
|
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.ref.name="alcapone1933/ddns-ipv64" \
|
||||||
org.opencontainers.image.title="DDNS Updater ipv64.net" \
|
org.opencontainers.image.title="DDNS Updater ipv64.net" \
|
||||||
org.opencontainers.image.description="Community DDNS Updater fuer ipv64.net"
|
org.opencontainers.image.description="Community DDNS Updater fuer ipv64.net"
|
||||||
@@ -12,7 +12,7 @@ LABEL maintainer="alcapone1933 <alcapone1933@cosanostra-cloud.de>" \
|
|||||||
ENV TZ=Europe/Berlin
|
ENV TZ=Europe/Berlin
|
||||||
ENV CRON_TIME="*/15 * * * *"
|
ENV CRON_TIME="*/15 * * * *"
|
||||||
ENV CRON_TIME_DIG="*/30 * * * *"
|
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"
|
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 && \
|
RUN apk add --update --no-cache tzdata curl bash tini bind-tools jq && \
|
||||||
rm -rf /var/cache/apk/*
|
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/
|
RUN mkdir -p /data /usr/local/bin/ /etc/cron.d/
|
||||||
COPY data /data
|
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 && \
|
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 /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 /etc/cron.d/container_cronjob && touch /var/log/cron.log
|
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" ]
|
# VOLUME [ "/data" ]
|
||||||
|
|
||||||
ENTRYPOINT ["/sbin/tini", "--", "/usr/local/bin/entrypoint.sh"]
|
ENTRYPOINT ["/sbin/tini", "--", "/usr/local/bin/entrypoint.sh"]
|
||||||
|
|||||||
16
README.md
16
README.md
@@ -53,10 +53,17 @@ Wenn Du dieses Docker Projekt nutzen möchtest, ändere bitte die Environments v
|
|||||||
|
|
||||||
### Domain Key
|
### 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"`
|
`-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" \
|
-e "DOMAIN_PRAEFIX_YES=yes" \
|
||||||
"⚠️ Hier bitte nur ein DOMAIN PRAEFIX (subdomain) eintragen (ersetzen) ⚠️"
|
"⚠️ Hier bitte nur ein DOMAIN PRAEFIX (subdomain) eintragen (ersetzen) ⚠️"
|
||||||
-e "DOMAIN_PRAEFIX=ddns" \
|
-e "DOMAIN_PRAEFIX=ddns" \
|
||||||
|
-e "DOMAIN_KEY_TYPE=dkey" \
|
||||||
```
|
```
|
||||||
|
|
||||||
## Docker Compose
|
## 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"
|
# 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"
|
- "DOMAIN_IPV64=deine-domain.ipv64.net"
|
||||||
# Wenn Du mehrere DOMAINS eintragen willst, bitte mit Komma trennen:
|
# 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
|
# Damit wird das Domain PRAEFIX aktiv genutzt
|
||||||
# - "DOMAIN_PRAEFIX_YES=yes"
|
# - "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 ⚠️
|
# ⚠️ 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"
|
# - "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"
|
- "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 für die aktuelle IP | CRON_TIME | */15 * * * * | */15 * * * * |
|
||||||
| Zeitliche Abfrage auf die Domain (dig DOMAIN_IPV64 A) | CRON_TIME_DIG | */30 * * * * | */30 * * * * |
|
| 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: 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 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 |
|
| 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 |
|
| 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 |
|
| DEIN DOMAIN PRAEFIX (subdomain) : ⚠️ Nur ein Praefix verwenden ⚠️ z.b. ddns | DOMAIN_PRAEFIX | ------------------ | ddns |
|
||||||
|
|
||||||
|
|
||||||
* * *
|
* * *
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
59
data/ddns-update-dkey-praefix.sh
Normal file
59
data/ddns-update-dkey-praefix.sh
Normal file
@@ -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=<ipaddr>&ip6=<ip6addr>&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=<ipaddr>&ip6=<ip6addr>&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
|
||||||
60
data/ddns-update-dkey.sh
Normal file
60
data/ddns-update-dkey.sh
Normal file
@@ -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=<ipaddr>&ip6=<ip6addr>&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=<ipaddr>&ip6=<ip6addr>&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
|
||||||
@@ -25,7 +25,7 @@ else
|
|||||||
else
|
else
|
||||||
echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET"
|
echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET"
|
||||||
fi
|
fi
|
||||||
# curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&praefix=${DOMAIN_PRAEFIX}&ip=<ipaddr>&ip6=<ip6addr>&output=min
|
# curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}praefix=${DOMAIN_PRAEFIX}&ip=<ipaddr>&ip6=<ip6addr>&output=min
|
||||||
fi
|
fi
|
||||||
sleep 5
|
sleep 5
|
||||||
# Nachpruefung ob der DOMAIN Eintrag richtig gesetzt ist
|
# Nachpruefung ob der DOMAIN Eintrag richtig gesetzt ist
|
||||||
@@ -53,7 +53,7 @@ else
|
|||||||
else
|
else
|
||||||
echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET"
|
echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET"
|
||||||
fi
|
fi
|
||||||
# curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&ip=<ipaddr>&ip6=<ip6addr>&output=min
|
# curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&praefix=${DOMAIN_PRAEFIX}&ip=<ipaddr>&ip6=<ip6addr>&output=min
|
||||||
sleep 15
|
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
|
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
|
||||||
|
|||||||
@@ -26,7 +26,7 @@ else
|
|||||||
else
|
else
|
||||||
echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET"
|
echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET"
|
||||||
fi
|
fi
|
||||||
# curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}=${DOMAIN_IPV64}&ip=<ipaddr>&ip6=<ip6addr>&output=min
|
# curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&ip=<ipaddr>&ip6=<ip6addr>&output=min
|
||||||
fi
|
fi
|
||||||
sleep 5
|
sleep 5
|
||||||
# Nachpruefung ob der DOMAIN Eintrag richtig gesetzt ist
|
# Nachpruefung ob der DOMAIN Eintrag richtig gesetzt ist
|
||||||
@@ -54,7 +54,7 @@ else
|
|||||||
else
|
else
|
||||||
echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET"
|
echo "$DATUM UPDATE !!! - UPDATE IP=$IP NICHT GESENTET"
|
||||||
fi
|
fi
|
||||||
# curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}=${DOMAIN_IPV64}&ip=<ipaddr>&ip6=<ip6addr>&output=min
|
# curl -4sSL https://ipv64.net/update.php?key=${DOMAIN_KEY}&domain=${DOMAIN_IPV64}&ip=<ipaddr>&ip6=<ip6addr>&output=min
|
||||||
sleep 15
|
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
|
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
|
||||||
|
|||||||
@@ -73,7 +73,6 @@ echo "$CRON_TIME_DIG" 'sleep 20 && for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed
|
|||||||
|
|
||||||
function Domain_mit_praefix() {
|
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")
|
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
|
if [[ "$CHECK" =~ (nochg|good|ok) ]] ; then
|
||||||
echo "$DATUM CHECK - Die Angaben sind richtig gesetzt: DOMAIN mit PRAEFIX und DOMAIN KEY"
|
echo "$DATUM CHECK - Die Angaben sind richtig gesetzt: DOMAIN mit PRAEFIX und DOMAIN KEY"
|
||||||
sleep 5
|
sleep 5
|
||||||
@@ -86,11 +85,47 @@ 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
|
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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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
|
||||||
|
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
|
if [[ "$DOMAIN_PRAEFIX_YES" =~ (YES|yes|Yes) ]] ; then
|
||||||
Domain_mit_praefix
|
Domain_mit_praefix
|
||||||
else
|
else
|
||||||
Domain_default
|
Domain_default
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
echo "${IP}" > /data/updip.txt
|
echo "${IP}" > /data/updip.txt
|
||||||
sleep 2
|
sleep 2
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ services:
|
|||||||
# build:
|
# build:
|
||||||
# dockerfile: ./Dockerfile
|
# dockerfile: ./Dockerfile
|
||||||
image: alcapone1933/ddns-ipv64:latest
|
image: alcapone1933/ddns-ipv64:latest
|
||||||
# image: alcapone1933/ddns-ipv64:v0.0.7
|
# image: alcapone1933/ddns-ipv64:v0.0.8
|
||||||
container_name: ddns-ipv64
|
container_name: ddns-ipv64
|
||||||
restart: always
|
restart: always
|
||||||
# volumes:
|
# volumes:
|
||||||
@@ -21,6 +21,7 @@ services:
|
|||||||
# ⚠️ Nur ein Praefix verwenden ⚠️
|
# ⚠️ Nur ein Praefix verwenden ⚠️
|
||||||
# - "DOMAIN_PRAEFIX=ddns"
|
# - "DOMAIN_PRAEFIX=ddns"
|
||||||
- "DOMAIN_KEY=1234567890abcdefghijklmn"
|
- "DOMAIN_KEY=1234567890abcdefghijklmn"
|
||||||
|
# - "DOMAIN_KEY_TYPE=dkey"
|
||||||
# volumes:
|
# volumes:
|
||||||
# data:
|
# data:
|
||||||
# name: ddns-ipv64_data
|
# name: ddns-ipv64_data
|
||||||
|
|||||||
Reference in New Issue
Block a user