bootstrap.sh 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. #!/bin/bash
  2. if [[ "${SKIP_CLAMD}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then
  3. echo "SKIP_CLAMD=y, skipping ClamAV..."
  4. sleep 365d
  5. exit 0
  6. fi
  7. # Prepare whitelist
  8. if [[ -s /etc/clamav/whitelist.ign2 ]]; then
  9. cp /etc/clamav/whitelist.ign2 /var/lib/clamav/whitelist.ign2
  10. chown clamav:clamav /var/lib/clamav/whitelist.ign2
  11. fi
  12. if [[ ! -f /var/lib/clamav/whitelist.ign2 ]]; then
  13. echo "Example-Signature.Ignore-1" > /var/lib/clamav/whitelist.ign2
  14. fi
  15. chown clamav:clamav /var/lib/clamav/whitelist.ign2
  16. dos2unix /var/lib/clamav/whitelist.ign2
  17. sed -i '/^\s*$/d' /var/lib/clamav/whitelist.ign2
  18. BACKGROUND_TASKS=()
  19. (
  20. while true; do
  21. sleep 1m
  22. freshclam
  23. sleep 1h
  24. done
  25. ) &
  26. BACKGROUND_TASKS+=($!)
  27. (
  28. while true; do
  29. sleep 2m
  30. SANE_MIRRORS="$(dig +ignore +short rsync.sanesecurity.net)"
  31. for sane_mirror in ${SANE_MIRRORS}; do
  32. rsync -avp --chown=clamav:clamav --timeout=5 rsync://${sane_mirror}/sanesecurity/ \
  33. --include 'blurl.ndb' \
  34. --include 'junk.ndb' \
  35. --include 'jurlbl.ndb' \
  36. --include 'phish.ndb' \
  37. --exclude='*' /var/lib/clamav/
  38. if [ $? -eq 0 ]; then
  39. echo RELOAD | nc localhost 3310
  40. break
  41. fi
  42. done
  43. sleep 30h
  44. done
  45. ) &
  46. BACKGROUND_TASKS+=($!)
  47. clamd &
  48. BACKGROUND_TASKS+=($!)
  49. while true; do
  50. for bg_task in ${BACKGROUND_TASKS[*]}; do
  51. if ! kill -0 ${bg_task} 1>&2; then
  52. echo "Worker ${bg_task} died, stopping container waiting for respawn..."
  53. kill -TERM 1
  54. fi
  55. sleep 10
  56. done
  57. done