bootstrap.sh 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  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. fi
  11. if [[ ! -f /var/lib/clamav/whitelist.ign2 ]]; then
  12. echo "Example-Signature.Ignore-1" > /var/lib/clamav/whitelist.ign2
  13. fi
  14. chown clamav:clamav /var/lib/clamav/whitelist.ign2
  15. mkdir -p /run/clamav /var/lib/clamav
  16. chown clamav:clamav /run/clamav /var/lib/clamav
  17. chmod 750 /run/clamav
  18. chmod 755 -R /var/lib/clamav
  19. dos2unix /var/lib/clamav/whitelist.ign2
  20. sed -i '/^\s*$/d' /var/lib/clamav/whitelist.ign2
  21. BACKGROUND_TASKS=()
  22. (
  23. while true; do
  24. sleep 1m
  25. freshclam
  26. sleep 1h
  27. done
  28. ) &
  29. BACKGROUND_TASKS+=($!)
  30. (
  31. while true; do
  32. sleep 2m
  33. SANE_MIRRORS="$(dig +ignore +short rsync.sanesecurity.net)"
  34. for sane_mirror in ${SANE_MIRRORS}; do
  35. rsync -avp --chown=clamav:clamav --timeout=5 rsync://${sane_mirror}/sanesecurity/ \
  36. --include 'blurl.ndb' \
  37. --include 'junk.ndb' \
  38. --include 'jurlbl.ndb' \
  39. --include 'jurbla.ndb' \
  40. --include 'phishtank.ndb' \
  41. --include 'phish.ndb' \
  42. --include 'spamimg.hdb' \
  43. --include 'scam.ndb' \
  44. --include 'rogue.hdb' \
  45. --include 'sanesecurity.ftm' \
  46. --include 'sigwhitelist.ign2' \
  47. --exclude='*' /var/lib/clamav/
  48. if [ $? -eq 0 ]; then
  49. echo RELOAD | nc localhost 3310
  50. break
  51. fi
  52. done
  53. sleep 30h
  54. done
  55. ) &
  56. BACKGROUND_TASKS+=($!)
  57. nice -n10 clamd &
  58. BACKGROUND_TASKS+=($!)
  59. while true; do
  60. for bg_task in ${BACKGROUND_TASKS[*]}; do
  61. if ! kill -0 ${bg_task} 1>&2; then
  62. echo "Worker ${bg_task} died, stopping container waiting for respawn..."
  63. kill -TERM 1
  64. fi
  65. sleep 10
  66. done
  67. done