Solved

Configuring SENDMAIL to queue 'undeliverable' mail

Posted on 2004-05-02
8
727 Views
Last Modified: 2013-12-17
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
   http://www.sendmail.org/faq/section4.html#4.12
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)?
0
Comment
Question by:sprinkmeier
  • 3
  • 3
8 Comments
 
LVL 40

Expert Comment

by:jlevie
ID: 10978546
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 (http://mailscanner.info) as the framework for an anti-spam/anti-virus filter. It supports some twenty different A/V scanners, including the OpenSource ClamAV.
0
 
LVL 2

Author Comment

by:sprinkmeier
ID: 10982425
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 sendmail.cf guru could do this, or milter or something, but I want something simple to audit.
0
 
LVL 40

Expert Comment

by:jlevie
ID: 10988972
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/mqueue.in) 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 mqueue.in and does no further delivery. Your "filter process" picks up qf/df pairs from mqueue.in, 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.
0
Ransomware: The New Cyber Threat & How to Stop It

This infographic explains ransomware, type of malware that blocks access to your files or your systems and holds them hostage until a ransom is paid. It also examines the different types of ransomware and explains what you can do to thwart this sinister online threat.  

 
LVL 2

Author Comment

by:sprinkmeier
ID: 10991793
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 not-really-there.internal.example.com, then periodically process the queue removing "failed to contact not-really-there.internal.example.com" messages").

I think something like
   http://www.sendmail.org/~ca/email/offline_mailing.html
should to the trick.
0
 
LVL 40

Accepted Solution

by:
jlevie earned 500 total points
ID: 10992082
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 mqueue.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.
0
 
LVL 2

Author Comment

by:sprinkmeier
ID: 12120028
jlevie,

project on hold (again).

Thaks for your info.
0

Featured Post

Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Import PST to Exchange using Power Shell new-mailboximportrequest command, you can simply import the PST file into Exchange mailbox or archived. To know How to import PST into Exchange  2013 read the complete article.
Easy CSR creation in Exchange 2007,2010 and 2013
Familiarize people with the process of utilizing SQL Server views from within Microsoft Access. Microsoft Access is a very powerful client/server development tool. One of the SQL Server objects that you can interact with from within Microsoft Access…
Established in 1997, Technology Architects has become one of the most reputable technology solutions companies in the country. TA have been providing businesses with cost effective state-of-the-art solutions and unparalleled service that is designed…

820 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question