diff --git a/dnsapi/dns_dyn.sh b/dnsapi/dns_dyn.sh deleted file mode 100644 index 024e0a38..00000000 --- a/dnsapi/dns_dyn.sh +++ /dev/null @@ -1,339 +0,0 @@ -#!/usr/bin/env sh -# -# Dyn.com Domain API -# -# Author: Gerd Naschenweng -# https://github.com/magicdude4eva -# -# Dyn Managed DNS API -# https://help.dyn.com/dns-api-knowledge-base/ -# -# It is recommended to add a "Dyn Managed DNS" user specific for API access. -# The "Zones & Records Permissions" required by this script are: -# -- -# RecordAdd -# RecordUpdate -# RecordDelete -# RecordGet -# ZoneGet -# ZoneAddNode -# ZoneRemoveNode -# ZonePublish -# -- -# -# Pass credentials before "acme.sh --issue --dns dns_dyn ..." -# -- -# export DYN_Customer="customer" -# export DYN_Username="apiuser" -# export DYN_Password="secret" -# -- - -DYN_API="https://api.dynect.net/REST" - -#REST_API -######## Public functions ##################### - -#Usage: add _acme-challenge.www.domain.com "Challenge-code" -dns_dyn_add() { - fulldomain="$1" - txtvalue="$2" - - DYN_Customer="${DYN_Customer:-$(_readaccountconf_mutable DYN_Customer)}" - DYN_Username="${DYN_Username:-$(_readaccountconf_mutable DYN_Username)}" - DYN_Password="${DYN_Password:-$(_readaccountconf_mutable DYN_Password)}" - if [ -z "$DYN_Customer" ] || [ -z "$DYN_Username" ] || [ -z "$DYN_Password" ]; then - DYN_Customer="" - DYN_Username="" - DYN_Password="" - _err "You must export variables: DYN_Customer, DYN_Username and DYN_Password" - return 1 - fi - - #save the config variables to the account conf file. - _saveaccountconf_mutable DYN_Customer "$DYN_Customer" - _saveaccountconf_mutable DYN_Username "$DYN_Username" - _saveaccountconf_mutable DYN_Password "$DYN_Password" - - if ! _dyn_get_authtoken; then - return 1 - fi - - if [ -z "$_dyn_authtoken" ]; then - _dyn_end_session - return 1 - fi - - if ! _dyn_get_zone; then - _dyn_end_session - return 1 - fi - - if ! _dyn_add_record; then - _dyn_end_session - return 1 - fi - - if ! _dyn_publish_zone; then - _dyn_end_session - return 1 - fi - - _dyn_end_session - - return 0 -} - -#Usage: fulldomain txtvalue -#Remove the txt record after validation. -dns_dyn_rm() { - fulldomain="$1" - txtvalue="$2" - - DYN_Customer="${DYN_Customer:-$(_readaccountconf_mutable DYN_Customer)}" - DYN_Username="${DYN_Username:-$(_readaccountconf_mutable DYN_Username)}" - DYN_Password="${DYN_Password:-$(_readaccountconf_mutable DYN_Password)}" - if [ -z "$DYN_Customer" ] || [ -z "$DYN_Username" ] || [ -z "$DYN_Password" ]; then - DYN_Customer="" - DYN_Username="" - DYN_Password="" - _err "You must export variables: DYN_Customer, DYN_Username and DYN_Password" - return 1 - fi - - if ! _dyn_get_authtoken; then - return 1 - fi - - if [ -z "$_dyn_authtoken" ]; then - _dyn_end_session - return 1 - fi - - if ! _dyn_get_zone; then - _dyn_end_session - return 1 - fi - - if ! _dyn_get_record_id; then - _dyn_end_session - return 1 - fi - - if [ -z "$_dyn_record_id" ]; then - _dyn_end_session - return 1 - fi - - if ! _dyn_rm_record; then - _dyn_end_session - return 1 - fi - - if ! _dyn_publish_zone; then - _dyn_end_session - return 1 - fi - - _dyn_end_session - - return 0 -} - -#################### Private functions below ################################## - -#get Auth-Token -_dyn_get_authtoken() { - - _info "Start Dyn API Session" - - data="{\"customer_name\":\"$DYN_Customer\", \"user_name\":\"$DYN_Username\", \"password\":\"$DYN_Password\"}" - dyn_url="$DYN_API/Session/" - method="POST" - - _debug data "$data" - _debug dyn_url "$dyn_url" - - export _H1="Content-Type: application/json" - - response="$(_post "$data" "$dyn_url" "" "$method")" - sessionstatus="$(printf "%s\n" "$response" | _egrep_o '"status" *: *"[^"]*' | _head_n 1 | sed 's#^"status" *: *"##')" - - _debug response "$response" - _debug sessionstatus "$sessionstatus" - - if [ "$sessionstatus" = "success" ]; then - _dyn_authtoken="$(printf "%s\n" "$response" | _egrep_o '"token" *: *"[^"]*' | _head_n 1 | sed 's#^"token" *: *"##')" - _info "Token received" - _debug _dyn_authtoken "$_dyn_authtoken" - return 0 - fi - - _dyn_authtoken="" - _err "get token failed" - return 1 -} - -#fulldomain=_acme-challenge.www.domain.com -#returns -# _dyn_zone=domain.com -_dyn_get_zone() { - i=2 - while true; do - domain="$(printf "%s" "$fulldomain" | cut -d . -f "$i-100")" - if [ -z "$domain" ]; then - break - fi - - dyn_url="$DYN_API/Zone/$domain/" - - export _H1="Auth-Token: $_dyn_authtoken" - export _H2="Content-Type: application/json" - - response="$(_get "$dyn_url" "" "")" - sessionstatus="$(printf "%s\n" "$response" | _egrep_o '"status" *: *"[^"]*' | _head_n 1 | sed 's#^"status" *: *"##')" - - _debug dyn_url "$dyn_url" - _debug response "$response" - _debug sessionstatus "$sessionstatus" - - if [ "$sessionstatus" = "success" ]; then - _dyn_zone="$domain" - return 0 - fi - i=$(_math "$i" + 1) - done - - _dyn_zone="" - _err "get zone failed" - return 1 -} - -#add TXT record -_dyn_add_record() { - - _info "Adding TXT record" - - data="{\"rdata\":{\"txtdata\":\"$txtvalue\"},\"ttl\":\"300\"}" - dyn_url="$DYN_API/TXTRecord/$_dyn_zone/$fulldomain/" - method="POST" - - export _H1="Auth-Token: $_dyn_authtoken" - export _H2="Content-Type: application/json" - - response="$(_post "$data" "$dyn_url" "" "$method")" - sessionstatus="$(printf "%s\n" "$response" | _egrep_o '"status" *: *"[^"]*' | _head_n 1 | sed 's#^"status" *: *"##')" - - _debug response "$response" - _debug sessionstatus "$sessionstatus" - - if [ "$sessionstatus" = "success" ]; then - _info "TXT Record successfully added" - return 0 - fi - - _err "add TXT record failed" - return 1 -} - -#publish the zone -_dyn_publish_zone() { - - _info "Publishing zone" - - data="{\"publish\":\"true\"}" - dyn_url="$DYN_API/Zone/$_dyn_zone/" - method="PUT" - - export _H1="Auth-Token: $_dyn_authtoken" - export _H2="Content-Type: application/json" - - response="$(_post "$data" "$dyn_url" "" "$method")" - sessionstatus="$(printf "%s\n" "$response" | _egrep_o '"status" *: *"[^"]*' | _head_n 1 | sed 's#^"status" *: *"##')" - - _debug response "$response" - _debug sessionstatus "$sessionstatus" - - if [ "$sessionstatus" = "success" ]; then - _info "Zone published" - return 0 - fi - - _err "publish zone failed" - return 1 -} - -#get record_id of TXT record so we can delete the record -_dyn_get_record_id() { - - _info "Getting record_id of TXT record" - - dyn_url="$DYN_API/TXTRecord/$_dyn_zone/$fulldomain/" - - export _H1="Auth-Token: $_dyn_authtoken" - export _H2="Content-Type: application/json" - - response="$(_get "$dyn_url" "" "")" - sessionstatus="$(printf "%s\n" "$response" | _egrep_o '"status" *: *"[^"]*' | _head_n 1 | sed 's#^"status" *: *"##')" - - _debug response "$response" - _debug sessionstatus "$sessionstatus" - - if [ "$sessionstatus" = "success" ]; then - _dyn_record_id="$(printf "%s\n" "$response" | _egrep_o "\"data\" *: *\[\"/REST/TXTRecord/$_dyn_zone/$fulldomain/[^\"]*" | _head_n 1 | sed "s#^\"data\" *: *\[\"/REST/TXTRecord/$_dyn_zone/$fulldomain/##")" - _debug _dyn_record_id "$_dyn_record_id" - return 0 - fi - - _dyn_record_id="" - _err "getting record_id failed" - return 1 -} - -#delete TXT record -_dyn_rm_record() { - - _info "Deleting TXT record" - - dyn_url="$DYN_API/TXTRecord/$_dyn_zone/$fulldomain/$_dyn_record_id/" - method="DELETE" - - _debug dyn_url "$dyn_url" - - export _H1="Auth-Token: $_dyn_authtoken" - export _H2="Content-Type: application/json" - - response="$(_post "" "$dyn_url" "" "$method")" - sessionstatus="$(printf "%s\n" "$response" | _egrep_o '"status" *: *"[^"]*' | _head_n 1 | sed 's#^"status" *: *"##')" - - _debug response "$response" - _debug sessionstatus "$sessionstatus" - - if [ "$sessionstatus" = "success" ]; then - _info "TXT record successfully deleted" - return 0 - fi - - _err "delete TXT record failed" - return 1 -} - -#logout -_dyn_end_session() { - - _info "End Dyn API Session" - - dyn_url="$DYN_API/Session/" - method="DELETE" - - _debug dyn_url "$dyn_url" - - export _H1="Auth-Token: $_dyn_authtoken" - export _H2="Content-Type: application/json" - - response="$(_post "" "$dyn_url" "" "$method")" - - _debug response "$response" - - _dyn_authtoken="" - return 0 -}