forked from Github/acme.sh
neil
5 years ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 260 additions and 5 deletions
-
13acme.sh
-
2dnsapi/dns_ali.sh
-
155dnsapi/dns_domeneshop.sh
-
3dnsapi/dns_linode_v4.sh
-
2dnsapi/dns_namesilo.sh
-
90notify/xmpp.sh
@ -0,0 +1,155 @@ |
|||
#!/usr/bin/env sh |
|||
|
|||
DOMENESHOP_Api_Endpoint="https://api.domeneshop.no/v0" |
|||
|
|||
##################### Public functions ##################### |
|||
|
|||
# Usage: dns_domeneshop_add <full domain> <txt record> |
|||
# Example: dns_domeneshop_add _acme-challenge.www.domain.com "XKrxpRBosdIKFzxW_CT3KLZNf6q0HG9i01zxXp5CPBs" |
|||
dns_domeneshop_add() { |
|||
fulldomain=$1 |
|||
txtvalue=$2 |
|||
|
|||
# Get token and secret |
|||
DOMENESHOP_Token="${DOMENESHOP_Token:-$(_readaccountconf_mutable DOMENESHOP_Token)}" |
|||
DOMENESHOP_Secret="${DOMENESHOP_Secret:-$(_readaccountconf_mutable DOMENESHOP_Secret)}" |
|||
|
|||
if [ -z "$DOMENESHOP_Token" ] || [ -z "$DOMENESHOP_Secret" ]; then |
|||
DOMENESHOP_Token="" |
|||
DOMENESHOP_Secret="" |
|||
_err "You need to spesify a Domeneshop/Domainnameshop API Token and Secret." |
|||
return 1 |
|||
fi |
|||
|
|||
# Save the api token and secret. |
|||
_saveaccountconf_mutable DOMENESHOP_Token "$DOMENESHOP_Token" |
|||
_saveaccountconf_mutable DOMENESHOP_Secret "$DOMENESHOP_Secret" |
|||
|
|||
# Get the domain name id |
|||
if ! _get_domainid "$fulldomain"; then |
|||
_err "Did not find domainname" |
|||
return 1 |
|||
fi |
|||
|
|||
# Create record |
|||
_domeneshop_rest POST "domains/$_domainid/dns" "{\"type\":\"TXT\",\"host\":\"$_sub_domain\",\"data\":\"$txtvalue\",\"ttl\":120}" |
|||
} |
|||
|
|||
# Usage: dns_domeneshop_rm <full domain> <txt record> |
|||
# Example: dns_domeneshop_rm _acme-challenge.www.domain.com "XKrxpRBosdIKFzxW_CT3KLZNf6q0HG9i01zxXp5CPBs" |
|||
dns_domeneshop_rm() { |
|||
fulldomain=$1 |
|||
txtvalue=$2 |
|||
|
|||
# Get token and secret |
|||
DOMENESHOP_Token="${DOMENESHOP_Token:-$(_readaccountconf_mutable DOMENESHOP_Token)}" |
|||
DOMENESHOP_Secret="${DOMENESHOP_Secret:-$(_readaccountconf_mutable DOMENESHOP_Secret)}" |
|||
|
|||
if [ -z "$DOMENESHOP_Token" ] || [ -z "$DOMENESHOP_Secret" ]; then |
|||
DOMENESHOP_Token="" |
|||
DOMENESHOP_Secret="" |
|||
_err "You need to spesify a Domeneshop/Domainnameshop API Token and Secret." |
|||
return 1 |
|||
fi |
|||
|
|||
# Get the domain name id |
|||
if ! _get_domainid "$fulldomain"; then |
|||
_err "Did not find domainname" |
|||
return 1 |
|||
fi |
|||
|
|||
# Find record |
|||
if ! _get_recordid "$_domainid" "$_sub_domain" "$txtvalue"; then |
|||
_err "Did not find dns record" |
|||
return 1 |
|||
fi |
|||
|
|||
# Remove record |
|||
_domeneshop_rest DELETE "domains/$_domainid/dns/$_recordid" |
|||
} |
|||
|
|||
##################### Private functions ##################### |
|||
|
|||
_get_domainid() { |
|||
domain=$1 |
|||
|
|||
# Get domains |
|||
_domeneshop_rest GET "domains" |
|||
|
|||
if ! _contains "$response" "\"id\":"; then |
|||
_err "failed to get domain names" |
|||
return 1 |
|||
fi |
|||
|
|||
i=2 |
|||
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" "\"$h\"" >/dev/null; then |
|||
# We have found the domain name. |
|||
_sub_domain=$(printf "%s" "$domain" | cut -d . -f 1-$p) |
|||
_domain=$h |
|||
_domainid=$(printf "%s" "$response" | _egrep_o "[^{]*\"domain\":\"$_domain\"[^}]*" | _egrep_o "\"id\":[0-9]+" | cut -d : -f 2) |
|||
return 0 |
|||
fi |
|||
p=$i |
|||
i=$(_math "$i" + 1) |
|||
done |
|||
return 1 |
|||
} |
|||
|
|||
_get_recordid() { |
|||
domainid=$1 |
|||
subdomain=$2 |
|||
txtvalue=$3 |
|||
|
|||
# Get all dns records for the domainname |
|||
_domeneshop_rest GET "domains/$domainid/dns" |
|||
|
|||
if ! _contains "$response" "\"id\":"; then |
|||
_debug "No records in dns" |
|||
return 1 |
|||
fi |
|||
|
|||
if ! _contains "$response" "\"host\":\"$subdomain\""; then |
|||
_debug "Record does not exist" |
|||
return 1 |
|||
fi |
|||
|
|||
# Get the id of the record in question |
|||
_recordid=$(printf "%s" "$response" | _egrep_o "[^{]*\"host\":\"$subdomain\"[^}]*" | _egrep_o "[^{]*\"data\":\"$txtvalue\"[^}]*" | _egrep_o "\"id\":[0-9]+" | cut -d : -f 2) |
|||
if [ -z "$_recordid" ]; then |
|||
return 1 |
|||
fi |
|||
return 0 |
|||
} |
|||
|
|||
_domeneshop_rest() { |
|||
method=$1 |
|||
endpoint=$2 |
|||
data=$3 |
|||
|
|||
credentials=$(printf "%b" "$DOMENESHOP_Token:$DOMENESHOP_Secret" | _base64) |
|||
|
|||
export _H1="Authorization: Basic $credentials" |
|||
export _H2="Content-Type: application/json" |
|||
|
|||
if [ "$method" != "GET" ]; then |
|||
response="$(_post "$data" "$DOMENESHOP_Api_Endpoint/$endpoint" "" "$method")" |
|||
else |
|||
response="$(_get "$DOMENESHOP_Api_Endpoint/$endpoint")" |
|||
fi |
|||
|
|||
if [ "$?" != "0" ]; then |
|||
_err "error $endpoint" |
|||
return 1 |
|||
fi |
|||
|
|||
return 0 |
|||
} |
@ -0,0 +1,90 @@ |
|||
#!/usr/bin/env sh |
|||
|
|||
#Support xmpp via sendxmpp |
|||
|
|||
#XMPP_BIN="/usr/bin/sendxmpp" |
|||
#XMPP_BIN_ARGS="-n -t --tls-ca-path=/etc/ssl/certs" |
|||
#XMPP_TO="zzzz@example.com" |
|||
|
|||
xmpp_send() { |
|||
_subject="$1" |
|||
_content="$2" |
|||
_statusCode="$3" #0: success, 1: error 2($RENEW_SKIP): skipped |
|||
_debug "_subject" "$_subject" |
|||
_debug "_content" "$_content" |
|||
_debug "_statusCode" "$_statusCode" |
|||
|
|||
XMPP_BIN="${XMPP_BIN:-$(_readaccountconf_mutable XMPP_BIN)}" |
|||
if [ -n "$XMPP_BIN" ] && ! _exists "$XMPP_BIN"; then |
|||
_err "It seems that the command $XMPP_BIN is not in path." |
|||
return 1 |
|||
fi |
|||
_XMPP_BIN=$(_xmpp_bin) |
|||
if [ -n "$XMPP_BIN" ]; then |
|||
_saveaccountconf_mutable XMPP_BIN "$XMPP_BIN" |
|||
else |
|||
_clearaccountconf "XMPP_BIN" |
|||
fi |
|||
|
|||
XMPP_BIN_ARGS="${XMPP_BIN_ARGS:-$(_readaccountconf_mutable XMPP_BIN_ARGS)}" |
|||
if [ -n "$XMPP_BIN_ARGS" ]; then |
|||
_saveaccountconf_mutable XMPP_BIN_ARGS "$XMPP_BIN_ARGS" |
|||
else |
|||
_clearaccountconf "XMPP_BIN_ARGS" |
|||
fi |
|||
|
|||
XMPP_TO="${XMPP_TO:-$(_readaccountconf_mutable XMPP_TO)}" |
|||
if [ -n "$XMPP_TO" ]; then |
|||
if ! _xmpp_valid "$XMPP_TO"; then |
|||
_err "It seems that the XMPP_TO=$XMPP_TO is not a valid xmpp address." |
|||
return 1 |
|||
fi |
|||
|
|||
_saveaccountconf_mutable XMPP_TO "$XMPP_TO" |
|||
fi |
|||
|
|||
result=$({ _xmpp_message | eval "$(_xmpp_cmnd)"; } 2>&1) |
|||
|
|||
# shellcheck disable=SC2181 |
|||
if [ $? -ne 0 ]; then |
|||
_debug "xmpp send error." |
|||
_err "$result" |
|||
return 1 |
|||
fi |
|||
|
|||
_debug "xmpp send success." |
|||
return 0 |
|||
} |
|||
|
|||
_xmpp_bin() { |
|||
if [ -n "$XMPP_BIN" ]; then |
|||
_XMPP_BIN="$XMPP_BIN" |
|||
elif _exists "sendxmpp"; then |
|||
_XMPP_BIN="sendxmpp" |
|||
else |
|||
_err "Please install sendxmpp first." |
|||
return 1 |
|||
fi |
|||
|
|||
echo "$_XMPP_BIN" |
|||
} |
|||
|
|||
_xmpp_cmnd() { |
|||
case $(basename "$_XMPP_BIN") in |
|||
sendxmpp) |
|||
echo "'$_XMPP_BIN' '$XMPP_TO' $XMPP_BIN_ARGS" |
|||
;; |
|||
*) |
|||
_err "Command $XMPP_BIN is not supported, use sendxmpp." |
|||
return 1 |
|||
;; |
|||
esac |
|||
} |
|||
|
|||
_xmpp_message() { |
|||
echo "$_subject" |
|||
} |
|||
|
|||
_xmpp_valid() { |
|||
_contains "$1" "@" |
|||
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue