# Last Edit: 17.02.2022
dns_selfhost_add() {
- domain=$1
+ fulldomain=$1
txt=$2
_info "Calling acme-dns on selfhost"
- _debug fulldomain "$domain"
+ _debug fulldomain "$fulldomain"
_debug txtvalue "$txt"
SELFHOSTDNS_UPDATE_URL="https://selfhost.de/cgi-bin/api.pl"
+
+ # Get values, but don't save until we successfully validated
SELFHOSTDNS_USERNAME="${SELFHOSTDNS_USERNAME:-$(_readaccountconf_mutable SELFHOSTDNS_USERNAME)}"
SELFHOSTDNS_PASSWORD="${SELFHOSTDNS_PASSWORD:-$(_readaccountconf_mutable SELFHOSTDNS_PASSWORD)}"
- SELFHOSTDNS_MAP="${SELFHOSTDNS_MAP:-$(_readaccountconf_mutable SELFHOSTDNS_MAP)}"
- SELFHOSTDNS_RID="${SELFHOSTDNS_RID:-$(_readaccountconf_mutable SELFHOSTDNS_RID)}"
- SELFHOSTDNS_RID2="${SELFHOSTDNS_RID2:-$(_readaccountconf_mutable SELFHOSTDNS_RID2)}"
- SELFHOSTDNS_LAST_SLOT="$(_readaccountconf_mutable SELFHOSTDNS_LAST_SLOT)"
+ # These values are domain dependent, so read them from there
+ SELFHOSTDNS_MAP="${SELFHOSTDNS_MAP:-$(_readdomainconf SELFHOSTDNS_MAP)}"
+ # Selfhost api can't dynamically add TXT record,
+ # so we have to store the last used RID of the domain to support a second RID for wildcard domains
+ # (format: 'fulldomainA:lastRid fulldomainB:lastRid ...')
+ SELFHOSTDNS_MAP_LAST_USED_INTERNAL=$(_readdomainconf SELFHOSTDNS_MAP_LAST_USED_INTERNAL)
- if test -z "$SELFHOSTDNS_LAST_SLOT"; then
- SELFHOSTDNS_LAST_SLOT=1
+ if [ -z "${SELFHOSTDNS_USERNAME:-}" ] || [ -z "${SELFHOSTDNS_PASSWORD:-}" ]; then
+ _err "SELFHOSTDNS_USERNAME and SELFHOSTDNS_PASSWORD must be set"
+ return 1
fi
- _saveaccountconf_mutable SELFHOSTDNS_USERNAME "$SELFHOSTDNS_USERNAME"
- _saveaccountconf_mutable SELFHOSTDNS_PASSWORD "$SELFHOSTDNS_PASSWORD"
- _saveaccountconf_mutable SELFHOSTDNS_MAP "$SELFHOSTDNS_MAP"
- _saveaccountconf_mutable SELFHOSTDNS_RID "$SELFHOSTDNS_RID"
- _saveaccountconf_mutable SELFHOSTDNS_RID2 "$SELFHOSTDNS_RID2"
+ # get the domain entry from SELFHOSTDNS_MAP
+ # only match full domains (at the beginning of the string or with a leading whitespace),
+ # e.g. don't match mytest.example.com or sub.test.example.com for test.example.com
+ # if the domain is defined multiple times only the last occurance will be matched
+ mapEntry=$(echo "$SELFHOSTDNS_MAP" | sed -n -E "s/(^|^.*[[:space:]])($fulldomain)(:[[:digit:]]+)([:]?[[:digit:]]*)(.*)/\2\3\4/p")
+ _debug2 mapEntry "$mapEntry"
+ if test -z "$mapEntry"; then
+ _err "SELFHOSTDNS_MAP must contain the fulldomain incl. prefix and at least one RID"
+ return 1
+ fi
- rid=$(echo "$SELFHOSTDNS_MAP" | grep -Eoi "$domain:(\d+)" | tr -d "$domain:")
+ # get the RIDs from the map entry
+ rid1=$(echo "$mapEntry" | cut -d: -f2)
+ rid2=$(echo "$mapEntry" | cut -d: -f3)
- if test -z "$rid"; then
- if [ $SELFHOSTDNS_LAST_SLOT = "2" ]; then
- rid=$SELFHOSTDNS_RID
- SELFHOSTDNS_LAST_SLOT=1
- else
- rid=$SELFHOSTDNS_RID2
- SELFHOSTDNS_LAST_SLOT=2
- fi
- fi
+ # read last used rid domain
+ lastUsedRidForDomainEntry=$(echo "$SELFHOSTDNS_MAP_LAST_USED_INTERNAL" | sed -n -E "s/(^|^.*[[:space:]])($fulldomain:[[:digit:]]+)(.*)/\2/p")
+ _debug2 lastUsedRidForDomainEntry "$lastUsedRidForDomainEntry"
+ lastUsedRidForDomain=$(echo "$lastUsedRidForDomainEntry" | cut -d: -f2)
- _saveaccountconf_mutable SELFHOSTDNS_LAST_SLOT "$SELFHOSTDNS_LAST_SLOT"
+ rid="$rid1"
+ if [ "$lastUsedRidForDomain" = "$rid" ] && ! test -z "$rid2"; then
+ rid="$rid2"
+ fi
_info "Trying to add $txt on selfhost for rid: $rid"
_err "Invalid response of acme-dns for selfhost"
return 1
fi
+
+ # write last used rid domain
+ newLastUsedRidForDomainEntry="$fulldomain:$rid"
+ if ! test -z "$lastUsedRidForDomainEntry"; then
+ # replace last used rid entry for domain
+ SELFHOSTDNS_MAP_LAST_USED_INTERNAL=$(echo "$SELFHOSTDNS_MAP_LAST_USED_INTERNAL" | sed -n -E "s/$lastUsedRidForDomainEntry/$newLastUsedRidForDomainEntry/p")
+ else
+ # add last used rid entry for domain
+ if test -z "$SELFHOSTDNS_MAP_LAST_USED_INTERNAL"; then
+ SELFHOSTDNS_MAP_LAST_USED_INTERNAL="$newLastUsedRidForDomainEntry"
+ else
+ SELFHOSTDNS_MAP_LAST_USED_INTERNAL="$SELFHOSTDNS_MAP_LAST_USED_INTERNAL $newLastUsedRidForDomainEntry"
+ fi
+ fi
+
+ # Now that we know the values are good, save them
+ _saveaccountconf_mutable SELFHOSTDNS_USERNAME "$SELFHOSTDNS_USERNAME"
+ _saveaccountconf_mutable SELFHOSTDNS_PASSWORD "$SELFHOSTDNS_PASSWORD"
+ # These values are domain dependent, so store them there
+ _savedomainconf SELFHOSTDNS_MAP "$SELFHOSTDNS_MAP"
+ _savedomainconf SELFHOSTDNS_MAP_LAST_USED_INTERNAL "$SELFHOSTDNS_MAP_LAST_USED_INTERNAL"
}
-dns_acmedns_rm() {
- domain=$1
+dns_selfhost_rm() {
+ fulldomain=$1
txt=$2
- _debug fulldomain "$domain"
+ _debug fulldomain "$fulldomain"
_debug txtvalue "$txt"
+ _info "Creating and removing of records is not supported by selfhost API, will not delete anything."
}