From 476bcd446c256945618d071b65d1ef55c02498f6 Mon Sep 17 00:00:00 2001 From: fenghe Date: Fri, 10 Apr 2020 10:12:32 +0800 Subject: [PATCH 1/2] try compatible with ipv6 --- cf-v4-ddns.sh | 20 +++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/cf-v4-ddns.sh b/cf-v4-ddns.sh index 3242a56..f814d69 100644 --- a/cf-v4-ddns.sh +++ b/cf-v4-ddns.sh @@ -19,6 +19,7 @@ set -o pipefail # -u user@example.com \ # -h host.example.com \ # fqdn of the record you want to update # -z example.com \ # will show you all zones if forgot, but you need this +# -t A|AAAA # specify ipv4/ipv6, default: ipv4 # Optional flags: # -f false|true \ # force dns update, disregard local stored ip @@ -38,22 +39,35 @@ CFZONE_NAME= # Hostname to update, eg: homeserver.example.com CFRECORD_NAME= +# Record type, A: IPv4 / AAAA: IPv6, default IPv4 +CFRECORD_TYPE=A + # Cloudflare TTL for record, between 120 and 86400 seconds CFTTL=120 # Ignore local file, update ip anyway FORCE=false +WANIPSITE="http://ipv4.icanhazip.com" + # Site to retrieve WAN ip, other examples are: bot.whatismyipaddress.com, https://api.ipify.org/ ... -WANIPSITE="http://icanhazip.com" +if p["$CFRECORD_TYPE" = "A"]; then + : +elif ["$CFRECORD_TYPE" = "AAAA"]; then + WANIPSITE="http://ipv6.icanhazip.com" +else + echo "$CFRECORD_TYPE specified is invalid, CFRECORD_TYPE can only be A(IPv4) or AAAA(IPv6)" + exit 2 +fi # get parameter -while getopts k:u:h:z:f: opts; do +while getopts k:u:h:z:t:f: opts; do case ${opts} in k) CFKEY=${OPTARG} ;; u) CFUSER=${OPTARG} ;; h) CFRECORD_NAME=${OPTARG} ;; z) CFZONE_NAME=${OPTARG} ;; + t) CFRECORD_TYPE=${OPTARG} ;; f) FORCE=${OPTARG} ;; esac done @@ -121,7 +135,7 @@ RESPONSE=$(curl -s -X PUT "https://api.cloudflare.com/client/v4/zones/$CFZONE_ID -H "X-Auth-Email: $CFUSER" \ -H "X-Auth-Key: $CFKEY" \ -H "Content-Type: application/json" \ - --data "{\"id\":\"$CFZONE_ID\",\"type\":\"A\",\"name\":\"$CFRECORD_NAME\",\"content\":\"$WAN_IP\", \"ttl\":$CFTTL}") + --data "{\"id\":\"$CFZONE_ID\",\"type\":\"$CFRECORD_TYPE\",\"name\":\"$CFRECORD_NAME\",\"content\":\"$WAN_IP\", \"ttl\":$CFTTL}") if [ "$RESPONSE" != "${RESPONSE%success*}" ] && [ $(echo $RESPONSE | grep "\"success\":true") != "" ]; then echo "Updated succesfuly!" From e00f9c4a25dd081b520bffd4d328b4ce13e61f50 Mon Sep 17 00:00:00 2001 From: fenghe Date: Fri, 10 Apr 2020 10:12:32 +0800 Subject: [PATCH 2/2] try compatible with ipv6 --- README.md | 3 ++- cf-v4-ddns.sh | 20 +++++++++++++++++--- 2 files changed, 19 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 6e538f3..76da694 100644 --- a/README.md +++ b/README.md @@ -1 +1,2 @@ -Cloudflare API v4 Dynamic DNS Update in Bash, without unnecessary requests \ No newline at end of file +Cloudflare API v4 Dynamic DNS Update in Bash, without unnecessary requests +Now the script also supports v6(AAAA DDNS Recoards) \ No newline at end of file diff --git a/cf-v4-ddns.sh b/cf-v4-ddns.sh index 3242a56..0b0ed8b 100644 --- a/cf-v4-ddns.sh +++ b/cf-v4-ddns.sh @@ -19,6 +19,7 @@ set -o pipefail # -u user@example.com \ # -h host.example.com \ # fqdn of the record you want to update # -z example.com \ # will show you all zones if forgot, but you need this +# -t A|AAAA # specify ipv4/ipv6, default: ipv4 # Optional flags: # -f false|true \ # force dns update, disregard local stored ip @@ -38,22 +39,35 @@ CFZONE_NAME= # Hostname to update, eg: homeserver.example.com CFRECORD_NAME= +# Record type, A(IPv4)|AAAA(IPv6), default IPv4 +CFRECORD_TYPE=A + # Cloudflare TTL for record, between 120 and 86400 seconds CFTTL=120 # Ignore local file, update ip anyway FORCE=false +WANIPSITE="http://ipv4.icanhazip.com" + # Site to retrieve WAN ip, other examples are: bot.whatismyipaddress.com, https://api.ipify.org/ ... -WANIPSITE="http://icanhazip.com" +if [ "$CFRECORD_TYPE" = "A" ]; then + : +elif [ "$CFRECORD_TYPE" = "AAAA" ]; then + WANIPSITE="http://ipv6.icanhazip.com" +else + echo "$CFRECORD_TYPE specified is invalid, CFRECORD_TYPE can only be A(for IPv4)|AAAA(for IPv6)" + exit 2 +fi # get parameter -while getopts k:u:h:z:f: opts; do +while getopts k:u:h:z:t:f: opts; do case ${opts} in k) CFKEY=${OPTARG} ;; u) CFUSER=${OPTARG} ;; h) CFRECORD_NAME=${OPTARG} ;; z) CFZONE_NAME=${OPTARG} ;; + t) CFRECORD_TYPE=${OPTARG} ;; f) FORCE=${OPTARG} ;; esac done @@ -121,7 +135,7 @@ RESPONSE=$(curl -s -X PUT "https://api.cloudflare.com/client/v4/zones/$CFZONE_ID -H "X-Auth-Email: $CFUSER" \ -H "X-Auth-Key: $CFKEY" \ -H "Content-Type: application/json" \ - --data "{\"id\":\"$CFZONE_ID\",\"type\":\"A\",\"name\":\"$CFRECORD_NAME\",\"content\":\"$WAN_IP\", \"ttl\":$CFTTL}") + --data "{\"id\":\"$CFZONE_ID\",\"type\":\"$CFRECORD_TYPE\",\"name\":\"$CFRECORD_NAME\",\"content\":\"$WAN_IP\", \"ttl\":$CFTTL}") if [ "$RESPONSE" != "${RESPONSE%success*}" ] && [ $(echo $RESPONSE | grep "\"success\":true") != "" ]; then echo "Updated succesfuly!"