Add ndns_netim
parent
c459b5eb9d
commit
62b7e97cbd
|
@ -0,0 +1,176 @@
|
||||||
|
#!/usr/bin/env sh
|
||||||
|
dns_netim_info='Netim.com
|
||||||
|
Site: netim.com
|
||||||
|
Docs: github.com/acmesh-official/acme.sh/wiki/dnsapi2#dns_netim
|
||||||
|
Options:
|
||||||
|
NETIM_USER Netim reseller UserID
|
||||||
|
NETIM_SECRET Password
|
||||||
|
Issues: github.com/acmesh-official/acme.sh/issues/6273
|
||||||
|
Author: Fabio Bas <ctrlaltca@gmail.com>
|
||||||
|
'
|
||||||
|
|
||||||
|
NETIM_SOAP_URL="https://api.netim.com/2.0/"
|
||||||
|
NETIM_SESSION=""
|
||||||
|
|
||||||
|
######## Public functions #####################
|
||||||
|
|
||||||
|
# Usage: add _acme-challenge.www.domain.com "XKrxpRBosdIKFzxW_CT3KLZNf6q0HG9i01zxXp5CPBs"
|
||||||
|
# Used to add txt record
|
||||||
|
dns_netim_add() {
|
||||||
|
fulldomain=$1
|
||||||
|
txtvalue=$2
|
||||||
|
|
||||||
|
NETIM_USER="${NETIM_USER:-$(_readaccountconf_mutable NETIM_USER)}"
|
||||||
|
NETIM_SECRET="${NETIM_SECRET:-$(_readaccountconf_mutable NETIM_SECRET)}"
|
||||||
|
if [ -z "$NETIM_USER" ] || [ -z "$NETIM_SECRET" ]; then
|
||||||
|
NETIM_USER=""
|
||||||
|
NETIM_SECRET=""
|
||||||
|
_err "You don't specify Netim username and secret yet."
|
||||||
|
_err "Please create your key and try again."
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
#save the credentials to the account conf file.
|
||||||
|
_saveaccountconf_mutable NETIM_USER "$NETIM_USER"
|
||||||
|
_saveaccountconf_mutable NETIM_SECRET "$NETIM_SECRET"
|
||||||
|
|
||||||
|
if _dns_netim_session_open; then
|
||||||
|
_info "Adding TXT record to ${_domain} as ${fulldomain}"
|
||||||
|
|
||||||
|
_debug "First detect the root zone"
|
||||||
|
if ! _get_root "$fulldomain"; then
|
||||||
|
_err "invalid domain"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
_debug _subdomain "$_subdomain"
|
||||||
|
_debug _domain "$_domain"
|
||||||
|
|
||||||
|
_dns_netim_soap Services domainZoneCreate IDSession "${NETIM_SESSION}" domain "${_domain}" subdomain "${_subdomain}" type TXT value "${txtvalue}"
|
||||||
|
if _contains "${response}" '>Done</STATUS'; then
|
||||||
|
_dns_netim_session_close
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
_dns_netim_session_close
|
||||||
|
_err "Could not create resource record, check logs"
|
||||||
|
fi
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# Usage: fulldomain txtvalue
|
||||||
|
# Used to remove the txt record after validation
|
||||||
|
dns_netim_rm() {
|
||||||
|
fulldomain=$1
|
||||||
|
txtvalue=$2
|
||||||
|
|
||||||
|
if _dns_netim_session_open; then
|
||||||
|
_info "Deleting TXT record to ${_domain} as ${fulldomain}"
|
||||||
|
|
||||||
|
_debug "First detect the root zone"
|
||||||
|
if ! _get_root "$fulldomain"; then
|
||||||
|
_err "invalid domain"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
_debug _subdomain "$_subdomain"
|
||||||
|
_debug _domain "$_domain"
|
||||||
|
|
||||||
|
_dns_netim_soap Services domainZoneDelete IDSession "${NETIM_SESSION}" domain "${_domain}" subdomain "${_subdomain}" type TXT value "${txtvalue}"
|
||||||
|
if _contains "${response}" '>Done</STATUS'; then
|
||||||
|
_dns_netim_session_close
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
_dns_netim_session_close
|
||||||
|
_err "Could not delete record, check logs"
|
||||||
|
fi
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
#################### Private functions below ##################################
|
||||||
|
_dns_netim_session_open() {
|
||||||
|
_info "Authenticating as ${NETIM_USER}"
|
||||||
|
_dns_netim_soap DRS sessionOpen idReseller "${NETIM_USER}" password "${NETIM_SECRET}" language "EN"
|
||||||
|
NETIM_SESSION=$(echo "$response" |
|
||||||
|
_egrep_o "<IDSession.*>[0-9a-f]{32}</IDSession" |
|
||||||
|
_egrep_o ">[0-9a-f]{32}<" |
|
||||||
|
tr -d '><')
|
||||||
|
_debug "NETIM_SESSION $NETIM_SESSION"
|
||||||
|
if [ -z "$NETIM_SESSION" ]; then
|
||||||
|
_err "Authentication failed, are NETIM_USER and NETIM_SECRET set correctly?"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
_dns_netim_session_close() {
|
||||||
|
_info "Closing session"
|
||||||
|
_dns_netim_soap DRS sessionClose idSession "${NETIM_SESSION}"
|
||||||
|
if _contains "${response}" 'sessionCloseResponse'; then
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
_err "Authentication failed, are NETIM_USER and NETIM_SECRET set correctly?"
|
||||||
|
fi
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
_dns_netim_soap() {
|
||||||
|
ns="$1"
|
||||||
|
shift
|
||||||
|
func="$1"
|
||||||
|
shift
|
||||||
|
# put the parameters to xml
|
||||||
|
body="<ns1:${func}>"
|
||||||
|
while [ "$1" ]; do
|
||||||
|
_k="$1"
|
||||||
|
shift
|
||||||
|
_v="$1"
|
||||||
|
shift
|
||||||
|
body="$body<$_k xsi:type=\"xsd:string\">$_v</$_k>"
|
||||||
|
done
|
||||||
|
body="$body</ns1:${func}>"
|
||||||
|
_debug2 "SOAP request ${body}"
|
||||||
|
|
||||||
|
# build SOAP XML
|
||||||
|
_xml='<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ns1="urn:'"${ns}"'" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:SOAP-ENC="http://schemas.xmlsoap.org/soap/encoding/" SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
|
||||||
|
<SOAP-ENV:Body>'"$body"'</SOAP-ENV:Body>
|
||||||
|
</SOAP-ENV:Envelope>'
|
||||||
|
|
||||||
|
# set SOAP headers
|
||||||
|
export _H1="SOAPAction: ${NETIM_SOAP_URL}#${func}"
|
||||||
|
|
||||||
|
if ! response="$(_post "${_xml}" "${NETIM_SOAP_URL}")"; then
|
||||||
|
_err "Error <$1>"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
_debug2 "SOAP response $response"
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
_get_root() {
|
||||||
|
domain=$1
|
||||||
|
filter=$(printf "%s" "$domain" | rev | cut -d . -f 1-2 | rev)
|
||||||
|
if ! _dns_netim_soap Services queryDomainList IDSession "${NETIM_SESSION}" filter "${filter}"; then
|
||||||
|
_debug "Cant query domain list"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
i=1
|
||||||
|
p=1
|
||||||
|
while true; do
|
||||||
|
h=$(printf "%s" "$domain" | cut -d . -f $i-100)
|
||||||
|
_debug h "$h"
|
||||||
|
if [ -z "$h" ]; then
|
||||||
|
#not valid
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if _contains "$response" "<domain xsi:type=\"xsd:string\">$h</domain>"; then
|
||||||
|
_subdomain=$(printf "%s" "$domain" | cut -d . -f 1-$p)
|
||||||
|
_domain=$h
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
p=$i
|
||||||
|
i=$(_math "$i" + 1)
|
||||||
|
done
|
||||||
|
_debug "$domain not found"
|
||||||
|
return 1
|
||||||
|
}
|
Loading…
Reference in New Issue