fix: fix adding record before removing

This commit is contained in:
Easton Man 2020-11-23 14:57:33 +08:00
parent f6f6550bfb
commit 5d0657c49a
1 changed files with 29 additions and 8 deletions

View File

@ -141,13 +141,15 @@ _add_record() {
# Get Existing Records # Get Existing Records
export _H1="X-Auth-Token: ${_token}" export _H1="X-Auth-Token: ${_token}"
response=$(_get "${dns_api}/v2/zones/${_zoneid}/recordsets?name=${_domain}") response=$(_get "${dns_api}/v2/zones/${zoneid}/recordsets?name=${_domain}")
_debug "${response}"
_exist_record=$(echo "${response}" | sed ':a;N;$!ba;s/\n/ /g' | grep -o '"records":[^]]*' | sed 's/\"records\"\:\[//g') _exist_record=$(echo "${response}" | sed ':a;N;$!ba;s/\n/ /g' | grep -o '"records":[^]]*' | sed 's/\"records\"\:\[//g')
_debug "${_exist_record}" _debug "${_exist_record}"
# Check if record exist # Check if record exist
# Generate body data # Generate body data
body="{ _post_body="{
\"name\": \"${_domain}.\", \"name\": \"${_domain}.\",
\"description\": \"ACME Challenge\", \"description\": \"ACME Challenge\",
\"type\": \"TXT\", \"type\": \"TXT\",
@ -158,7 +160,7 @@ _add_record() {
] ]
}" }"
if [ -z "${_exist_record}" ]; then if [ -z "${_exist_record}" ]; then
body="{ _post_body="{
\"name\": \"${_domain}.\", \"name\": \"${_domain}.\",
\"description\": \"ACME Challenge\", \"description\": \"ACME Challenge\",
\"type\": \"TXT\", \"type\": \"TXT\",
@ -168,19 +170,38 @@ _add_record() {
] ]
}" }"
fi fi
_debug2 "${body}"
_record_id="$(_get_recordset_id "${_token}" "${_domain}" "${zoneid}")"
_debug "Record Set ID is: ${_record_id}"
# Remove all records
while [ "${_record_id}" != "0" ]; do
_debug "Removing Record"
_rm_record "${_token}" "${zoneid}" "${_record_id}"
_record_id="$(_get_recordset_id "${_token}" "${_domain}" "${zoneid}")"
_debug "${_record_id}"
done
# Add brand new records with all old and new records
export _H2="Content-Type: application/json" export _H2="Content-Type: application/json"
export _H1="X-Auth-Token: ${_token}" export _H1="X-Auth-Token: ${_token}"
_post "${body}" "${dns_api}/v2/zones/${zoneid}/recordsets" >/dev/null _debug "${_post_body}"
sleep 2
_post "${_post_body}" "${dns_api}/v2/zones/${zoneid}/recordsets" >/dev/null
_code="$(grep "^HTTP" "$HTTP_HEADER" | _tail_n 1 | cut -d " " -f 2 | tr -d "\\r\\n")" _code="$(grep "^HTTP" "$HTTP_HEADER" | _tail_n 1 | cut -d " " -f 2 | tr -d "\\r\\n")"
if [ "$_code" != "202" ]; then if [ "$_code" != "202" ]; then
_err "dns_huaweicloud: http code ${_code}" _err "dns_huaweicloud: http code ${_code}"
sleep 60
return 1 return 1
fi fi
return 0 return 0
} }
# _rm_record $token $zoneid $recordid
# assume ${dns_api} exist
# no output
# return 0
_rm_record() { _rm_record() {
_token=$1 _token=$1
_zone_id=$2 _zone_id=$2
@ -189,8 +210,8 @@ _rm_record() {
export _H2="Content-Type: application/json" export _H2="Content-Type: application/json"
export _H1="X-Auth-Token: ${_token}" export _H1="X-Auth-Token: ${_token}"
_post "${body}" "${dns_api}/v2/zones/${_zone_id}/recordsets/${_record_id}" false "DELETE" >/dev/null _post "" "${dns_api}/v2/zones/${_zone_id}/recordsets/${_record_id}" false "DELETE" >/dev/null
return 0 return $?
} }
_get_token() { _get_token() {