2017-06-27 15:21:39 +02:00
|
|
|
#!/usr/bin/env sh
|
|
|
|
|
|
|
|
#Created by RaidenII, to use DuckDNS's API to add/remove text records
|
|
|
|
#06/27/2017
|
|
|
|
|
2017-08-11 23:46:29 +02:00
|
|
|
# Pass credentials before "acme.sh --issue --dns dns_duckdns ..."
|
|
|
|
# --
|
|
|
|
# export DuckDNS_Token="aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee"
|
|
|
|
# --
|
|
|
|
#
|
|
|
|
# Due to the fact that DuckDNS uses StartSSL as cert provider, --insecure may need to be used with acme.sh
|
2017-06-27 15:21:39 +02:00
|
|
|
|
2017-06-27 21:28:10 +02:00
|
|
|
DuckDNS_API="https://www.duckdns.org/update"
|
2017-06-27 15:21:39 +02:00
|
|
|
|
2021-03-21 16:16:38 +01:00
|
|
|
######## Public functions #####################
|
2017-06-27 15:21:39 +02:00
|
|
|
|
|
|
|
#Usage: dns_duckdns_add _acme-challenge.domain.duckdns.org "XKrxpRBosdIKFzxW_CT3KLZNf6q0HG9i01zxXp5CPBs"
|
|
|
|
dns_duckdns_add() {
|
|
|
|
fulldomain=$1
|
|
|
|
txtvalue=$2
|
|
|
|
|
2017-08-11 23:46:29 +02:00
|
|
|
DuckDNS_Token="${DuckDNS_Token:-$(_readaccountconf_mutable DuckDNS_Token)}"
|
2017-07-01 14:14:52 +02:00
|
|
|
if [ -z "$DuckDNS_Token" ]; then
|
2017-08-11 23:46:29 +02:00
|
|
|
_err "You must export variable: DuckDNS_Token"
|
2017-06-27 15:21:39 +02:00
|
|
|
_err "The token for your DuckDNS account is necessary."
|
|
|
|
_err "You can look it up in your DuckDNS account."
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Now save the credentials.
|
2017-08-11 23:46:29 +02:00
|
|
|
_saveaccountconf_mutable DuckDNS_Token "$DuckDNS_Token"
|
2017-06-27 15:21:39 +02:00
|
|
|
|
|
|
|
# Unfortunately, DuckDNS does not seems to support lookup domain through API
|
|
|
|
# So I assume your credentials (which are your domain and token) are correct
|
|
|
|
# If something goes wrong, we will get a KO response from DuckDNS
|
|
|
|
|
2017-08-11 23:46:29 +02:00
|
|
|
if ! _duckdns_get_domain; then
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
2017-06-27 15:21:39 +02:00
|
|
|
# Now add the TXT record to DuckDNS
|
|
|
|
_info "Trying to add TXT record"
|
2017-08-11 23:46:29 +02:00
|
|
|
if _duckdns_rest GET "domains=$_duckdns_domain&token=$DuckDNS_Token&txt=$txtvalue"; then
|
|
|
|
if [ "$response" = "OK" ]; then
|
|
|
|
_info "TXT record has been successfully added to your DuckDNS domain."
|
|
|
|
_info "Note that all subdomains under this domain uses the same TXT record."
|
|
|
|
return 0
|
|
|
|
else
|
|
|
|
_err "Errors happened during adding the TXT record, response=$response"
|
|
|
|
return 1
|
|
|
|
fi
|
2017-06-27 15:21:39 +02:00
|
|
|
else
|
|
|
|
_err "Errors happened during adding the TXT record."
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
#Usage: fulldomain txtvalue
|
|
|
|
#Remove the txt record after validation.
|
|
|
|
dns_duckdns_rm() {
|
|
|
|
fulldomain=$1
|
|
|
|
txtvalue=$2
|
|
|
|
|
2017-08-11 23:46:29 +02:00
|
|
|
DuckDNS_Token="${DuckDNS_Token:-$(_readaccountconf_mutable DuckDNS_Token)}"
|
|
|
|
if [ -z "$DuckDNS_Token" ]; then
|
|
|
|
_err "You must export variable: DuckDNS_Token"
|
|
|
|
_err "The token for your DuckDNS account is necessary."
|
|
|
|
_err "You can look it up in your DuckDNS account."
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if ! _duckdns_get_domain; then
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
2017-06-27 15:21:39 +02:00
|
|
|
# Now remove the TXT record from DuckDNS
|
2017-06-27 21:28:10 +02:00
|
|
|
_info "Trying to remove TXT record"
|
2017-08-11 23:46:29 +02:00
|
|
|
if _duckdns_rest GET "domains=$_duckdns_domain&token=$DuckDNS_Token&txt=&clear=true"; then
|
|
|
|
if [ "$response" = "OK" ]; then
|
|
|
|
_info "TXT record has been successfully removed from your DuckDNS domain."
|
|
|
|
return 0
|
|
|
|
else
|
|
|
|
_err "Errors happened during removing the TXT record, response=$response"
|
|
|
|
return 1
|
|
|
|
fi
|
2017-06-27 15:21:39 +02:00
|
|
|
else
|
|
|
|
_err "Errors happened during removing the TXT record."
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
#################### Private functions below ##################################
|
|
|
|
|
2020-06-30 13:19:41 +02:00
|
|
|
# fulldomain may be 'domain.duckdns.org' (if using --domain-alias) or '_acme-challenge.domain.duckdns.org'
|
|
|
|
# either way, return 'domain'. (duckdns does not allow further subdomains and restricts domains to [a-z0-9-].)
|
2017-08-11 23:46:29 +02:00
|
|
|
_duckdns_get_domain() {
|
|
|
|
|
|
|
|
# We'll extract the domain/username from full domain
|
2020-12-16 11:11:43 +01:00
|
|
|
_duckdns_domain="$(printf "%s" "$fulldomain" | _lower_case | _egrep_o '^(_acme-challenge\.)?([a-z0-9-]+\.)+duckdns\.org' | sed -n 's/^\([^.]\{1,\}\.\)*\([a-z0-9-]\{1,\}\)\.duckdns\.org$/\2/p;')"
|
2017-08-11 23:46:29 +02:00
|
|
|
|
|
|
|
if [ -z "$_duckdns_domain" ]; then
|
|
|
|
_err "Error extracting the domain."
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2017-06-27 21:28:10 +02:00
|
|
|
#Usage: method URI
|
2017-06-27 15:21:39 +02:00
|
|
|
_duckdns_rest() {
|
|
|
|
method=$1
|
|
|
|
param="$2"
|
|
|
|
_debug param "$param"
|
|
|
|
url="$DuckDNS_API?$param"
|
2021-03-21 16:16:38 +01:00
|
|
|
if [ "$DEBUG" -gt 0 ]; then
|
2020-09-14 16:22:36 +02:00
|
|
|
url="$url&verbose=true"
|
|
|
|
fi
|
2017-06-27 15:21:39 +02:00
|
|
|
_debug url "$url"
|
|
|
|
|
|
|
|
# DuckDNS uses GET to update domain info
|
2017-06-29 21:43:58 +02:00
|
|
|
if [ "$method" = "GET" ]; then
|
2017-06-27 15:21:39 +02:00
|
|
|
response="$(_get "$url")"
|
2020-09-14 16:29:23 +02:00
|
|
|
_debug2 response "$response"
|
2021-03-21 16:16:38 +01:00
|
|
|
if [ "$DEBUG" -gt 0 ] && _contains "$response" "UPDATED" && _contains "$response" "OK"; then
|
2020-09-14 16:29:23 +02:00
|
|
|
response="OK"
|
|
|
|
fi
|
2017-06-27 15:21:39 +02:00
|
|
|
else
|
|
|
|
_err "Unsupported method"
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
return 0
|
|
|
|
}
|