cloudflareddns.sh 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. #!/bin/bash
  2. set -e;
  3. ipv4Regex="((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])"
  4. ipv6Regex="(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))"
  5. ipv6="true"
  6. # proxy="true"
  7. # ask for existing proxy, don't override it <.<
  8. # DSM Config
  9. username="$1"
  10. password="$2"
  11. hostname="$3"
  12. ipAddr="$4"
  13. #Fetch and filter IPv6, if Synology won't provide it
  14. if [[ $ipv6 = "true" ]]; then
  15. ip6fetch=$(ip -6 addr show eth0 | grep -oP "$ipv6Regex" || true)
  16. ip6Addr=$(if [ -z "$ip6fetch" ]; then echo ""; else echo "${ip6fetch:0:$((${#ip6fetch})) - 7}"; fi) # in case of NULL, echo NULL
  17. recType6="AAAA"
  18. if [[ -z "$ip6Addr" ]]; then
  19. ipv6="false"; # if only ipv4 is available
  20. fi
  21. if [[ $ipAddr =~ $ipv4Regex ]]; then
  22. recordType="A";
  23. else
  24. recordType="AAAA";
  25. ipv6="false"; # because, Synology had provided the IPv6
  26. fi
  27. else
  28. recordType="A";
  29. fi
  30. # Cloudflare API-Calls for listing entries
  31. listDnsApi="https://api.cloudflare.com/client/v4/zones/${username}/dns_records?type=${recordType}&name=${hostname}"
  32. # above only, if IPv4 and/or IPv6 is provided
  33. listDnsv6Api="https://api.cloudflare.com/client/v4/zones/${username}/dns_records?type=${recType6}&name=${hostname}" # if only IPv4 is provided
  34. res=$(curl -s -X GET "$listDnsApi" -H "Authorization: Bearer $password" -H "Content-Type:application/json")
  35. resSuccess=$(echo "$res" | jq -r ".success")
  36. if [[ $ipv6 = "true" ]]; then ## Adding new commands, if Synology didn't provided IPv6
  37. resv6=$(curl -s -X GET "$listDnsv6Api" -H "Authorization: Bearer $password" -H "Content-Type:application/json");
  38. fi
  39. if [[ $resSuccess != "true" ]]; then
  40. echo "badauth";
  41. exit 1;
  42. fi
  43. recordId=$(echo "$res" | jq -r ".result[0].id")
  44. recordIp=$(echo "$res" | jq -r ".result[0].content")
  45. recordProx=$(echo "$res" | jq -r ".result[0].proxied")
  46. if [[ $ipv6 = "true" ]]; then
  47. recordIdv6=$(echo "$resv6" | jq -r ".result[0].id");
  48. recordIpv6=$(echo "$resv6" | jq -r ".result[0].content");
  49. recordProxv6=$(echo "$resv6" | jq -r ".result[0].proxied");
  50. fi
  51. # API-Calls for creating DNS-Entries
  52. createDnsApi="https://api.cloudflare.com/client/v4/zones/${username}/dns_records" # does also work for IPv6
  53. # API-Calls for update DNS-Entries
  54. updateDnsApi="https://api.cloudflare.com/client/v4/zones/${username}/dns_records/${recordId}" # for IPv4 or if provided IPv6
  55. update6DnsApi="https://api.cloudflare.com/client/v4/zones/${username}/dns_records/${recordIdv6}" # if only IPv4 is provided
  56. if [[ $recordIp = "$ipAddr" ]] && [[ $recordIpv6 = "$ip6Addr" ]]; then
  57. echo "nochg";
  58. exit 0;
  59. fi
  60. if [[ $recordId = "null" ]]; then
  61. # Record not exists
  62. proxy="true" # new Record. Enable proxy by default
  63. res=$(curl -s -X POST "$createDnsApi" -H "Authorization: Bearer $password" -H "Content-Type:application/json" --data "{\"type\":\"$recordType\",\"name\":\"$hostname\",\"content\":\"$ipAddr\",\"proxied\":$proxy}")
  64. else
  65. # Record exists
  66. res=$(curl -s -X PUT "$updateDnsApi" -H "Authorization: Bearer $password" -H "Content-Type:application/json" --data "{\"type\":\"$recordType\",\"name\":\"$hostname\",\"content\":\"$ipAddr\",\"proxied\":$recordProx}")
  67. fi
  68. if [[ $ipv6 = "true" ]] ; then
  69. if [[ $recordIdv6 = "null" ]]; then
  70. # IPv6 Record not exists
  71. proxy="true"; # new entry, enable proxy by default
  72. res6=$(curl -s -X POST "$createDnsApi" -H "Authorization: Bearer $password" -H "Content-Type:application/json" --data "{\"type\":\"$recType6\",\"name\":\"$hostname\",\"content\":\"$ip6Addr\",\"proxied\":$proxy}");
  73. else
  74. # IPv6 Record exists
  75. res6=$(curl -s -X PUT "$update6DnsApi" -H "Authorization: Bearer $password" -H "Content-Type:application/json" --data "{\"type\":\"$recType6\",\"name\":\"$hostname\",\"content\":\"$ip6Addr\",\"proxied\":$recordProxv6}");
  76. fi;
  77. res6Success=$(echo "$res6" | jq -r ".success");
  78. fi
  79. resSuccess=$(echo "$res" | jq -r ".success")
  80. if [[ $resSuccess = "true" ]] || [[ $res6Success = "true" ]]; then
  81. echo "good";
  82. else
  83. echo "badauth";
  84. fi