-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_ddns.sh
executable file
·70 lines (61 loc) · 2.26 KB
/
run_ddns.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#!/bin/bash
# Stop the script if any command returns a non-zero exit code
set -e
# Configuration file
source config.sh
# Function to log messages to the log file with timestamps
log_message() {
TIMESTAMP=$(date "+%Y-%m-%d %H:%M:%S")
EVENT="$1"
MESSAGE="$2"
echo "$TIMESTAMP,$EVENT,$MESSAGE" >>"$LOG_FILE"
echo "$TIMESTAMP,$EVENT,$MESSAGE"
}
log_message "STARTED" "Route53 DDNS execution started"
SERVER_IP=$(curl -sf https://api.ipify.org) || {
log_message "FAILED_SERVER_IP_CHECK" "Failed to get server's public IP"
exit 1
}
log_message "CHECKED_SERVER_IP" "Server's current public IP: $SERVER_IP"
if ! [[ $SERVER_IP =~ ^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
log_message "INVALID_SERVER_IP" "Server's reported current public IP is invalid: $SERVER_IP"
exit 1
fi
for FQDN in "${FQDNS[@]}"; do
DOMAIN_IP=$(
aws route53 list-resource-record-sets \
--hosted-zone-id "$AWS_HOSTED_ZONE_ID" \
--query "ResourceRecordSets[?Type == 'A' && Name == '$FQDN.'].ResourceRecords[0].Value" \
--output text
)
log_message "CHECKED_DOMAIN_IP" "Current Route53 IP for $FQDN: $DOMAIN_IP"
if ! [[ $DOMAIN_IP =~ ^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
log_message "INVALID_DOMAIN_IP" "Domain's reported current public IP is invalid: $DOMAIN_IP"
continue
fi
if [ "$SERVER_IP" != "$DOMAIN_IP" ]; then
# Send email notification through IFTTT webhook
curl -s -X POST \
-H "Content-Type: application/json" \
-d "{\"message\": \"Updating $FQDN from $DOMAIN_IP to $SERVER_IP...\"}" \
"https://maker.ifttt.com/trigger/$IFTTT_EVENT/json/with/key/$IFTTT_KEY" >/dev/null
log_message "INVOKED_IFTTT_WEBHOOK" "Invoked IFTTT webhook to send email notification"
# Update the A record
CHANGE_BATCH="{
\"Changes\": [{
\"Action\": \"UPSERT\",
\"ResourceRecordSet\": {
\"Name\": \"$FQDN\",
\"Type\": \"A\",
\"TTL\": 600,
\"ResourceRecords\": [{\"Value\": \"$SERVER_IP\"}]
}
}]
}"
aws route53 change-resource-record-sets \
--hosted-zone-id "$AWS_HOSTED_ZONE_ID" \
--change-batch "$CHANGE_BATCH"
log_message "UPDATED_ROUTE53" "Updated $FQDN from $DOMAIN_IP to $SERVER_IP..."
fi
done
log_message "COMPLETED" "Route53 DDNS execution complete"