From 97542521898905ec7b6b7875bb7e546799dac817 Mon Sep 17 00:00:00 2001 From: alcapone1933 Date: Thu, 29 Dec 2022 13:12:19 +0100 Subject: [PATCH] v0.1.0 --- .drone-dev.yml | 51 -------------------------------- Dockerfile | 5 ++-- data/cronjob | 5 ++-- data/ddns-update-dkey-praefix.sh | 4 +-- data/ddns-update-dkey.sh | 4 +-- data/ddns-update-praefix.sh | 12 ++++---- data/ddns-update.sh | 12 ++++---- data/domain-ip-scheck.sh | 10 +++++++ data/entrypoint.sh | 29 +++++++++++++----- data/healthcheck.sh | 4 +-- 10 files changed, 54 insertions(+), 82 deletions(-) delete mode 100644 .drone-dev.yml create mode 100644 data/domain-ip-scheck.sh diff --git a/.drone-dev.yml b/.drone-dev.yml deleted file mode 100644 index c2a0350..0000000 --- a/.drone-dev.yml +++ /dev/null @@ -1,51 +0,0 @@ ---- -kind: pipeline -type: docker -name: BUILD-TEST-DEV -steps: - - name: Build Multi-arch - image: alcapone1933/drone:docker-buildx - privileged: true - settings: - platforms: linux/386,linux/amd64,linux/arm/v6,linux/arm/v7,linux/arm64/v8 - repo: alcapone1933/ddns-ipv64 - tags: dev - dry_run: true - -trigger: - branch: - - development - event: - - custom - # - push - # - pull_request - ---- -kind: pipeline -type: docker -name: BUILD-Dockerhub-DEV -steps: - - name: Build Multi-arch - image: alcapone1933/drone:docker-buildx - privileged: true - settings: - username: - from_secret: DOCKER_USER - password: - from_secret: DOCKER_PASS - platforms: linux/386,linux/amd64,linux/arm/v6,linux/arm/v7,linux/arm64/v8 - repo: alcapone1933/ddns-ipv64 - # tags: latest - auto_tag: true - auto_tag_suffix: dev - -trigger: - branch: - - development - event: - - custom - # - push - # - pull_request - -depends_on: - - BUILD-TEST-DEV diff --git a/Dockerfile b/Dockerfile index 36223f9..e562e32 100644 --- a/Dockerfile +++ b/Dockerfile @@ -21,9 +21,8 @@ RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone & mkdir -p /data /usr/local/bin/ /etc/cron.d/ COPY data /data COPY --from=alcapone1933/shoutrrr:latest /usr/local/bin/shoutrrr /usr/local/bin/shoutrrr -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 +RUN cd /data && chmod +x *.sh && 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 && touch /var/log/cron.log # VOLUME [ "/data" ] ENTRYPOINT ["/sbin/tini", "--", "/usr/local/bin/entrypoint.sh"] diff --git a/data/cronjob b/data/cronjob index 22fdf5c..1287bb4 100644 --- a/data/cronjob +++ b/data/cronjob @@ -1,5 +1,6 @@ # Cronjob DDNS Updater ipv64.net */15 * * * * /bin/bash /data/ddns-update.sh >> /var/log/cron.log 2>&1 +*/30 * * * * sleep 20 && /bin/bash /data/domain-ip-scheck.sh >> /var/log/cron.log 2>&1 # */30 * * * * 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 -*/30 * * * * 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 ${DOMAIN} HAT DIE IP=`dig +short ${DOMAIN} A @ns1.ipv64.net`" >> /var/log/cron.log 2>&1; done -# */30 * * * * 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 +# */30 * * * * sleep 20 && for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); do echo "`date +%Y-%m-%d\ %H:%M:%S` IP CHECK - Deine DOMAIN ${DOMAIN} HAT DIE IP=`dig +short ${DOMAIN} A @ns1.ipv64.net`" >> /var/log/cron.log 2>&1; done +# */30 * * * * sleep 20 && for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); 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 diff --git a/data/ddns-update-dkey-praefix.sh b/data/ddns-update-dkey-praefix.sh index 1e7dcff..438f6de 100644 --- a/data/ddns-update-dkey-praefix.sh +++ b/data/ddns-update-dkey-praefix.sh @@ -1,8 +1,8 @@ #!/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 +if ! curl -sSL --user-agent "${CURL_USER_AGENT}" --fail "https://ipv64.net" 2>&1 > /dev/null; then echo "$DATUM FEHLER !!! - 404 Sie haben kein Netzwerk oder Internetzugang oder die Webseite ipv64.net ist nicht erreichbar" - exit 0 + exit 0 fi PFAD="/data" IP=$(curl -4ssL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php?howismyip" | jq -r 'to_entries[] | "\(.value)"') diff --git a/data/ddns-update-dkey.sh b/data/ddns-update-dkey.sh index 72c1254..2db7ff9 100644 --- a/data/ddns-update-dkey.sh +++ b/data/ddns-update-dkey.sh @@ -1,8 +1,8 @@ #!/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 +if ! curl -sSL --user-agent "${CURL_USER_AGENT}" --fail "https://ipv64.net" 2>&1 > /dev/null; then echo "$DATUM FEHLER !!! - 404 Sie haben kein Netzwerk oder Internetzugang oder die Webseite ipv64.net ist nicht erreichbar" - exit 0 + 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) diff --git a/data/ddns-update-praefix.sh b/data/ddns-update-praefix.sh index 33a792a..674cc37 100644 --- a/data/ddns-update-praefix.sh +++ b/data/ddns-update-praefix.sh @@ -1,8 +1,8 @@ #!/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 +if ! curl -sSL --user-agent "${CURL_USER_AGENT}" --fail "https://ipv64.net" 2>&1 > /dev/null; then echo "$DATUM FEHLER !!! - 404 Sie haben kein Netzwerk oder Internetzugang oder die Webseite ipv64.net ist nicht erreichbar" - exit 0 + exit 0 fi PFAD="/data" IP=$(curl -4ssL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.php?howismyip" | jq -r 'to_entries[] | "\(.value)"') @@ -14,7 +14,7 @@ function SHOUTRRR_NOTIFY() { NOTIFY=" DOCKER DDNS UPDATER IPV64.NET - IP UPDATE !!! \n -`for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do echo "$DATUM UPDATE !!! \nUpdate IP=$IP - Alte-IP=$UPDIP \nDOMAIN mit PRAEFIX: ${DOMAIN_PRAEFIX}.${DOMAIN} \n"; done`" +`for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); do echo "$DATUM UPDATE !!! \nUpdate IP=$IP - Alte-IP=$UPDIP \nDOMAIN mit PRAEFIX: ${DOMAIN_PRAEFIX}.${DOMAIN} \n"; done`" /usr/local/bin/shoutrrr send --url "${SHOUTRRR_URL}" --message "`echo -e "${NOTIFY}"`" 2> /dev/null } @@ -50,11 +50,11 @@ 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) -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) +DOMAIN_CHECK=$(for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); 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`" - 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 + for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); 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 !!! ..." echo "$DATUM UPDATE !!! - NACHEINTRAG DIE IP WIRD NOCH EINMAL GESETZT" @@ -78,7 +78,7 @@ else # 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`" - 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//,/ }"); do echo "$DATUM NACHEINTRAG - DOMAIN mit PRAEFIX HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN_PRAEFIX}.${DOMAIN} A @ns1.ipv64.net`"; done fi } CHECK_A_DOMAIN diff --git a/data/ddns-update.sh b/data/ddns-update.sh index 15931a1..f8fb8bd 100644 --- a/data/ddns-update.sh +++ b/data/ddns-update.sh @@ -1,8 +1,8 @@ #!/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 +if ! curl -sSL --user-agent "${CURL_USER_AGENT}" --fail "https://ipv64.net" 2>&1 > /dev/null; then echo "$DATUM FEHLER !!! - 404 Sie haben kein Netzwerk oder Internetzugang oder die Webseite ipv64.net ist nicht erreichbar" - exit 0 + 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) @@ -15,7 +15,7 @@ function SHOUTRRR_NOTIFY() { NOTIFY=" DOCKER DDNS UPDATER IPV64.NET - IP UPDATE !!! \n -`for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do echo "$DATUM UPDATE !!! \nUpdate IP=$IP - Alte-IP=$UPDIP \nDOMAIN: ${DOMAIN} \n"; done`" +`for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); do echo "$DATUM UPDATE !!! \nUpdate IP=$IP - Alte-IP=$UPDIP \nDOMAIN: ${DOMAIN} \n"; done`" /usr/local/bin/shoutrrr send --url "${SHOUTRRR_URL}" --message "`echo -e "${NOTIFY}"`" 2> /dev/null } @@ -51,11 +51,11 @@ 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) -DOMAIN_CHECK=$(for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do dig +short ${DOMAIN} A @ns1.ipv64.net; done | tail -n 1) +DOMAIN_CHECK=$(for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); 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`" - 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 + for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); do echo "$DATUM CHECK - DOMAIN HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN} A @ns1.ipv64.net`"; done else echo "$DATUM UPDATE !!! ..." echo "$DATUM UPDATE !!! - NACHEINTRAG DIE IP WIRD NOCH EINMAL GESETZT" @@ -79,7 +79,7 @@ else # 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`" - 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//,/ }"); do echo "$DATUM NACHEINTRAG - DOMAIN HAT DEN A-RECORD=`dig +noall +answer ${DOMAIN} A @ns1.ipv64.net`"; done fi } CHECK_A_DOMAIN diff --git a/data/domain-ip-scheck.sh b/data/domain-ip-scheck.sh new file mode 100644 index 0000000..42a1163 --- /dev/null +++ b/data/domain-ip-scheck.sh @@ -0,0 +1,10 @@ +#!/usr/bin/env bash +if [[ "${DOMAIN_PRAEFIX_YES}" =~ (YES|yes|Yes) ]] ; then + for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); do + echo "`date +%Y-%m-%d\ %H:%M:%S` IP CHECK - Deine DOMAIN ${DOMAIN} HAT DIE IP=`dig +short ${DOMAIN} A @ns1.ipv64.net`" >> /var/log/cron.log 2>&1 + done +else + for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); 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 +fi diff --git a/data/entrypoint.sh b/data/entrypoint.sh index 68c5a27..2c86f2b 100644 --- a/data/entrypoint.sh +++ b/data/entrypoint.sh @@ -44,7 +44,7 @@ if [[ "${DOMAIN_PRAEFIX_YES}" =~ (YES|yes|Yes) ]] ; then exit 1 else echo "$DATUM DOMAIN - Sie haben eine DOMAIN gesetzt" - for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do echo "$DATUM DOMAIN - Deine DOMAIN mit PRAEFIX ${DOMAIN_PRAEFIX}.${DOMAIN}"; done + for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); do echo "$DATUM DOMAIN - Deine DOMAIN mit PRAEFIX ${DOMAIN_PRAEFIX}.${DOMAIN}"; done fi else if [ -z "${DOMAIN_IPV64:-}" ] ; then @@ -53,7 +53,7 @@ else else echo "$DATUM DOMAIN - Sie haben eine DOMAIN gesetzt" # echo "$DATUM DOMAIN - Deine DOMAIN $DOMAIN_IPV64" - for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do echo "$DATUM DOMAIN - Deine DOMAIN ${DOMAIN}"; done + for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); do echo "$DATUM DOMAIN - Deine DOMAIN ${DOMAIN}"; done fi fi @@ -64,9 +64,19 @@ else echo "$DATUM DOMAIN KEY - Sie haben einen DOMAIN Key gesetzt" fi -if ! curl -sSL --user-agent "${CURL_USER_AGENT}" --fail "https://ipv64.net" > /dev/null; then +if [ -z "${CRON_TIME:-}" ] ; then + echo "$DATUM FEHLER !!! - Sie haben die Environment CRON_TIME nicht gesetzt" + exit 1 +fi + +if [ -z "${CRON_TIME_DIG:-}" ] ; then + echo "$DATUM FEHLER !!! - Sie haben die Environment CRON_TIME_DIG nicht gesetzt" + exit 1 +fi + +if ! curl -sSL --user-agent "${CURL_USER_AGENT}" --fail "https://ipv64.net" 2>&1 > /dev/null; then echo "$DATUM FEHLER !!! - 404 Sie haben kein Netzwerk oder Internetzugang oder die Webseite ipv64.net ist nicht erreichbar" - exit 0 + exit 0 fi if [ -z "${SHOUTRRR_URL:-}" ] ; then @@ -92,14 +102,15 @@ CHECK=$(curl -4sSL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.p if [[ "$CHECK" =~ (nochg|good|ok) ]] ; then echo "$DATUM CHECK - Die Angaben sind richtig gesetzt: DOMAIN und DOMAIN KEY" sleep 5 - for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do echo "$DATUM IP CHECK - Deine DOMAIN ${DOMAIN} HAT DIE IP=`dig +short ${DOMAIN} A @ns1.ipv64.net`"; done + for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); do echo "$DATUM IP CHECK - Deine DOMAIN ${DOMAIN} HAT DIE IP=`dig +short ${DOMAIN} A @ns1.ipv64.net`"; done else echo "$DATUM FEHLER !!! - Die Angaben sind falsch gesetzt: DOMAIN oder DOMAIN KEY" exit 1 fi echo "${CRON_TIME} /bin/bash /data/ddns-update.sh >> /var/log/cron.log 2>&1" > /etc/cron.d/container_cronjob +echo "${CRON_TIME_DIG} sleep 20 && /bin/bash /data/domain-ip-scheck.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 -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 ${DOMAIN} HAT DIE IP=`dig +short ${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//,/ }"); do echo "`date +%Y-%m-%d\ %H:%M:%S` IP CHECK - Deine DOMAIN ${DOMAIN} HAT DIE IP=`dig +short ${DOMAIN} A @ns1.ipv64.net`" >> /var/log/cron.log 2>&1; done' >> /etc/cron.d/container_cronjob } function Domain_mit_praefix() { @@ -107,13 +118,15 @@ CHECK=$(curl -4sSL --user-agent "${CURL_USER_AGENT}" "https://ipv64.net/update.p if [[ "$CHECK" =~ (nochg|good|ok) ]] ; then echo "$DATUM CHECK - Die Angaben sind richtig gesetzt: DOMAIN mit PRAEFIX und DOMAIN KEY" sleep 5 - for DOMAIN in $(echo "${DOMAIN_IPV64}" | sed -e "s/,/ /g"); do echo "$DATUM IP CHECK - Deine DOMAIN mit PRAEFIX ${DOMAIN_PRAEFIX}.${DOMAIN} HAT DIE IP=`dig +short ${DOMAIN_PRAEFIX}.${DOMAIN} A @ns1.ipv64.net`"; done + for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); do echo "$DATUM IP CHECK - Deine DOMAIN mit PRAEFIX ${DOMAIN_PRAEFIX}.${DOMAIN} HAT DIE IP=`dig +short ${DOMAIN_PRAEFIX}.${DOMAIN} A @ns1.ipv64.net`"; done 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-praefix.sh >> /var/log/cron.log 2>&1" > /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 +echo "${CRON_TIME_DIG} sleep 20 && /bin/bash /data/domain-ip-scheck.sh >> /var/log/cron.log 2>&1" >> /etc/cron.d/container_cronjob +# echo "$CRON_TIME_DIG" 'sleep 20 && for DOMAIN in $(echo "${DOMAIN_IPV64//,/ }"); 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 diff --git a/data/healthcheck.sh b/data/healthcheck.sh index 48fa145..ed95f4c 100644 --- a/data/healthcheck.sh +++ b/data/healthcheck.sh @@ -1,7 +1,7 @@ #!/usr/bin/env bash DATUM=$(date +%Y-%m-%d\ %H:%M:%S) set -e -if ! curl -sSL --user-agent "${CURL_USER_AGENT}" --fail "https://ipv64.net" > /dev/null; then +if ! curl -sSL --user-agent "${CURL_USER_AGENT}" --fail "https://ipv64.net" 2>&1 > /dev/null; then echo "$DATUM FEHLER !!! - 404 Sie haben kein Netzwerk oder Internetzugang oder die Webseite ipv64.net ist nicht erreichbar" - exit 0 + exit 0 fi