clamd.sh 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  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. # Cleaning up garbage
  8. echo "Cleaning up tmp files..."
  9. rm -rf /var/lib/clamav/clamav-*.tmp
  10. # Prepare whitelist
  11. mkdir -p /run/clamav /var/lib/clamav
  12. if [[ -s /etc/clamav/whitelist.ign2 ]]; then
  13. echo "Copying non-empty whitelist.ign2 to /var/lib/clamav/whitelist.ign2"
  14. cp /etc/clamav/whitelist.ign2 /var/lib/clamav/whitelist.ign2
  15. fi
  16. if [[ ! -f /var/lib/clamav/whitelist.ign2 ]]; then
  17. echo "Creating /var/lib/clamav/whitelist.ign2"
  18. cat <<EOF > /var/lib/clamav/whitelist.ign2
  19. # Please restart ClamAV after changing signatures
  20. Example-Signature.Ignore-1
  21. PUA.Win.Trojan.EmbeddedPDF-1
  22. PUA.Pdf.Trojan.EmbeddedJavaScript-1
  23. PUA.Pdf.Trojan.OpenActionObjectwithJavascript-1
  24. EOF
  25. fi
  26. chown clamav:clamav -R /var/lib/clamav /run/clamav
  27. chmod 755 /var/lib/clamav
  28. chmod 644 -R /var/lib/clamav/*
  29. chmod 750 /run/clamav
  30. stat /var/lib/clamav/whitelist.ign2
  31. dos2unix /var/lib/clamav/whitelist.ign2
  32. sed -i '/^\s*$/d' /var/lib/clamav/whitelist.ign2
  33. # Copying to /etc/clamav to expose file as-is to administrator
  34. cp -p /var/lib/clamav/whitelist.ign2 /etc/clamav/whitelist.ign2
  35. BACKGROUND_TASKS=()
  36. echo "Running freshclam..."
  37. freshclam
  38. (
  39. while true; do
  40. sleep 12600
  41. freshclam
  42. done
  43. ) &
  44. BACKGROUND_TASKS+=($!)
  45. (
  46. while true; do
  47. sleep 10m
  48. SANE_MIRRORS="$(dig +ignore +short rsync.sanesecurity.net)"
  49. for sane_mirror in ${SANE_MIRRORS}; do
  50. CE=
  51. rsync -avp --chown=clamav:clamav --chmod=Du=rwx,Dgo=rx,Fu=rw,Fog=r --timeout=5 rsync://${sane_mirror}/sanesecurity/ \
  52. --include 'blurl.ndb' \
  53. --include 'junk.ndb' \
  54. --include 'jurlbl.ndb' \
  55. --include 'jurbla.ndb' \
  56. --include 'phishtank.ndb' \
  57. --include 'phish.ndb' \
  58. --include 'spamimg.hdb' \
  59. --include 'scam.ndb' \
  60. --include 'rogue.hdb' \
  61. --include 'sanesecurity.ftm' \
  62. --include 'sigwhitelist.ign2' \
  63. --exclude='*' /var/lib/clamav/
  64. CE=$?
  65. chmod 755 /var/lib/clamav/
  66. if [ ${CE} -eq 0 ]; then
  67. while [ ! -z "$(pidof freshclam)" ]; do
  68. echo "Freshclam is active, waiting..."
  69. sleep 5
  70. done
  71. echo RELOAD | nc clamd-mailcow 3310
  72. break
  73. fi
  74. done
  75. sleep 12h
  76. done
  77. ) &
  78. BACKGROUND_TASKS+=($!)
  79. echo "$(clamd -V) is starting... please wait a moment."
  80. nice -n10 clamd &
  81. BACKGROUND_TASKS+=($!)
  82. while true; do
  83. for bg_task in ${BACKGROUND_TASKS[*]}; do
  84. if ! kill -0 ${bg_task} 1>&2; then
  85. echo "Worker ${bg_task} died, stopping container waiting for respawn..."
  86. kill -TERM 1
  87. fi
  88. sleep 10
  89. done
  90. done