feat(ingress.tjo.cloud): handle any record
Some checks failed
/ lint (push) Failing after 39s

This commit is contained in:
Tine 2025-01-03 20:41:46 +01:00
parent 1124b18822
commit 7a8ab362db
Signed by: mentos1386
SSH key fingerprint: SHA256:MNtTsLbihYaWF8j1fkOHfkKNlnN1JQfxEU/rBU8nCGw
2 changed files with 82 additions and 52 deletions

View file

@ -85,7 +85,7 @@ cp -r root/etc/default/dyndns /etc/default/dyndns
{ {
echo "" echo ""
echo "DNSIMPLE_TOKEN=${DNSIMPLE_TOKEN}" echo "DNSIMPLE_TOKEN=${DNSIMPLE_TOKEN}"
echo "NAME=any;${CLOUD_REGION}" echo "CLOUD_REGION=${CLOUD_REGION}"
} >>/etc/default/dyndns } >>/etc/default/dyndns
systemctl enable --now dyndns systemctl enable --now dyndns
systemctl restart dyndns systemctl restart dyndns

View file

@ -29,70 +29,98 @@ error() {
test -z "${DNSIMPLE_TOKEN}" && error "DNSIMPLE_TOKEN not set!" test -z "${DNSIMPLE_TOKEN}" && error "DNSIMPLE_TOKEN not set!"
test -z "${DNSIMPLE_ACCOUNT_ID}" && error "DNSIMPLE_ACCOUNT_ID not set!" test -z "${DNSIMPLE_ACCOUNT_ID}" && error "DNSIMPLE_ACCOUNT_ID not set!"
test -z "${DOMAIN}" && error "DOMAIN not set!" test -z "${DOMAIN}" && error "DOMAIN not set!"
test -z "${NAME}" && error "NAME not set!" test -z "${CLOUD_REGION}" && error "CLOUD_REGION not set!"
dns_list="$api_host/$DNSIMPLE_ACCOUNT_ID/zones/$DOMAIN/records" dns_list="$api_host/$DNSIMPLE_ACCOUNT_ID/zones/$DOMAIN/records"
configure_record() { configure_single() {
# disable glob expansion # disable glob expansion
set -f set -f
domain_records=$1 domain_records=$1
ip=$2 domain=$2
type=$3 ip=$3
type=$4
for sub in ${NAME//;/ }; do record_id=$(echo "$domain_records" | jq ".data[] | select(.type == \"$type\" and .name == \"$domain\") | .id")
record_id=$(echo "$domain_records" | jq ".data[] | select(.type == \"$type\" and .name == \"$sub\") | .id") record_data=$(echo "$domain_records" | jq -r ".data[] | select(.type == \"$type\" and .name == \"$domain\") | .content")
record_data=$(echo "$domain_records" | jq -r ".data[] | select(.type == \"$type\" and .name == \"$sub\") | .content")
# For all subdomains except "any" if [ "$(echo "$record_id" | wc -l)" -ge 2 ]; then
# we remove duplicates and only keep one A and AAAA records. warn "domain=$domain type=$type Domain name has duplicate DNS records, removing duplicates"
if [[ "${sub}" != "any" ]]; then record_id_to_delete=$(echo "$record_id" | tail -n +2)
if [ "$(echo "$record_id" | wc -l)" -ge 2 ]; then record_id=$(echo "$record_id" | head -1)
warn "domain=$sub type=$type Domain name has duplicate DNS records, removing duplicates" record_data=$(echo "$record_data" | head -1)
record_id_to_delete=$(echo "$record_id" | tail -n +2)
record_id=$(echo "$record_id" | head -1)
record_data=$(echo "$record_data" | head -1)
while IFS= read -r line; do while IFS= read -r line; do
curl -s -X DELETE \ curl -s -X DELETE \
-H "Content-Type: application/json" \
-H "Authorization: Bearer $DNSIMPLE_TOKEN" \
"$dns_list/$line" &>/dev/null
done <<<"$record_id_to_delete"
fi
fi
# re-enable glob expansion
set +f
data="{\"type\": \"$type\", \"name\": \"$sub\", \"content\": \"$ip\", \"ttl\": $record_ttl}"
url="$dns_list/$record_id"
if [[ -z $record_id ]]; then
info "domain=$sub type=$type No record found. Creating record, sending data=$data to url=$url"
new_record=$(curl -s -X POST \
-H "Content-Type: application/json" \ -H "Content-Type: application/json" \
-H "Authorization: Bearer $DNSIMPLE_TOKEN" \ -H "Authorization: Bearer $DNSIMPLE_TOKEN" \
-d "$data" \ "$dns_list/$line" &>/dev/null
"$url") done <<<"$record_id_to_delete"
fi
record_data=$(echo "$new_record" | jq -r ".data") # re-enable glob expansion
fi set +f
if [[ "$ip" != "$record_data" ]]; then data="{\"type\": \"$type\", \"name\": \"$domain\", \"content\": \"$ip\", \"ttl\": $record_ttl}"
info "domain=$sub type=$type Existing DNS record address ($record_data) doesn't match current IP ($ip), sending data=$data to url=$url" url="$dns_list/$record_id"
curl -s -X PATCH \ if [[ -z $record_id ]]; then
-H "Content-Type: application/json" \ info "domain=$domain type=$type No record found. Creating record, sending data=$data to url=$url"
-H "Authorization: Bearer $DNSIMPLE_TOKEN" \
-d "$data" \ new_record=$(curl -s -X POST \
"$url" &>/dev/null -H "Content-Type: application/json" \
else -H "Authorization: Bearer $DNSIMPLE_TOKEN" \
info "domain=$sub type=$type Existing DNS record address ($record_data) did not need updating" -d "$data" \
fi "$url")
done
record_data=$(echo "$new_record" | jq -r ".data")
fi
if [[ "$ip" != "$record_data" ]]; then
info "domain=$domain type=$type Existing DNS record address ($record_data) doesn't match current IP ($ip), sending data=$data to url=$url"
curl -s -X PATCH \
-H "Content-Type: application/json" \
-H "Authorization: Bearer $DNSIMPLE_TOKEN" \
-d "$data" \
"$url" &>/dev/null
else
info "domain=$domain type=$type Existing DNS record address ($record_data) did not need updating"
fi
}
configure_many() {
# disable glob expansion
set -f
domain_records=$1
domain=$2
ip=$3
type=$4
record_id=$(echo "$domain_records" | jq ".data[] | select(.type == \"$type\" and .name == \"$domain\" and .content = \"$ip\") | .id")
record_data=$(echo "$domain_records" | jq ".data[] | select(.type == \"$type\" and .name == \"$domain\" and .content = \"$ip\") | .content")
# re-enable glob expansion
set +f
data="{\"type\": \"$type\", \"name\": \"$domain\", \"content\": \"$ip\", \"ttl\": $record_ttl}"
url="$dns_list/$record_id"
if [[ -z $record_id ]]; then
info "domain=$domain type=$type No record found. Creating record, sending data=$data to url=$url"
new_record=$(curl -s -X POST \
-H "Content-Type: application/json" \
-H "Authorization: Bearer $DNSIMPLE_TOKEN" \
-d "$data" \
"$url")
record_data=$(echo "$new_record" | jq -r ".data")
else
info "domain=$domain type=$type Existing DNS record address ($record_data) did not need updating"
fi
} }
while (true); do while (true); do
@ -118,14 +146,16 @@ while (true); do
warn "IPv4 wasn't retrieved within allowed interval. Will try $sleep_interval seconds later.." warn "IPv4 wasn't retrieved within allowed interval. Will try $sleep_interval seconds later.."
else else
info "Found IPv4 address $ipv4" info "Found IPv4 address $ipv4"
configure_record "$domain_records" "$ipv4" "A" configure_single "$domain_records" "$CLOUD_REGION" "$ipv4" "A"
configure_many "$domain_records" "any" "$ipv4" "A"
fi fi
if [[ -z $ipv6 ]]; then if [[ -z $ipv6 ]]; then
warn "IPv6 wasn't retrieved within allowed interval. Will try $sleep_interval seconds later.." warn "IPv6 wasn't retrieved within allowed interval. Will try $sleep_interval seconds later.."
else else
info "Found IPv6 address $ipv6" info "Found IPv6 address $ipv6"
configure_record "$domain_records" "$ipv6" "AAAA" configure_single "$domain_records" "$CLOUD_REGION" "$ipv6" "AAAA"
configure_many "$domain_records" "any" "$ipv6" "AAAA"
fi fi
sleep "$sleep_interval" sleep "$sleep_interval"