acme.sh/dnsapi/dns_nm.sh

113 lines
3.0 KiB
Bash
Raw Normal View History

2020-03-07 13:55:09 +00:00
#!/usr/bin/env sh
########################################################################
# https://namemaster.de hook script for acme.sh
#
# Environment variables:
#
# - $NM_user (your namemaster.de API username)
# - $NM_sha256 (your namemaster.de API password_as_sha256hash)
2020-03-07 13:55:09 +00:00
#
# Author: Thilo Gass <thilo.gass@gmail.com>
# Git repo: https://github.com/ThiloGa/acme.sh
#-- dns_nm_add() - Add TXT record --------------------------------------
# Usage: dns_nm_add _acme-challenge.subdomain.domain.com "XyZ123..."
namemaster_api="https://namemaster.de/api/api.php"
2020-03-07 13:55:09 +00:00
dns_nm_add() {
fulldomain=$1
txt_value=$2
_info "Using DNS-01 namemaster hook"
2020-03-07 13:55:09 +00:00
NM_user="${NM_user:-$(_readaccountconf_mutable NM_user)}"
NM_sha256="${NM_sha256:-$(_readaccountconf_mutable NM_sha256)}"
if [ -z "$NM_user" ] || [ -z "$NM_sha256" ]; then
2020-03-07 13:55:09 +00:00
NM_user=""
NM_sha256=""
_err "No auth details provided. Please set user credentials using the \$NM_user and \$NM_sha256 environment variables."
2020-03-07 13:55:09 +00:00
return 1
fi
#save the api user and sha256 password to the account conf file.
2020-03-07 13:55:09 +00:00
_debug "Save user and hash"
_saveaccountconf_mutable NM_user "$NM_user"
_saveaccountconf_mutable NM_sha256 "$NM_sha256"
_debug "First detect the root zone"
if ! _get_root "$fulldomain"; then
_err "invalid domain" "$fulldomain"
return 1
fi
_info "die Zone lautet:" "$zone"
get="$namemaster_api?User=$NM_user&Password=$NM_sha256&Antwort=csv&Typ=ACME&zone=$zone&hostname=$fulldomain&TXT=$txt_value&Action=Auto&Lifetime=3600"
2020-03-21 18:41:46 +00:00
if ! erg="$(_get "$get")"; then
_err "error Adding $fulldomain TXT: $txt_value"
return 1
2020-03-07 13:55:09 +00:00
fi
if _contains "$erg" "Success"; then
_info "Success, TXT Added, OK"
else
_err "error Adding $fulldomain TXT: $txt_value erg: $erg"
2020-03-07 13:55:09 +00:00
return 1
fi
_debug "ok Auto $fulldomain TXT: $txt_value erg: $erg"
2020-03-07 13:55:09 +00:00
return 0
}
dns_nm_rm() {
fulldomain=$1
txt_value=$2
2020-03-07 13:55:09 +00:00
NM_user="${NM_user:-$(_readaccountconf_mutable NM_user)}"
NM_sha256="${NM_sha256:-$(_readaccountconf_mutable NM_sha256)}"
if [ -z "$NM_user" ] || [ -z "$NM_sha256" ]; then
2020-03-07 13:55:09 +00:00
NM_user=""
NM_sha256=""
_err "No auth details provided. Please set user credentials using the \$NM_user and \$NM_sha256 environment variables."
2020-03-07 13:55:09 +00:00
return 1
fi
zone="$(echo "$fulldomain" | _egrep_o "[^.]+.[^.]+$")"
get="$namemaster_api?User=$NM_user&Password=$NM_sha256&Antwort=csv&Typ=TXT&Zone=$zone&hostname=$fulldomain&TXT=$txt_value&Action=Delete_IN"
2020-03-07 15:00:52 +00:00
2020-03-21 18:41:46 +00:00
if ! erg="$(_get "$get")"; then
_err "error Deleting $fulldomain TXT: $txt_value"
2020-03-07 13:55:09 +00:00
return 1
fi
if _contains "$erg" "Success"; then
_info "Success, TXT removed, OK"
else
_err "error Auto $fulldomain TXT: $txt_value erg: $erg"
return 1
fi
2020-03-07 13:55:09 +00:00
_debug "ok Auto $fulldomain TXT: $txt_value erg: $erg"
return 0
2020-03-07 13:55:09 +00:00
}
_get_root() {
domain=$1
get="$namemaster_api?User=$NM_user&Password=$NM_sha256&Typ=acme&hostname=$domain&Action=getzone&antwort=csv"
2020-03-21 18:41:46 +00:00
if ! zone="$(_get "$get")"; then
_err "error getting Zone"
return 1
else
2020-03-21 18:48:17 +00:00
if _contains "$zone" "hostname not found"; then
return 1
fi
fi
2020-03-21 18:41:46 +00:00
}