bootstrap.sh 2.1 KB

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