Some mail-reading programs (MUAs) allow users to forward messages to
other users. For example, the mush(1) MUA forwards
the current message to the user named fred
with the following
command:
message 1 of 3>m -f fred
Messages can also be forwarded with dist(1) from mh(1) and from within other MUAs.
When messages are forwarded, header lines that describe the
forwarding user must begin with the Resent-
prefix.
When fred
receives this message, he sees two similar header
lines:
From: original-sender Resent-From: forwarding-sender
When both the original From:
and the forwarded
Resent-From:
appear in the same header, the
Resent-
form is always considered the most recent.
The sendmail program examines only a few header names to see whether a mail message has been forwarded. Those that it knows are listed in Table 35.9.
Resent- form of | Header |
---|---|
Resent-Bcc: | Bcc: |
Resent-Cc: | Cc: |
Resent-Date: | Date: |
Resent-From: | From: |
Resent-Message-ID: | Message-ID: |
Resent-To: | To: |
If sendmail finds any header with a name beginning with Resent-
,
it marks that message as
one that is being forwarded, preserves all Resent-
headers, and creates any needed ones.
Whether the message is forwarded or not, sendmail compares
the sender envelope address to the address in the From:
header (or Resent-From:
if present).
If they are the same, sendmail deletes the From:
(or Resent-From:
). The purpose of this deletion
is to add the sender's full name (the $x
macro; see Section 31.10.42) to the
address. If the envelope and sender addresses are the same,
it is safe to delete and regenerate those header lines.
If the message is being forwarded, sendmail recreates
the Resent-From:
header; otherwise, it recreates
the From:
header (see Section 37.5.113, -d31.2).
This recreation is useful because some old versions of mh(1)
added a From:
header without the full name ($x
).
It is also useful in mail client/server arrangements in which
all mail is sent to the server. Because that mail is sent with
the TCP
delivery agent, no $x
full name is added.
On the server the From:
is discarded, and there
is a second chance to add the $x
. However, this can happen only if the address in the envelope and the address in
the From:
are identical. Since the address in
the envelope is surrounded with angle brackets, so must be the
address in the From:
header. One way to ensure
that they are the same is by defining the From:
header with $g
in angle brackets, as <$g>
in the
client's configuration file.