Browse Source
Implementation DNS-01 _acme-challenge plugin dns_ukraine.sh (ukraine.com.ua)
pull/4943/head
Implementation DNS-01 _acme-challenge plugin dns_ukraine.sh (ukraine.com.ua)
pull/4943/head
Stanislav Butsenko
1 year ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 116 additions and 0 deletions
@ -0,0 +1,116 @@ |
|||||
|
#!/usr/bin/env bash |
||||
|
|
||||
|
## DNS-01 challenge plugin for ACME & ukraine.com.ua DNS hosting. |
||||
|
|
||||
|
## How to usage: |
||||
|
## 1. Create the API token: https://adm.tools/user/api/ |
||||
|
## 2. export DNS_UKRAINE_API_KEY="..." |
||||
|
## 3. acme.sh --issue -d your.domain.com.ua --dns dns_ukraine --server letsencrypt --dnssleep 180 |
||||
|
|
||||
|
## Author: QipDev <dev@qip.cx> |
||||
|
## Report Bugs: https://github.com/sorbing/acme.sh |
||||
|
## Development DNS API plugin for acme.sh: https://github.com/acmesh-official/acme.sh/wiki/DNS-API-Dev-Guide |
||||
|
|
||||
|
## Debug API: |
||||
|
## curl -X POST -H "Authorization: Bearer $DNS_UKRAINE_API_KEY" https://adm.tools/action/dns/list/ |
||||
|
## curl -X POST -H "Authorization: Bearer $DNS_UKRAINE_API_KEY" -H "Content-Type: application/json" --data "{\"domain_id\":000000}" https://adm.tools/action/dns/records_list/ |
||||
|
|
||||
|
|
||||
|
######## Public functions ##################### |
||||
|
|
||||
|
## Add the TXT record `_acme-challenge.your.domain` for validation. |
||||
|
## Ukraine DNS API Documentation: |
||||
|
## - https://adm.tools/user/api/#/tab-sandbox/dns/list |
||||
|
## - https://adm.tools/user/api/#/tab-sandbox/dns/record_add |
||||
|
dns_ukraine_add() { |
||||
|
fulldomain=$1 |
||||
|
txtvalue=$2 |
||||
|
|
||||
|
_info "Using dns_ukraine.sh" |
||||
|
_debug fulldomain "$fulldomain" ## fulldomain='_acme-challenge.your.domain.com.ua' |
||||
|
_debug txtvalue "$txtvalue" ## txtvalue='XxXxXxXxX' |
||||
|
|
||||
|
## Save the credentials to the account conf file |
||||
|
DNS_UKRAINE_API_KEY="${DNS_UKRAINE_API_KEY:-$(_readaccountconf_mutable DNS_UKRAINE_API_KEY)}" |
||||
|
if [ -z "$DNS_UKRAINE_API_KEY" ]; then |
||||
|
DNS_UKRAINE_API_KEY="" |
||||
|
_err "You don't specify env variable DNS_UKRAINE_API_KEY." |
||||
|
_err 'Please create your api key and export DNS_UKRAINE_API_KEY="...".' |
||||
|
return 1 |
||||
|
fi |
||||
|
_saveaccountconf_mutable DNS_UKRAINE_API_KEY "$DNS_UKRAINE_API_KEY" |
||||
|
|
||||
|
## Get domain_id |
||||
|
__dns_ukraine_get_domain_id "$fulldomain" |
||||
|
_debug ukraine_domain_id "$DOMAIN_ID" |
||||
|
|
||||
|
if test -z "$DOMAIN_ID"; then |
||||
|
_err "Failed to add the TXT record $fulldomain" |
||||
|
return 1 |
||||
|
fi |
||||
|
|
||||
|
data="{\"domain_id\":\"$DOMAIN_ID\",\"type\":\"TXT\",\"record\":\"$ACME_CHALLENGE_RECORD\",\"data\":\"$txtvalue\"}" |
||||
|
response="$(_post "$data" "https://adm.tools/action/dns/record_add/" "" "POST")" |
||||
|
_debug response "$response" |
||||
|
} |
||||
|
|
||||
|
## Remove the TXT record after validation. |
||||
|
## Ukraine DNS API Documentation: |
||||
|
## - https://adm.tools/user/api/#/tab-sandbox/dns/records_list |
||||
|
## - https://adm.tools/user/api/#/tab-sandbox/dns/record_delete |
||||
|
dns_ukraine_rm() { |
||||
|
fulldomain=$1 |
||||
|
txtvalue=$2 |
||||
|
_info "Using dns_ukraine.sh" |
||||
|
_debug fulldomain "$fulldomain" |
||||
|
_debug txtvalue "$txtvalue" |
||||
|
|
||||
|
## Get domain_id |
||||
|
__dns_ukraine_get_domain_id "$fulldomain" |
||||
|
_debug ukraine_domain_id "$DOMAIN_ID" |
||||
|
|
||||
|
response="$(_post "{\"domain_id\":\"$DOMAIN_ID\"}" "https://adm.tools/action/dns/records_list/" "" "POST")" |
||||
|
subdomain_id=$(echo "$response" | grep -Po '(?<="id":")\d+(?=","domain_id":"[0-9]+","record":"'$ACME_CHALLENGE_RECORD'")') |
||||
|
|
||||
|
if test -z "$subdomain_id"; then |
||||
|
_err "Failed getting subdomain_id from API ukraine.com.ua to delete the dns record: $ACME_CHALLENGE_RECORD" |
||||
|
return 1 |
||||
|
fi |
||||
|
|
||||
|
response="$(_post "{\"subdomain_id\":\"$subdomain_id\"}" "https://adm.tools/action/dns/record_delete/" "" "POST")" |
||||
|
_debug response "$response" |
||||
|
} |
||||
|
|
||||
|
|
||||
|
#################### Private functions below ################################## |
||||
|
|
||||
|
__dns_ukraine_get_domain_id() { |
||||
|
fulldomain=$1 |
||||
|
|
||||
|
export _H1="Authorization: Bearer $DNS_UKRAINE_API_KEY" |
||||
|
export _H2="Accept: application/json" |
||||
|
export _H3="Content-Type: application/json" |
||||
|
|
||||
|
local response="$(_post "" "https://adm.tools/action/dns/list/" "" "POST" "application/json")" |
||||
|
|
||||
|
local subdomain=$(echo "$fulldomain" | sed -E 's/^_acme-challenge\.//') |
||||
|
local topdomain=$subdomain |
||||
|
|
||||
|
DOMAIN_ID=$(echo "$response" | grep -Po '(?<="'$topdomain'":{"domain_id":)\d+') |
||||
|
if test -z "$DOMAIN_ID"; then |
||||
|
topdomain=$(echo "$topdomain" | sed -E 's/^[^\.]+\.//') |
||||
|
DOMAIN_ID=$(echo "$response" | grep -Po '(?<="'$topdomain'":{"domain_id":)\d+') |
||||
|
|
||||
|
if test -z "$DOMAIN_ID"; then |
||||
|
topdomain=$(echo "$topdomain" | sed -E 's/^[^\.]+\.//') |
||||
|
DOMAIN_ID=$(echo "$response" | grep -Po '(?<="'$topdomain'":{"domain_id":)\d+') |
||||
|
fi |
||||
|
fi |
||||
|
|
||||
|
if test -z "$DOMAIN_ID"; then |
||||
|
_err "Failed getting domain_id from API ukraine.com.ua" |
||||
|
return 1 |
||||
|
fi |
||||
|
|
||||
|
ACME_CHALLENGE_RECORD=$(echo "$fulldomain" | sed -E "s/\.$topdomain$//") ## _acme-challenge.subdomain |
||||
|
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue