|
@ -2,7 +2,8 @@ |
|
|
|
|
|
|
|
|
# HUAWEICLOUD_Username |
|
|
# HUAWEICLOUD_Username |
|
|
# HUAWEICLOUD_Password |
|
|
# HUAWEICLOUD_Password |
|
|
# HUAWEICLOUD_ProjectID |
|
|
|
|
|
|
|
|
# HUAWEICLOUD_DomainName |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
iam_api="https://iam.myhuaweicloud.com" |
|
|
iam_api="https://iam.myhuaweicloud.com" |
|
|
dns_api="https://dns.ap-southeast-1.myhuaweicloud.com" # Should work |
|
|
dns_api="https://dns.ap-southeast-1.myhuaweicloud.com" # Should work |
|
@ -14,6 +15,8 @@ dns_api="https://dns.ap-southeast-1.myhuaweicloud.com" # Should work |
|
|
# |
|
|
# |
|
|
# Ref: https://support.huaweicloud.com/intl/zh-cn/api-dns/zh-cn_topic_0132421999.html |
|
|
# Ref: https://support.huaweicloud.com/intl/zh-cn/api-dns/zh-cn_topic_0132421999.html |
|
|
# |
|
|
# |
|
|
|
|
|
# About "DomainName" parameters see: https://support.huaweicloud.com/api-iam/iam_01_0006.html |
|
|
|
|
|
# |
|
|
|
|
|
|
|
|
dns_huaweicloud_add() { |
|
|
dns_huaweicloud_add() { |
|
|
fulldomain=$1 |
|
|
fulldomain=$1 |
|
@ -21,16 +24,16 @@ dns_huaweicloud_add() { |
|
|
|
|
|
|
|
|
HUAWEICLOUD_Username="${HUAWEICLOUD_Username:-$(_readaccountconf_mutable HUAWEICLOUD_Username)}" |
|
|
HUAWEICLOUD_Username="${HUAWEICLOUD_Username:-$(_readaccountconf_mutable HUAWEICLOUD_Username)}" |
|
|
HUAWEICLOUD_Password="${HUAWEICLOUD_Password:-$(_readaccountconf_mutable HUAWEICLOUD_Password)}" |
|
|
HUAWEICLOUD_Password="${HUAWEICLOUD_Password:-$(_readaccountconf_mutable HUAWEICLOUD_Password)}" |
|
|
HUAWEICLOUD_ProjectID="${HUAWEICLOUD_ProjectID:-$(_readaccountconf_mutable HUAWEICLOUD_ProjectID)}" |
|
|
|
|
|
|
|
|
HUAWEICLOUD_DomainName="${HUAWEICLOUD_DomainName:-$(_readaccountconf_mutable HUAWEICLOUD_Username)}" |
|
|
|
|
|
|
|
|
# Check information |
|
|
# Check information |
|
|
if [ -z "${HUAWEICLOUD_Username}" ] || [ -z "${HUAWEICLOUD_Password}" ] || [ -z "${HUAWEICLOUD_ProjectID}" ]; then |
|
|
|
|
|
|
|
|
if [ -z "${HUAWEICLOUD_Username}" ] || [ -z "${HUAWEICLOUD_Password}" ] || [ -z "${HUAWEICLOUD_DomainName}" ]; then |
|
|
_err "Not enough information provided to dns_huaweicloud!" |
|
|
_err "Not enough information provided to dns_huaweicloud!" |
|
|
return 1 |
|
|
return 1 |
|
|
fi |
|
|
fi |
|
|
|
|
|
|
|
|
unset token # Clear token |
|
|
unset token # Clear token |
|
|
token="$(_get_token "${HUAWEICLOUD_Username}" "${HUAWEICLOUD_Password}" "${HUAWEICLOUD_ProjectID}")" |
|
|
|
|
|
|
|
|
token="$(_get_token "${HUAWEICLOUD_Username}" "${HUAWEICLOUD_Password}" "${HUAWEICLOUD_DomainName}")" |
|
|
if [ -z "${token}" ]; then # Check token |
|
|
if [ -z "${token}" ]; then # Check token |
|
|
_err "dns_api(dns_huaweicloud): Error getting token." |
|
|
_err "dns_api(dns_huaweicloud): Error getting token." |
|
|
return 1 |
|
|
return 1 |
|
@ -56,7 +59,7 @@ dns_huaweicloud_add() { |
|
|
# Do saving work if all succeeded |
|
|
# Do saving work if all succeeded |
|
|
_saveaccountconf_mutable HUAWEICLOUD_Username "${HUAWEICLOUD_Username}" |
|
|
_saveaccountconf_mutable HUAWEICLOUD_Username "${HUAWEICLOUD_Username}" |
|
|
_saveaccountconf_mutable HUAWEICLOUD_Password "${HUAWEICLOUD_Password}" |
|
|
_saveaccountconf_mutable HUAWEICLOUD_Password "${HUAWEICLOUD_Password}" |
|
|
_saveaccountconf_mutable HUAWEICLOUD_ProjectID "${HUAWEICLOUD_ProjectID}" |
|
|
|
|
|
|
|
|
_saveaccountconf_mutable HUAWEICLOUD_DomainName "${HUAWEICLOUD_DomainName}" |
|
|
return 0 |
|
|
return 0 |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -72,16 +75,16 @@ dns_huaweicloud_rm() { |
|
|
|
|
|
|
|
|
HUAWEICLOUD_Username="${HUAWEICLOUD_Username:-$(_readaccountconf_mutable HUAWEICLOUD_Username)}" |
|
|
HUAWEICLOUD_Username="${HUAWEICLOUD_Username:-$(_readaccountconf_mutable HUAWEICLOUD_Username)}" |
|
|
HUAWEICLOUD_Password="${HUAWEICLOUD_Password:-$(_readaccountconf_mutable HUAWEICLOUD_Password)}" |
|
|
HUAWEICLOUD_Password="${HUAWEICLOUD_Password:-$(_readaccountconf_mutable HUAWEICLOUD_Password)}" |
|
|
HUAWEICLOUD_ProjectID="${HUAWEICLOUD_ProjectID:-$(_readaccountconf_mutable HUAWEICLOUD_ProjectID)}" |
|
|
|
|
|
|
|
|
HUAWEICLOUD_DomainName="${HUAWEICLOUD_DomainName:-$(_readaccountconf_mutable HUAWEICLOUD_Username)}" |
|
|
|
|
|
|
|
|
# Check information |
|
|
# Check information |
|
|
if [ -z "${HUAWEICLOUD_Username}" ] || [ -z "${HUAWEICLOUD_Password}" ] || [ -z "${HUAWEICLOUD_ProjectID}" ]; then |
|
|
|
|
|
|
|
|
if [ -z "${HUAWEICLOUD_Username}" ] || [ -z "${HUAWEICLOUD_Password}" ] || [ -z "${HUAWEICLOUD_DomainName}" ]; then |
|
|
_err "Not enough information provided to dns_huaweicloud!" |
|
|
_err "Not enough information provided to dns_huaweicloud!" |
|
|
return 1 |
|
|
return 1 |
|
|
fi |
|
|
fi |
|
|
|
|
|
|
|
|
unset token # Clear token |
|
|
unset token # Clear token |
|
|
token="$(_get_token "${HUAWEICLOUD_Username}" "${HUAWEICLOUD_Password}" "${HUAWEICLOUD_ProjectID}")" |
|
|
|
|
|
|
|
|
token="$(_get_token "${HUAWEICLOUD_Username}" "${HUAWEICLOUD_Password}" "${HUAWEICLOUD_DomainName}")" |
|
|
if [ -z "${token}" ]; then # Check token |
|
|
if [ -z "${token}" ]; then # Check token |
|
|
_err "dns_api(dns_huaweicloud): Error getting token." |
|
|
_err "dns_api(dns_huaweicloud): Error getting token." |
|
|
return 1 |
|
|
return 1 |
|
@ -253,7 +256,7 @@ _rm_record() { |
|
|
_get_token() { |
|
|
_get_token() { |
|
|
_username=$1 |
|
|
_username=$1 |
|
|
_password=$2 |
|
|
_password=$2 |
|
|
_project=$3 |
|
|
|
|
|
|
|
|
_domain_name=$3 |
|
|
|
|
|
|
|
|
_debug "Getting Token" |
|
|
_debug "Getting Token" |
|
|
body="{ |
|
|
body="{ |
|
@ -267,14 +270,14 @@ _get_token() { |
|
|
\"name\": \"${_username}\", |
|
|
\"name\": \"${_username}\", |
|
|
\"password\": \"${_password}\", |
|
|
\"password\": \"${_password}\", |
|
|
\"domain\": { |
|
|
\"domain\": { |
|
|
\"name\": \"${_username}\" |
|
|
|
|
|
|
|
|
\"name\": \"${_domain_name}\" |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
}, |
|
|
}, |
|
|
\"scope\": { |
|
|
\"scope\": { |
|
|
\"project\": { |
|
|
\"project\": { |
|
|
\"id\": \"${_project}\" |
|
|
|
|
|
|
|
|
\"name\": \"ap-southeast-1\" |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
@ -287,3 +290,4 @@ _get_token() { |
|
|
printf "%s" "${_token}" |
|
|
printf "%s" "${_token}" |
|
|
return 0 |
|
|
return 0 |
|
|
} |
|
|
} |
|
|
|
|
|
|