bootstrap.sh 2.0 KB

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