quoted logFile variable to prevent globbing
This commit is contained in:
parent
8c24c6e625
commit
12c0cdde93
40
cfddns.sh
40
cfddns.sh
@ -83,7 +83,7 @@ function quit {
|
|||||||
if [ -z "$1" ]; then
|
if [ -z "$1" ]; then
|
||||||
# exit cleanly
|
# exit cleanly
|
||||||
echo -e "\e[1;32m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
echo -e "\e[1;32m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
||||||
"--[SUCCESS] Script completed --\e[0m" >> $logFile
|
"--[SUCCESS] Script completed --\e[0m" >> "$logFile"
|
||||||
exit 0
|
exit 0
|
||||||
elif [ "$1" = "none" ]; then
|
elif [ "$1" = "none" ]; then
|
||||||
if [ -z "$2" ]; then
|
if [ -z "$2" ]; then
|
||||||
@ -97,14 +97,14 @@ function quit {
|
|||||||
# list DNS entries that were not updated
|
# list DNS entries that were not updated
|
||||||
for failedName in "${failedDNS[@]}"; do
|
for failedName in "${failedDNS[@]}"; do
|
||||||
echo -e "\e[1;31m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
echo -e "\e[1;31m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
||||||
"-- [ERROR] $failedName was NOT updated --\e[0m" >> $logFile
|
"-- [ERROR] $failedName was NOT updated --\e[0m" >> "$logFile"
|
||||||
done
|
done
|
||||||
exit "$1"
|
exit "$1"
|
||||||
else
|
else
|
||||||
# notify use that error has occurred and provide exit code
|
# notify use that error has occurred and provide exit code
|
||||||
echo -e "\e[1;31m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
echo -e "\e[1;31m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
||||||
"-- [ERROR] Script exited with code $1 --" >> $logFile
|
"-- [ERROR] Script exited with code $1 --" >> "$logFile"
|
||||||
echo -e "\e[0;31m${errorExplain[$1]}\e[0m" >> $logFile
|
echo -e "\e[0;31m${errorExplain[$1]}\e[0m" >> "$logFile"
|
||||||
exit "$1"
|
exit "$1"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@ -194,7 +194,7 @@ done
|
|||||||
|
|
||||||
# Log beginning of script
|
# Log beginning of script
|
||||||
echo -e "\e[1;32m[`date +%Y-%m-%d` `date +%H:%M:%S`] -- Start CloudFlare" \
|
echo -e "\e[1;32m[`date +%Y-%m-%d` `date +%H:%M:%S`] -- Start CloudFlare" \
|
||||||
"DDNS script execution --\e[0m" >> $logFile
|
"DDNS script execution --\e[0m" >> "$logFile"
|
||||||
|
|
||||||
# Check validity of parameters
|
# Check validity of parameters
|
||||||
if [ -z "$accountFile" ] || [[ $accountFile == -* ]]; then
|
if [ -z "$accountFile" ] || [[ $accountFile == -* ]]; then
|
||||||
@ -215,10 +215,10 @@ fi
|
|||||||
# Log operating mode
|
# Log operating mode
|
||||||
if [ $ip4 -eq 1 ]; then
|
if [ $ip4 -eq 1 ]; then
|
||||||
echo -e "\e[1;36m[`date +%Y-%m-%d` `date +%H:%M:%S`] Script running in" \
|
echo -e "\e[1;36m[`date +%Y-%m-%d` `date +%H:%M:%S`] Script running in" \
|
||||||
"IP4 mode\e[0m" >> $logFile
|
"IP4 mode\e[0m" >> "$logFile"
|
||||||
elif [ $ip6 -eq 1 ]; then
|
elif [ $ip6 -eq 1 ]; then
|
||||||
echo -e "\e[1;36m [`date +%Y-%m-%d` `date +%H:%M:%S`] Script running in" \
|
echo -e "\e[1;36m [`date +%Y-%m-%d` `date +%H:%M:%S`] Script running in" \
|
||||||
"IP6 mode\e[0m" >> $logFile
|
"IP6 mode\e[0m" >> "$logFile"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
@ -229,7 +229,7 @@ mapfile -t cfDetails < "$accountFile"
|
|||||||
if [ -z "$ipAddress" ]; then
|
if [ -z "$ipAddress" ]; then
|
||||||
echo -e "\e[1;36m[`date +%Y-%m-%d` `date +%H:%M:%S`] No IP address for" \
|
echo -e "\e[1;36m[`date +%Y-%m-%d` `date +%H:%M:%S`] No IP address for" \
|
||||||
"update provided. Detecting this machine's IP address..." \
|
"update provided. Detecting this machine's IP address..." \
|
||||||
>> $logFile
|
>> "$logFile"
|
||||||
if [ $ip4 -eq 1 ]; then
|
if [ $ip4 -eq 1 ]; then
|
||||||
ipAddress=$(curl -s http://ipv4.icanhazip.com)
|
ipAddress=$(curl -s http://ipv4.icanhazip.com)
|
||||||
elif [ $ip6 -eq 1 ]; then
|
elif [ $ip6 -eq 1 ]; then
|
||||||
@ -242,22 +242,22 @@ if [ -z "$ipAddress" ]; then
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
echo -e "\e[1;36m[`date +%Y-%m-%d` `date +%H:%M:%S`] Using IP address:" \
|
echo -e "\e[1;36m[`date +%Y-%m-%d` `date +%H:%M:%S`] Using IP address:" \
|
||||||
"$ipAddress" >> $logFile
|
"$ipAddress" >> "$logFile"
|
||||||
|
|
||||||
|
|
||||||
## Check if desired record(s) exist at CloudFlare
|
## Check if desired record(s) exist at CloudFlare
|
||||||
echo -e "\e[0m[`date +%Y-%m-%d` `date +%H:%M:%S`] Performing CloudFlare" \
|
echo -e "\e[0m[`date +%Y-%m-%d` `date +%H:%M:%S`] Performing CloudFlare" \
|
||||||
"lookup on specified DNS records...\e[0m" >> $logFile
|
"lookup on specified DNS records...\e[0m" >> "$logFile"
|
||||||
# perform checks on A or AAAA records based on invocation options
|
# perform checks on A or AAAA records based on invocation options
|
||||||
if [ $ip4 -eq 1 ]; then
|
if [ $ip4 -eq 1 ]; then
|
||||||
echo -e "[`date +%Y-%m-%d` `date +%H:%M:%S`] (IP4: ${dnsRecords[*]})" \
|
echo -e "[`date +%Y-%m-%d` `date +%H:%M:%S`] (IP4: ${dnsRecords[*]})" \
|
||||||
>> $logFile
|
>> "$logFile"
|
||||||
for cfLookup in "${dnsRecords[@]}"; do
|
for cfLookup in "${dnsRecords[@]}"; do
|
||||||
cfRecords+=("$(curl -s -X GET "https://api.cloudflare.com/client/v4/zones/${cfDetails[2]}/dns_records?name=$cfLookup&type=A" -H "X-Auth-Email: ${cfDetails[0]}" -H "X-Auth-Key: ${cfDetails[1]}" -H "Content-Type: application/json")")
|
cfRecords+=("$(curl -s -X GET "https://api.cloudflare.com/client/v4/zones/${cfDetails[2]}/dns_records?name=$cfLookup&type=A" -H "X-Auth-Email: ${cfDetails[0]}" -H "X-Auth-Key: ${cfDetails[1]}" -H "Content-Type: application/json")")
|
||||||
done
|
done
|
||||||
elif [ $ip6 -eq 1 ]; then
|
elif [ $ip6 -eq 1 ]; then
|
||||||
echo -e "[`date +%Y-%m-%d` `date +%H:%M:%S`] (IP6: ${dnsRecords[*]})" \
|
echo -e "[`date +%Y-%m-%d` `date +%H:%M:%S`] (IP6: ${dnsRecords[*]})" \
|
||||||
>> $logFile
|
>> "$logFile"
|
||||||
for cfLookup in "${dnsRecords[@]}"; do
|
for cfLookup in "${dnsRecords[@]}"; do
|
||||||
cfRecords+=("$(curl -s -X GET "https://api.cloudflare.com/client/v4/zones/${cfDetails[2]}/dns_records?name=$cfLookup&type=AAAA" -H "X-Auth-Email: ${cfDetails[0]}" -H "X-Auth-Key: ${cfDetails[1]}" -H "Content-Type: application/json")")
|
cfRecords+=("$(curl -s -X GET "https://api.cloudflare.com/client/v4/zones/${cfDetails[2]}/dns_records?name=$cfLookup&type=AAAA" -H "X-Auth-Email: ${cfDetails[0]}" -H "X-Auth-Key: ${cfDetails[1]}" -H "Content-Type: application/json")")
|
||||||
done
|
done
|
||||||
@ -273,7 +273,7 @@ for recordIdx in "${!cfRecords[@]}"; do
|
|||||||
# inform user that domain not found in CloudFlare DNS records
|
# inform user that domain not found in CloudFlare DNS records
|
||||||
echo -e "\e[0;31m[`date +%Y-%m-%d` `date +%H:%M:%S`] ***" \
|
echo -e "\e[0;31m[`date +%Y-%m-%d` `date +%H:%M:%S`] ***" \
|
||||||
"${dnsRecords[recordIdx]} not found in your" \
|
"${dnsRecords[recordIdx]} not found in your" \
|
||||||
"CloudFlare DNS records***\e[0m" >> $logFile
|
"CloudFlare DNS records***\e[0m" >> "$logFile"
|
||||||
# remove the entry from the dnsRecords array
|
# remove the entry from the dnsRecords array
|
||||||
unset dnsRecords[$recordIdx]
|
unset dnsRecords[$recordIdx]
|
||||||
# remove the entry from the records array
|
# remove the entry from the records array
|
||||||
@ -293,7 +293,7 @@ else
|
|||||||
for recordIdx in "${!cfRecords[@]}"; do
|
for recordIdx in "${!cfRecords[@]}"; do
|
||||||
echo -e "\e[1;39m[`date +%Y-%m-%d` `date +%H:%M:%S`] Found" \
|
echo -e "\e[1;39m[`date +%Y-%m-%d` `date +%H:%M:%S`] Found" \
|
||||||
"${dnsRecords[recordIdx]} (Index: $recordIdx):\e[0m" \
|
"${dnsRecords[recordIdx]} (Index: $recordIdx):\e[0m" \
|
||||||
>> $logFile
|
>> "$logFile"
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -308,7 +308,7 @@ for recordIdx in "${!cfRecords[@]}"; do
|
|||||||
"For record ${dnsRecords[recordIdx]}" \
|
"For record ${dnsRecords[recordIdx]}" \
|
||||||
"with ID: ${recordID[recordIdx]}" \
|
"with ID: ${recordID[recordIdx]}" \
|
||||||
"the current IP is \e[1;35m ${currentIP[recordIdx]}" \
|
"the current IP is \e[1;35m ${currentIP[recordIdx]}" \
|
||||||
"\e[0m" >> $logFile
|
"\e[0m" >> "$logFile"
|
||||||
done
|
done
|
||||||
|
|
||||||
## Check whether new IP matches old IP and update if they do not match
|
## Check whether new IP matches old IP and update if they do not match
|
||||||
@ -316,11 +316,11 @@ for recordIdx in "${!currentIP[@]}"; do
|
|||||||
if [ ${currentIP[recordIdx]} = $ipAddress ]; then
|
if [ ${currentIP[recordIdx]} = $ipAddress ]; then
|
||||||
echo -e "\e[1;32m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
echo -e "\e[1;32m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
||||||
"${dnsRecords[recordIdx]} is up-to-date.\e[0m" \
|
"${dnsRecords[recordIdx]} is up-to-date.\e[0m" \
|
||||||
>> $logFile
|
>> "$logFile"
|
||||||
else
|
else
|
||||||
echo -e "\e[0;31m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
echo -e "\e[0;31m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
||||||
"${dnsRecords[recordIdx]} needs updating...\e[0m" \
|
"${dnsRecords[recordIdx]} needs updating...\e[0m" \
|
||||||
>> $logFile
|
>> "$logFile"
|
||||||
if [ $ip4 -eq 1 ]; then
|
if [ $ip4 -eq 1 ]; then
|
||||||
# update record at CloudFlare with new IP
|
# update record at CloudFlare with new IP
|
||||||
update=$(curl -s -X PUT "https://api.cloudflare.com/client/v4/zones/${cfDetails[2]}/dns_records/${recordID[recordIdx]}" -H "X-Auth-Email: ${cfDetails[0]}" -H "X-Auth-Key: ${cfDetails[1]}" -H "Content-Type: application/json" --data "{\"id\":\"${cfDetails[2]}\",\"type\":\"A\",\"proxied\":false,\"name\":\"${dnsRecords[recordIdx]}\",\"content\":\"$ipAddress\"}")
|
update=$(curl -s -X PUT "https://api.cloudflare.com/client/v4/zones/${cfDetails[2]}/dns_records/${recordID[recordIdx]}" -H "X-Auth-Email: ${cfDetails[0]}" -H "X-Auth-Key: ${cfDetails[1]}" -H "Content-Type: application/json" --data "{\"id\":\"${cfDetails[2]}\",\"type\":\"A\",\"proxied\":false,\"name\":\"${dnsRecords[recordIdx]}\",\"content\":\"$ipAddress\"}")
|
||||||
@ -331,11 +331,11 @@ for recordIdx in "${!currentIP[@]}"; do
|
|||||||
# check for success code from CloudFlare
|
# check for success code from CloudFlare
|
||||||
if [[ $update == *"\"success\":true"* ]]; then
|
if [[ $update == *"\"success\":true"* ]]; then
|
||||||
echo -e "\e[1;32m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
echo -e "\e[1;32m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
||||||
"${dnsRecords[recordIdx]} updated.\e[0m" >> $logFile
|
"${dnsRecords[recordIdx]} updated.\e[0m" >> "$logFile"
|
||||||
else
|
else
|
||||||
echo -e "\e[1;31m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
echo -e "\e[1;31m[`date +%Y-%m-%d` `date +%H:%M:%S`]" \
|
||||||
"${dnsRecords[recordIdx]} update failed\e[0m" >> $logFile
|
"${dnsRecords[recordIdx]} update failed\e[0m" >> "$logFile"
|
||||||
echo -e "\e[0;39m$update\e[0m" >> $logFile
|
echo -e "\e[0;39m$update\e[0m" >> "$logFile"
|
||||||
failedDNS+=("${dnsRecords[recordIdx]}")
|
failedDNS+=("${dnsRecords[recordIdx]}")
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
Loading…
Reference in New Issue
Block a user