X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=filesystem%2Fetc%2Fapt%2Fdetect-http-proxy;h=4bb8f3c8248c18e5b4f983031a43f7e73e333cf5;hb=e8591d75202b91bd2f5e73f603f991e0a2c14dcb;hp=a6d1d6fb77fa00b08ca1a7286fa40fcb9e9f4253;hpb=1178f7e7106ada9eba91184c04533feb28f695f5;p=distro-setup diff --git a/filesystem/etc/apt/detect-http-proxy b/filesystem/etc/apt/detect-http-proxy index a6d1d6f..4bb8f3c 100755 --- a/filesystem/etc/apt/detect-http-proxy +++ b/filesystem/etc/apt/detect-http-proxy @@ -11,17 +11,18 @@ proxy_host=faiserver proxy_port=3142 proxy_url=http://$proxy_host:$proxy_port/ f=/tmp/apt_proxy_fail -if [[ -r $f ]]; then - if (( $(( $(date +%s) - $(stat -c %Y $f ) )) < 60*10 )); then - echo DIRECT - exit 0 - else - if [[ -w $f ]]; then - rm $f - fi - fi +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 && nc -z $proxy_host $proxy_port &>/dev/null; then +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