X-Git-Url: http://git.grml.org/?a=blobdiff_plain;f=etc%2Fgrml%2Ffai%2Fconfig%2Fscripts%2FGRMLBASE%2F92-update-freshclam;h=afaadc4b072ea93bf94965608e30ff00be5044fe;hb=db5741b5b41210da401504a3493d9a284da32e9c;hp=e34a7079787a36aff3a7ba30b1258f25faf311b9;hpb=f3b335ea5c94d5cf24ec6b9184106b298849f311;p=grml-live.git diff --git a/etc/grml/fai/config/scripts/GRMLBASE/92-update-freshclam b/etc/grml/fai/config/scripts/GRMLBASE/92-update-freshclam index e34a707..afaadc4 100755 --- a/etc/grml/fai/config/scripts/GRMLBASE/92-update-freshclam +++ b/etc/grml/fai/config/scripts/GRMLBASE/92-update-freshclam @@ -12,19 +12,39 @@ if ifclass NO_ONLINE ; then fi set -u -set -e + +bailout() { + if [ "${1:-}" = "124" ] ; then + echo "Warning: freshclam returned with exit code 124." >&2 + + # be verbose in logs + echo "Warning: freshclam returned with exit code 124." + echo "-> This might happen when the incremental daily update failed to run, and" + echo " retrieving the full daily.cvd failed as well." + echo " This is known to be a problem in automated builds causing build errors." + echo " Therefore we are ignoring this issue." + echo " If a fresh clamav database is important for you, execute freshclam in the chroot." + + exit 0 + fi + + exit "${1:-0}" +} [ -x $target/usr/bin/timeout ] && TIMEOUT="10" || TIMEOUT="" if ! [ -x $target/usr/bin/freshclam ] ; then echo "freshclam not installed" + exit 0 +fi + +echo "Updating clamav database via running freshclam" +if [ -n "$TIMEOUT" ] ; then + $ROOTCMD timeout $TIMEOUT /usr/bin/freshclam + bailout $? else - echo "Updating clamav database via running freshclam" - if [ -n "$TIMEOUT" ] ; then - $ROOTCMD timeout $TIMEOUT /usr/bin/freshclam - else - $ROOTCMD /usr/bin/freshclam - fi + $ROOTCMD /usr/bin/freshclam + bailout $? fi ## END OF FILE #################################################################