ddns-scripts: update_gandi_net: improve logging & add timeout
[feed/packages.git] / net / ddns-scripts / files / usr / lib / ddns / update_gandi_net.sh
index 8953072e437ba46b3c535cc7420f8e6b1a41e617..321687d7007675f62e4c0af63381cb166b2da27b 100644 (file)
@@ -20,14 +20,23 @@ json_add_array rrset_values
 json_add_string "" "$__IP"
 json_close_array
 
+# Log the curl command
+write_log 7 "curl -s -X PUT \"$__ENDPOINT/domains/$domain/records/$username/$__RRTYPE\" \
+       -H \"Authorization: Apikey $password\" \
+       -H \"Content-Type: application/json\" \
+       -d \"$(json_dump)\" \
+       --connect-timeout 30"
+
 __STATUS=$(curl -s -X PUT "$__ENDPOINT/domains/$domain/records/$username/$__RRTYPE" \
        -H "Authorization: Apikey $password" \
        -H "Content-Type: application/json" \
        -d "$(json_dump)" \
+       --connect-timeout 30 \
        -w "%{http_code}\n" -o $DATFILE 2>$ERRFILE)
 
-if [ $? -ne 0 ]; then
-       write_log 14 "Curl failed: $(cat $ERRFILE)"
+local __ERRNO=$?
+if [ $__ERRNO -ne 0 ]; then
+       write_log 14 "Curl failed with $__ERRNO: $(cat $ERRFILE)"
        return 1
 elif [ -z $__STATUS ] || [ $__STATUS != 201 ]; then
        write_log 14 "LiveDNS failed: $__STATUS \ngandi.net answered: $(cat $DATFILE)"