|
@@ -23,8 +23,9 @@ dns_huaweicloud_add() {
|
|
|
HUAWEICLOUD_Password="${HUAWEICLOUD_Password:-$(_readaccountconf_mutable HUAWEICLOUD_Password)}"
|
|
|
HUAWEICLOUD_ProjectID="${HUAWEICLOUD_ProjectID:-$(_readaccountconf_mutable HUAWEICLOUD_ProjectID)}"
|
|
|
|
|
|
- if [ -z "${HUAWEICLOUD_Username}" ] || [ -z "${HUAWEICLOUD_Username}" ] || [ -z "${HUAWEICLOUD_Username}" ]; then
|
|
|
- _err "Not enough info provided to dns_huaweicloud!"
|
|
|
+ # Check information
|
|
|
+ if [ -z "${HUAWEICLOUD_Username}" ] || [ -z "${HUAWEICLOUD_Password}" ] || [ -z "${HUAWEICLOUD_ProjectID}" ]; then
|
|
|
+ _err "Not enough information provided to dns_huaweicloud!"
|
|
|
return 1
|
|
|
fi
|
|
|
|
|
@@ -62,8 +63,9 @@ dns_huaweicloud_rm() {
|
|
|
HUAWEICLOUD_Password="${HUAWEICLOUD_Password:-$(_readaccountconf_mutable HUAWEICLOUD_Password)}"
|
|
|
HUAWEICLOUD_ProjectID="${HUAWEICLOUD_ProjectID:-$(_readaccountconf_mutable HUAWEICLOUD_ProjectID)}"
|
|
|
|
|
|
- if [ -z "${HUAWEICLOUD_Username}" ] || [ -z "${HUAWEICLOUD_Username}" ] || [ -z "${HUAWEICLOUD_Username}" ]; then
|
|
|
- _err "Please provide enough information"
|
|
|
+ # Check information
|
|
|
+ if [ -z "${HUAWEICLOUD_Username}" ] || [ -z "${HUAWEICLOUD_Password}" ] || [ -z "${HUAWEICLOUD_ProjectID}" ]; then
|
|
|
+ _err "Not enough information provided to dns_huaweicloud!"
|
|
|
return 1
|
|
|
fi
|
|
|
|
|
@@ -75,6 +77,8 @@ dns_huaweicloud_rm() {
|
|
|
_debug "Record Set ID is: ${record_id}"
|
|
|
|
|
|
# Remove all records
|
|
|
+ # Therotically HuaweiCloud does not allow more than one record set
|
|
|
+ # But remove them recurringly to increase robusty
|
|
|
while [ "${record_id}" != "0" ]; do
|
|
|
_debug "Removing Record"
|
|
|
_rm_record "${token}" "${zoneid}" "${record_id}"
|
|
@@ -143,22 +147,12 @@ _add_record() {
|
|
|
export _H1="X-Auth-Token: ${_token}"
|
|
|
response=$(_get "${dns_api}/v2/zones/${zoneid}/recordsets?name=${_domain}")
|
|
|
|
|
|
- _debug "${response}"
|
|
|
- _exist_record=$(echo "${response}" | _egrep_o '"records":[^]]*' | sed 's/\"records\"\:\[//g')
|
|
|
+ _debug2 "${response}"
|
|
|
+ _exist_record=$(echo "${response}" | tr -d "\\r\\n" | _egrep_o '"records":[^]]*' | sed 's/\"records\"\:\[//g')
|
|
|
_debug "${_exist_record}"
|
|
|
|
|
|
# Check if record exist
|
|
|
# Generate body data
|
|
|
- _post_body="{
|
|
|
- \"name\": \"${_domain}.\",
|
|
|
- \"description\": \"ACME Challenge\",
|
|
|
- \"type\": \"TXT\",
|
|
|
- \"ttl\": 1,
|
|
|
- \"records\": [
|
|
|
- ${_exist_record},
|
|
|
- \"\\\"${_txtvalue}\\\"\"
|
|
|
- ]
|
|
|
- }"
|
|
|
if [ -z "${_exist_record}" ]; then
|
|
|
_post_body="{
|
|
|
\"name\": \"${_domain}.\",
|
|
@@ -169,6 +163,17 @@ _add_record() {
|
|
|
\"\\\"${_txtvalue}\\\"\"
|
|
|
]
|
|
|
}"
|
|
|
+ else
|
|
|
+ _post_body="{
|
|
|
+ \"name\": \"${_domain}.\",
|
|
|
+ \"description\": \"ACME Challenge\",
|
|
|
+ \"type\": \"TXT\",
|
|
|
+ \"ttl\": 1,
|
|
|
+ \"records\": [
|
|
|
+ ${_exist_record},
|
|
|
+ \"\\\"${_txtvalue}\\\"\"
|
|
|
+ ]
|
|
|
+ }"
|
|
|
fi
|
|
|
|
|
|
_record_id="$(_get_recordset_id "${_token}" "${_domain}" "${zoneid}")"
|
|
@@ -179,20 +184,17 @@ _add_record() {
|
|
|
_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 _H1="X-Auth-Token: ${_token}"
|
|
|
|
|
|
- _debug "${_post_body}"
|
|
|
- sleep 2
|
|
|
+ _debug2 "${_post_body}"
|
|
|
_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")"
|
|
|
if [ "$_code" != "202" ]; then
|
|
|
_err "dns_huaweicloud: http code ${_code}"
|
|
|
- sleep 60
|
|
|
return 1
|
|
|
fi
|
|
|
return 0
|