Configuring SENDMAIL to queue 'undeliverable' mail

I'm running sendmail-8.12.8-6.90 on a RH9 box on an internal network

I want to process email for the intranet seperatly: check for tag in subject line, virus check, tunnel through firewall for delivery.

My first thought was to queue all undeliverable emails so that I can raid the mail queue

I tried
but it does not seem to work, and it requires an SMTP gateway to be set up.

2 parts to this question really:
   is there a better way to do this outgoing filtering?
   if not, is there a better way to queue non-local email (HOLD_EXPENSIVE or something)?
Who is Participating?

[Webinar] Streamline your web hosting managementRegister Today

jlevieConnect With a Mentor Commented:
Alas , I think I've confused you by my reference to multiple instances of sendmail. I'm speaking of sendmail processes, not servers. All of the instances of sendmail would be running on the same server, it's just a change in the way the copies of sendmail are invoked.

Using this method all mail received by the MTA is held in It becomes the job of your "filter code" to process messages as you see fit and move then to the outgoing queue. You'll have to do that anyway in the code since at any given time there may be messages in the queue that are destined for local users. Note that sendmail doesn't "split" a message into local and remote messages. If one of your users sends an email to a local account and an Internet site, sendmail will hold it if you use something like the above reference since one address is non-local. Delivery to the local account won't occur until the message is processed for Internet delivery.
I presume that you intend to "manually" check the messages before delivering them from the way the question is phrased. A better approach, which will protect against internal spread of a virus would be to install a server-level anti-virus scanner that scans all mail. I personally prefer MailScanner ( as the framework for an anti-spam/anti-virus filter. It supports some twenty different A/V scanners, including the OpenSource ClamAV.
sprinkmeierAuthor Commented:
Poorly phrased question then :-)

I want to process outgoing mail to keep an achive copy and to ensure that the subject contains (and to remove) a certain tag.

I suppose a guru could do this, or milter or something, but I want something simple to audit.
Free Tool: SSL Checker

Scans your site and returns information about your SSL implementation and certificate. Helpful for debugging and validating your SSL configuration.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

The easiest way of doing this would be to use the same sort of procedure that MailScanner employs to injet itself into the mail stream. What happens is that you create a new queue (/var/spool/ and run a sendmail process as the MTA. This instance of sendmail listens on the SMTP port, accepts messages, and places the qf/df pair in and does no further delivery. Your "filter process" picks up qf/df pairs from, logs, modifies, etc., each message and then places the result in /var/spool/mqueue. Another sendmail instance runs that queue delivering the messgaes,  locally or to Internet hosts.

This is lots easier to implement than writing a custom milter filter and it is a lot safer w/respect to the possibility of losing email.
sprinkmeierAuthor Commented:
If I understand correctly, this solution implies a seperate instance of sendmail for "outgoing" mail.

I'm trying to avoid this (we only have one server at the moment).

Additionally, I'd need the main sendmail to know when to use the 'outgoing' sendmail. Once I have the rules in place for this, I actually don't need the other server anymore, I can just pick the queued-undeliverable messages out of the mqueue of the main server (i.e. "send outgogin mail to, then periodically process the queue removing "failed to contact" messages").

I think something like
should to the trick.
sprinkmeierAuthor Commented:

project on hold (again).

Thaks for your info.
All Courses

From novice to tech pro — start learning today.