-if [[ ! -r $f ]] \
- || (( $(( $(date +%s) - $(stat -c %Y $f ) )) > 60*60 )); then
- if host $proxy_host && nc -z $proxy_host $proxy_port; then
- echo $proxy_url
- else
+if [[ ! -w /tmp ]]; then
+ echo DIRECT
+ exit 0
+fi
+modtime=$(stat -c %Y $f 2>/dev/null ) ||:
+if [[ $modtime ]] && (( $(( $(date +%s) - modtime )) < 60*10 )); then
+ echo DIRECT
+ exit 0
+else
+ rm -f $f
+fi
+if getent hosts $proxy_host &>/dev/null && timeout 1 nc -z $proxy_host $proxy_port &>/dev/null; then
+ echo $proxy_url
+else
+ if [[ ! -e $f || -w $f ]]; then