39

My web application sends email fairly often, and it sends 3 kinds of emails: initiated by user, in response to an event in the system, and in automatic response to an email received by the application.

I would like to make sure that the third type of email does not get stuck in an endless loop of auto-responders talking to each other. Currently, I use the header:

Precedence: junk

but Yahoo! mail is treating these messages as spam. This is obviously not ideal, because we would like SOMEBODY to read our auto-response and make a decision on it, just not an out-of-office reply.

What is the best way to send an email without triggering either junk filters or auto-responders?

Precedence: junk?

Precedence: bulk?

Precedence: list?

X-Priority: 2?
Jacob Krall
  • 28,341
  • 6
  • 66
  • 76

5 Answers5

27

There is a RFC 3834 dedicated for automated email responses.

In short, it recommends:

  1. Send auto-responses only to address contained in the Return-Path header of an incoming message, if it is valid email address. Particularly "<>" (null address) in the Return-Path of the message means that auto-responses must not be sent for this message.

  2. When sending auto-response, MAIL FROM smtp command must contain "<>" (null address). This would lead to Return-Path:<> when message will be delivered.

  3. Use Auto-Submitted header with value other than "no" to explicitly indicate automated response.

One note: it is not worth to explicitly set Return-Path header in outgoing message, as this header must be rewritten by envelop address (from MAIL FROM smtp command) during delivery.

Community
  • 1
  • 1
user38936
  • 271
  • 2
  • 3
  • 1
    I believe #3 above should be "Auto-Submitted", and it can be "no" (human mail), "auto-replied" (bounces, vacation notices) or "auto-generated" (daily status cron jobs, etc) – Irongaze.com Apr 27 '12 at 19:34
  • By checking headers, do I still need to check subject to detect auto responders? – user4271704 Aug 29 '16 at 06:49
  • can we rely on Auto-Submitted=auto-replied in order to filter bounced messages from normal ones? Do all mail servers/clients respect RFC 3834? at least major ones? – Laurynas Mališauskas Dec 21 '16 at 09:21
18

RFC 2076 discourages the use of the precedence header. as you have noted, many clients will just filter that off (especially the precedence: junk variety). it may be better to use a null path to avoid auto responder wars:

Return-Path: <>

Ultimately you could use priority to try to get around this, but this seems like going against the spirit of the header. i'd suggest just using the return-path header for this, and avoiding precedence. in some cases you may have to write in some way to drop auto-responders in your application (to avoid getting into a responder war), but i can't remember a situation in which this happened using an appropriate return-path. (most auto responder wars i recall having to deal with were the result of very badly formed emails)

Note: the Return-Path header is, in short, the destination for notifications (bounces, delay delivery, etc...), and is described in RFC 2821 -- because it's required by SMTP. It's also one method to drop bad mail (as theoretically all good mail will set an appropriate return-path).

Michael Pryor
  • 25,046
  • 18
  • 72
  • 90
Owen
  • 82,995
  • 21
  • 120
  • 115
  • Can you explain what Return-Path is used for? (I assume it's much different than the Reply-To header) – Michael Pryor Sep 30 '08 at 23:13
  • in short it's the destination for notifications (bounces, delay delivery, etc...), and is described in RFC 2821. because it's required by SMTP, it's also one method to drop bad mail (as theoretically all good mail will set an appropriate return-path) – Owen Oct 01 '08 at 01:24
9

You can set these headers:

Precedence: bulk
Auto-Submitted: auto-generated

Source: http://www.redmine.org/projects/redmine/repository/revisions/2655/diff

guettli
  • 25,042
  • 81
  • 346
  • 663
  • RFC 2076 discourages the usage of Precedence. – WhyNotHugo Jun 30 '14 at 17:43
  • 3
    @WhyNotHugo You say the RFC discourages the usage of Precedence. Yes, you are right. I think there are two worlds of truth: The theory and the practice. Related: https://github.com/jpmckinney/multi_mail/wiki/Detecting-autoresponders – guettli Nov 16 '18 at 10:58
0

The traditional way of dealing with this is to send the email with a null envelope-sender (traditionally written as <>). This prevents the autoresponder on the other end from responding because there's no sender to respond to.

jj33
  • 7,543
  • 2
  • 38
  • 42
-5

How about configuring a white list on your email account?

I would assume that any email key words could get flagged by a junk filter.

Robert Deml
  • 12,390
  • 20
  • 65
  • 92