From 7a0f5348b3ab4e7044af623b96532c80fb45f67e Mon Sep 17 00:00:00 2001 From: "M.A.Sarbanha" <39798816+sarbanha@users.noreply.github.com> Date: Wed, 13 Jul 2022 16:20:40 +0400 Subject: [PATCH] Updated: looks up for the domain zone --- dnsapi/dns_arvancdn | 134 ---------------------------------- dnsapi/dns_arvancdn.sh | 161 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 161 insertions(+), 134 deletions(-) delete mode 100644 dnsapi/dns_arvancdn create mode 100644 dnsapi/dns_arvancdn.sh diff --git a/dnsapi/dns_arvancdn b/dnsapi/dns_arvancdn deleted file mode 100644 index 52238936..00000000 --- a/dnsapi/dns_arvancdn +++ /dev/null @@ -1,134 +0,0 @@ -#!/usr/bin/env #!/bin/sh - -# Author: Mohammad Ali Sarbanha -# Repository: https://github.com/sarbanha/acme.sh-dnsapi-dns_arvancdn - -# export ARVAN_API_KEY="-----------" - -ARVAN_CDN_API="https://napi.arvancloud.com/cdn/4.0" - -#Usage: dns_arvancdn_add _acme-challenge.www.domain.com "XKrxpRBosdIKFzxW_CT3KLZNf6q0HG9i01zxXp5CPBs" -dns_arvancdn_add() { - - fulldomain=$1 - challenge=$2 - zone=${fulldomain:16} - - _debug "dns_arvan_add(): Started" - - ARVAN_API_KEY="${ARVAN_API_KEY:-$(_readaccountconf_mutable ARVAN_API_KEY)}" - if [ -z $ARVAN_API_KEY ]; then - ARVAN_API_KEY="" - _err "dns_arvan_add(): ARVAN_API_KEY has not been defined yet." - _err "dns_arvan_add(): export ARVAN_API_KEY=\"---YOUR-API-KEY---\"" - return 1 - fi - _saveaccountconf_mutable ARVAN_API_KEY "$ARVAN_API_KEY" - - _debug "dns_arvan_add(): Check domain root zone availability for $zone" - if ! _get_root $zone; then - _err "dns_arvan_add(): Invalid domain $zone" - return 1 - fi - - _debug "dns_arvan_add(): fulldomain $fulldomain" - _debug "dns_arvan_add(): textvalue $challenge" - _debug "dns_arvan_add(): domain $zone" - - _record_add $zone $challenge - -} - -#Usage: dns_arvancdn_rm fulldomain txtvalue -dns_arvancdn_rm(){ - - fulldomain=$1 - challenge=$2 - zone=${fulldomain:16} - - ARVAN_API_KEY="${ARVAN_API_KEY:-$(_readaccountconf_mutable ARVAN_API_KEY)}" - if [ -z $ARVAN_API_KEY ]; then - ARVAN_API_KEY="" - _err "dns_arvan_rm(): ARVAN_API_KEY has not been defined yet." - _err "dns_arvan_rm(): export ARVAN_API_KEY=\"---YOUR-API-KEY---\"" - return 1 - fi - - record_id=$(_record_get_id $zone $challenge) - - _record_remove $zone $record_id - -} - -#################### -# Private functions -#################### - -#Usage: _get_root zone -_get_root(){ - _zone=$1 - - export _H1="Content-Type: application-json" - export _H2="Authorization: apikey $ARVAN_API_KEY" - - _response=$(_get $ARVAN_CDN_API/domains/$_zone) - _debug2 "_get_root()" $_response - _debug2 "_get_root()" $_zone - if _contains "$_response" "$_zone"; then - # is valid - _valid=0 - else - # is not valid - _valid=1 - fi - - return $_valid -} - -#Usage: _record_add zone challenge -_record_add(){ - zone=$1 - challenge=$2 - - export _H1="Content-Type: application-json" - export _H2="Authorization: apikey $ARVAN_API_KEY" - - payload="{\"type\":\"txt\",\"name\":\"_acme-challenge\",\"cloud\":false,\"value\":{\"text\":\"$challenge\"},\"ttl\":120}" - _response=$(_post "$payload" "$ARVAN_CDN_API/domains/$zone/dns-records" "" "POST" "application/json" | _base64) - - _debug2 "_record_add(): " $_response - _debug2 " Payload: " $payload -} - -#Usage: _record_get_id zone challenge -_record_get_id(){ - - zone=$1 - challenge=$2 - - export _H1="Content-Type: application-json" - export _H2="Authorization: apikey $ARVAN_API_KEY" - - _response=$(_get $ARVAN_CDN_API/domains/$zone/dns-records/?type=txt\&search=$challenge | _json_decode | _normalizeJson | grep -Eo '"id":.*?,"value":\{"text":".*?"\}' | sed 's/"id":"\([^"]*\)".*/\1/') - _debug2 "_record_get_id(): " $_response - - - echo "$_response" - -} - -#Usage: _record_remove zone record_id -_record_remove(){ - - zone=$1 - record_id=$2 - - export _H1="Content-Type: application-json" - export _H2="Authorization: apikey $ARVAN_API_KEY" - - _response=$(_post "" $ARVAN_CDN_API/domains/$zone/dns-records/$record_id "" "DELETE" "application/json") - - _debug "_record_remove(): ACME Challenge Removed" - _debug2 " Response: " $_response - -} diff --git a/dnsapi/dns_arvancdn.sh b/dnsapi/dns_arvancdn.sh new file mode 100644 index 00000000..db1dfd13 --- /dev/null +++ b/dnsapi/dns_arvancdn.sh @@ -0,0 +1,161 @@ +#!/usr/bin/env #!/bin/sh + +# Author: Mohammad Ali Sarbanha +# Repository: https://github.com/sarbanha/acme.sh-dnsapi-dns_arvancdn + +# export ARVAN_API_KEY="-----------" + +ARVAN_CDN_API="https://napi.arvancloud.com/cdn/4.0" + +#Usage: dns_arvancdn_add _acme-challenge.www.domain.com "XKrxpRBosdIKFzxW_CT3KLZNf6q0HG9i01zxXp5CPBs" +dns_arvancdn_add() { + + _fulldomain=$1 + _challenge=$2 + + _debug "dns_arvan_add(): Started" + + ARVAN_API_KEY="${ARVAN_API_KEY:-$(_readaccountconf_mutable ARVAN_API_KEY)}" + if [ -z $ARVAN_API_KEY ]; then + ARVAN_API_KEY="" + _err "dns_arvan_add(): ARVAN_API_KEY has not been defined yet." + _err "dns_arvan_add(): export ARVAN_API_KEY=\"---YOUR-API-KEY---\"" + return 1 + fi + _saveaccountconf_mutable ARVAN_API_KEY "$ARVAN_API_KEY" + + _debug "dns_arvan_add(): Check domain root zone availability for $_fulldomain" + _zone=$(_get_root $_fulldomain) + if [ $? -ne 0 ]; then + _err "dns_arvan_add(): Root zone for $_fulldomain not found!" + return 1 + fi + + _record_name=$(echo $_zone | sed "s/\.\..*//") + _zone=$(echo $_zone | sed "s/.*\.\.//") + + _debug "dns_arvan_add(): fulldomain $_fulldomain" + _debug "dns_arvan_add(): textvalue $_challenge" + _debug "dns_arvan_add(): domain $_record_name" + _debug "dns_arvan_add(): domain $_zone" + + _record_add $_record_name $_zone $_challenge + +} + +#Usage: dns_arvancdn_rm fulldomain txtvalue +dns_arvancdn_rm(){ + + _fulldomain=$1 + _challenge=$2 + + ARVAN_API_KEY="${ARVAN_API_KEY:-$(_readaccountconf_mutable ARVAN_API_KEY)}" + if [ -z $ARVAN_API_KEY ]; then + ARVAN_API_KEY="" + _err "dns_arvan_rm(): ARVAN_API_KEY has not been defined yet." + _err "dns_arvan_rm(): export ARVAN_API_KEY=\"---YOUR-API-KEY---\"" + return 1 + fi + + _zone=$(_get_root $_fulldomain) + if [ $? -ne 0 ]; then + _err "dns_arvan_rm(): Root zone for $_fulldomain not found!" + return 1 + fi + + _record_name=$(echo $_zone | sed "s/\.\..*//") + _zone=$(echo $_zone | sed "s/.*\.\.//") + + + _record_id=$(_record_get_id $_zone $_challenge) + + _record_remove $_zone $_record_id + +} + +#################### +# Private functions +#################### + +#Usage: _get_root zone +_get_root(){ + _fulldomain=$1 + _zone=$_fulldomain + + export _H1="Content-Type: application-json" + export _H2="Authorization: apikey $ARVAN_API_KEY" + + _response=$(_get $ARVAN_CDN_API/domains) + _domains_list=( $( echo $_response | grep -Poe '"domain":"[^"]*"' | sed 's/"domain":"//' | sed 's/"//') ) + + _debug2 "_get_root(): $_response" + _debug2 "_get_root(): $_domains_list" + + #Fibding a matching Zone + while [[ ! -z $_zone ]]; do + for tmp in ${_domains_list[@]}; do + if [ $tmp = $_zone ]; then + break 2 + fi + done + _zone=$(echo $_zone | sed 's/^[^.]*\.\?//') + done + if [ -z $_zone ]; then + _debug2 "_get_root(): Zone not found on provider" + exit 1 + fi + + _marked_zone=$(echo $_fulldomain | sed "s/^\(.*\)\.\(${_zone}\)$/\1..\2/") + echo $_marked_zone + +} + +#Usage: _record_add record_name zone challenge +_record_add(){ + + _record_name=$1 + _zone=$2 + _challenge=$3 + + export _H1="Content-Type: application-json" + export _H2="Authorization: apikey $ARVAN_API_KEY" + + _payload="{\"type\":\"txt\",\"name\":\"$_record_name\",\"cloud\":false,\"value\":{\"text\":\"$_challenge\"},\"ttl\":120}" + _response=$(_post "$_payload" "$ARVAN_CDN_API/domains/$_zone/dns-records" "" "POST" "application/json" | _base64) + + _debug2 "_record_add(): " $_response + _debug2 " Payload: " $_payload +} + +#Usage: _record_get_id zone challenge +_record_get_id(){ + + _zone=$1 + _challenge=$2 + + export _H1="Content-Type: application-json" + export _H2="Authorization: apikey $ARVAN_API_KEY" + + _response=$(_get $ARVAN_CDN_API/domains/$_zone/dns-records/?type=txt\&search=$_challenge | _json_decode | _normalizeJson | grep -Eo '"id":.*?,"value":\{"text":".*?"\}' | sed 's/"id":"\([^"]*\)".*/\1/') + _debug2 "_record_get_id(): " $_response + + + echo "$_response" + +} + +#Usage: _record_remove zone record_id +_record_remove(){ + + _zone=$1 + _record_id=$2 + + export _H1="Content-Type: application-json" + export _H2="Authorization: apikey $ARVAN_API_KEY" + + _response=$(_post "" $ARVAN_CDN_API/domains/$_zone/dns-records/$_record_id "" "DELETE" "application/json") + + _debug "_record_remove(): ACME Challenge Removed" + _debug2 " Response: " $_response + +}