dns_vultr.sh 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. #!/usr/bin/env sh
  2. # shellcheck disable=SC2034
  3. dns_vultr_info='vultr.com
  4. Site: vultr.com
  5. Docs: github.com/acmesh-official/acme.sh/wiki/dnsapi2#dns_vultr
  6. Options:
  7. VULTR_API_KEY API Key
  8. Issues: github.com/acmesh-official/acme.sh/issues/2374
  9. '
  10. VULTR_Api="https://api.vultr.com/v2"
  11. ######## Public functions #####################
  12. #
  13. #Usage: add _acme-challenge.www.domain.com "XKrxpRBosdIKFzxW_CT3KLZNf6q0HG9i01zxXp5CPBs"
  14. dns_vultr_add() {
  15. fulldomain=$1
  16. txtvalue=$2
  17. _debug fulldomain "$fulldomain"
  18. _debug txtvalue "$txtvalue"
  19. VULTR_API_KEY="${VULTR_API_KEY:-$(_readaccountconf_mutable VULTR_API_KEY)}"
  20. if test -z "$VULTR_API_KEY"; then
  21. VULTR_API_KEY=''
  22. _err 'VULTR_API_KEY was not exported'
  23. return 1
  24. fi
  25. _saveaccountconf_mutable VULTR_API_KEY "$VULTR_API_KEY"
  26. _debug 'First detect the root zone'
  27. if ! _get_root "$fulldomain"; then
  28. return 1
  29. fi
  30. _debug _sub_domain "$_sub_domain"
  31. _debug _domain "$_domain"
  32. _debug 'Getting txt records'
  33. _vultr_rest GET "domains/$_domain/records"
  34. if printf "%s\n" "$response" | grep -- "\"type\":\"TXT\",\"name\":\"$fulldomain\"" >/dev/null; then
  35. _err 'Error'
  36. return 1
  37. fi
  38. if ! _vultr_rest POST "domains/$_domain/records" "{\"name\":\"$_sub_domain\",\"data\":\"$txtvalue\",\"type\":\"TXT\"}"; then
  39. _err "$response"
  40. return 1
  41. fi
  42. _debug2 _response "$response"
  43. return 0
  44. }
  45. #fulldomain txtvalue
  46. dns_vultr_rm() {
  47. fulldomain=$1
  48. txtvalue=$2
  49. _debug fulldomain "$fulldomain"
  50. _debug txtvalue "$txtvalue"
  51. VULTR_API_KEY="${VULTR_API_KEY:-$(_readaccountconf_mutable VULTR_API_KEY)}"
  52. if test -z "$VULTR_API_KEY"; then
  53. VULTR_API_KEY=""
  54. _err 'VULTR_API_KEY was not exported'
  55. return 1
  56. fi
  57. _saveaccountconf_mutable VULTR_API_KEY "$VULTR_API_KEY"
  58. _debug 'First detect the root zone'
  59. if ! _get_root "$fulldomain"; then
  60. return 1
  61. fi
  62. _debug _sub_domain "$_sub_domain"
  63. _debug _domain "$_domain"
  64. _debug 'Getting txt records'
  65. _vultr_rest GET "domains/$_domain/records"
  66. if printf "%s\n" "$response" | grep -- "\"type\":\"TXT\",\"name\":\"$fulldomain\"" >/dev/null; then
  67. _err 'Error'
  68. return 1
  69. fi
  70. _record_id="$(echo "$response" | tr '{}' '\n' | grep '"TXT"' | grep -- "$txtvalue" | tr ',' '\n' | grep -i 'id' | cut -d : -f 2 | tr -d '"')"
  71. _debug _record_id "$_record_id"
  72. if [ "$_record_id" ]; then
  73. _info "Successfully retrieved the record id for ACME challenge."
  74. else
  75. _info "Empty record id, it seems no such record."
  76. return 0
  77. fi
  78. if ! _vultr_rest DELETE "domains/$_domain/records/$_record_id"; then
  79. _err "$response"
  80. return 1
  81. fi
  82. _debug2 _response "$response"
  83. return 0
  84. }
  85. #################### Private functions below ##################################
  86. #_acme-challenge.www.domain.com
  87. #returns
  88. # _sub_domain=_acme-challenge.www
  89. # _domain=domain.com
  90. # _domain_id=sdjkglgdfewsdfg
  91. _get_root() {
  92. domain=$1
  93. i=1
  94. while true; do
  95. _domain=$(printf "%s" "$domain" | cut -d . -f "$i"-100)
  96. _debug h "$_domain"
  97. if [ -z "$_domain" ]; then
  98. return 1
  99. fi
  100. if ! _vultr_rest GET "domains"; then
  101. return 1
  102. fi
  103. if printf "%s\n" "$response" | grep -E '^\{.*\}' >/dev/null; then
  104. if _contains "$response" "\"domain\":\"$_domain\""; then
  105. _sub_domain="$(echo "$fulldomain" | sed "s/\\.$_domain\$//")"
  106. return 0
  107. else
  108. _debug "Go to next level of $_domain"
  109. fi
  110. else
  111. _err "$response"
  112. return 1
  113. fi
  114. i=$(_math "$i" + 1)
  115. done
  116. return 1
  117. }
  118. _vultr_rest() {
  119. m=$1
  120. ep="$2"
  121. data="$3"
  122. _debug "$ep"
  123. api_key_trimmed=$(echo "$VULTR_API_KEY" | tr -d '"')
  124. export _H1="Authorization: Bearer $api_key_trimmed"
  125. export _H2='Content-Type: application/json'
  126. if [ "$m" != "GET" ]; then
  127. _debug data "$data"
  128. response="$(_post "$data" "$VULTR_Api/$ep" "" "$m")"
  129. else
  130. response="$(_get "$VULTR_Api/$ep")"
  131. fi
  132. if [ "$?" != "0" ]; then
  133. _err "Error $ep"
  134. return 1
  135. fi
  136. _debug2 response "$response"
  137. return 0
  138. }