Bobcares

How to Set Up Sendmail with ClamAV and MILTER Support

by | Jan 17, 2025

Learn how to set up Sendmail with ClamAV and MILTER Support. Our Sendmail Support team is here to help you with your questions and concerns.

How to Set Up Sendmail with ClamAV and MILTER Support

How to Set Up Sendmail with ClamAV and MILTER SupportDid you know that Sendmail integrates seamlessly with MILTER and ClamAV to enhance email security and filtering capabilities?

Our Experts have compiled this step-by-step guide to help you start configuring this setup.

 

Step 1: Check for MILTER Support

Sendmail requires MILTER support to function with filters. To verify if MILTER is enabled, run:

$ sendmail -d0 < /dev/null | grep MILTERCopy Code

If MILTER appears in the output, proceed to the next step. For systems like RedHat Linux, ensure the `sendmail` and `sendmail-devel` packages are installed:

# yum install sendmail sendmail-develCopy Code

If using Sendmail 8.12, add the following entries to `site.config.m4` and rebuild:


APPENDDEF(`confENVDEF', `-DMILTER')
dnl APPENDDEF(`conf_libmilter_ENVDEF', `-D_FFR_MILTER_ROOT_UNSAFE')
Copy Code

To rebuild Sendmail:

$ sh Build -c -f /etc/mail/site.config.m4Copy Code

Then, ensure the `libmilter` library is installed:

$ locate libmilter | grep /usr/localCopy Code

If not, install it from the Sendmail source directory:


$ cd libmilter
$ sh Build install
Copy Code

Step 2: Configure ClamAV with MILTER Support

Now, we have to make sure ClamAV is configured with MILTER support. From the ClamAV source directory:

$ ./configure --enable-milter
$ make && make install
Copy Code

Then, update `clamd.conf` with critical options:


LocalSocket /var/run/clamav.sock
LogSyslog
FixStaleSocket
StreamSaveToDisk
StreamMaxLength 10M
User clamav
ScanMail
ScanArchive
ArchiveMaxFileSize 10M
Copy Code

Next, start the ClamAV daemon:

$ sudo /usr/local/sbin/clamdCopy Code

Step 3: Launch ClamAV-MILTER

Now, start the ClamAV-MILTER service with the appropriate options:


$ sudo /usr/local/sbin/clamav-milter --max-children=2 -olb \
local:/var/run/clamav-milter.sock
Copy Code

For testing, use `–max-children=2`. Increase this value for production use.

Then, create a quarantine directory:


# mkdir /var/mail/quarantine/
# chown clamav:clamav /var/mail/quarantine/
# chmod 600 /var/mail/quarantine/
Copy Code

Step 4: Configure Sendmail for ClamAV-MILTER

Next, update the `sendmail.mc` file to enable virus scanning:


INPUT_MAIL_FILTER(`clamav-milter', `S=local:/var/run/clamav-milter.sock, F=T, T=S:4m;R:4m;E:10m')
define(`confINPUT_MAIL_FILTERS', `clamav-milter')
Copy Code

Then, rebuild the `sendmail.cf` configuration file:


# m4 /etc/mail/sendmail.mc > /etc/mail/sendmail.cf
# service sendmail reload
Copy Code

Step 5: Test the Configuration

At this point, send a test email with an EICAR test string:

# echo 'X5O!P%@AP[4\PZX54(P^)7CC)7}$EICAR-STANDARD-ANTIVIRUS-TEST-FILE!$H+H*' | sendmail -v abc@domain.comCopy Code

Also, verify the message is quarantined or appropriately flagged by ClamAV.

Additional Notes

  • Use `T=S:4m;R:4m` to define timeouts for sending and receiving to/from the filter.
  • Also, update ClamAV logs with `LogFile /var/log/clam/clamd.log`.
  • Then, increase `–max-children` and other parameters for production systems.

This configuration ensures the Sendmail setup integrates effectively with ClamAV and MILTER, providing robust email filtering and security.

[Need assistance with a different issue? Our team is available 24/7.]

Conclusion

In brief, our Support Experts demonstrated how to set up Sendmail with ClamAV and MILTER Support.

0 Comments

Submit a Comment

Your email address will not be published. Required fields are marked *

Speed issues driving customers away?
We’ve got your back!