Contents:
Headers
Headers Versus Delivery Agent Flags
Headers Learned So Far
Precedence
Sending Real Mail
Trusted User
Things to Try
In the previous chapter you sent mail to yourself and saw that
sendmail
added several problematic header lines to your message. Also the hub machine added some unsuitable headers. In this chapter we show how to use the
H
configuration command to add legal headers to a message, the
P
configuration command to set message priorities, and the
T
configuration command to define "trusted" users.
The header configuration command begins with the letter
H
. Like all configuration commands, the
H
is the first character on a line. The
H
is then followed by the name of a header:
Hname
:field
Here,
name
is the name of a header, such as
Subject
. The list of all header names that are of interest to
sendmail
can be found in
Chapter 35,
Headers
. The name is followed by a colon and then text that is appropriate for the header. Optional whitespace can surround the colon.
RFC822 (modified by RFC1123) specifies that certain header lines must appear in all email messages. Of those, the two you will first add to the client.cf file are shown in Table 14.1 .
Name | Description | When Added |
---|---|---|
From:
|
Address of the sender | If missing |
Received:
|
Record of receipt | Always |
Unless otherwise specified (as you will see later), a header that is declared in the configuration file is added to a mail message only if one doesn't already exist. The exception to this rule is the
Received:
header. It is always added to a mail message, even if there is already one (or more) there.
The
From:
header contains the official address of the sender. Declaring the
From:
header is simplicity itself, because it uses as its
field
a single macro surrounded by angle braces:
HFrom: <$g>
Recall that there are two kinds of macros: those that you define with the
D
command and those that
sendmail
defines. The
g
macro is one of the latter. The value
sendmail
gives the
g
macro is the address of the sender (generated by
sendmail
) as it appears on the envelope. That address, when you are the sender, was generated by the
Hubset
rule set:
SHubset # Rewrite the sender for the hub R$- $@ $1@${HUB} user -> user@hub
The sender address (
you
) is rewritten by this rule so that it becomes
[email protected]
. That is, the hostname and domain of the hub machine are appended so that the mail appears to come from the hub. This is the envelope address of the sender, and that is the address placed into the
g
macro. For email sent by you, the value that is given to
$g
(and thus to the
From:
header) is:
From: <[email protected]>
The
From:
header is added to an outgoing mail message only if there is not already a
From:
header there. (Often an MUA will add a
From:
header.) It is placed into the
client.cf
file to ensure that no mail leaves the local machine without this required header.
The
Received:
header is special. It is always added to the header portion of every mail message, even if one or more of them are already present.
The
Received:
header is used to make a record of each machine that mail has passed through. When
sendmail
calculates a hop count (to bounce mail with too many hops), it does so by counting the
Received:
header lines. The declaration of the
Received:
header is a bit complicated. A minimal
Received:
header declaration looks like this:
HReceived: by $j; $b
The word
by
is mandatory. It must be followed by the fully qualified, official name of the local machine. As you saw earlier when you ran
sendmail
with the
-d0.1
debugging switch, the fully qualified name was assigned to the
j
macro:
============ SYSTEM IDENTITY (after readcf) ============ (short domain name) $w = here (canonical domain name)$j
= here.us.edu note
The
Received:
header definition concludes with a semicolon, followed by the current date and time as stored in
$b
. The
b
macro contains the current date in ARPAnet format; that is, the day of the week, the month, the day, the time, the year, and the time zone.
These items in the
Received:
header form the minimum information required in this header.
Add the
From:
and
Received:
headers to the
client.cf
file. The new lines in
client.cf
will look like this:
O OldStyleHeaders=True O BlankSub=. # Replace unquoted spaces with a dot.# Headers
newHFrom: <$g> # Added only if missing
newHReceived: by $j; $b # Always added
new
Here, they follow the options that were added in the last chapter. As usual, comments have been included to clarify your intent. See
Chapter 31,
Defined Macros
, for a more detailed explanation of the
j
and
b
macros.
Now send mail to yourself just as you did at the end of the preceding chapter:
%./sendmail -Cclient.cf
you
Subject: testing
To:
you
testing
.
Retrieve the mail that you just sent, save it to a file, and look at what you saved. It will look something like this:
From [email protected] Fri Dec 13 05:47:47 1996 Return-Path: <[email protected]> Received: from here.us.edu ([email protected] [123.45.67.8]) by mail.us.edu (8.8.4/8.8.4) with ESMTP id FAA13451 for <you>; Fri, 13 Dec 1996 05:47:46 -0700 Date: Fri, 13 Dec 1996 05:47:46 -0700From: [email protected] (Your Full Name)
note Message-Id: <[email protected]>Received: by here.us.edu; Fri, 13 Dec 1996 05:47:44 -0700
note Subject: testing To: you testing
Notice that a new
Received:
header was added. This is the one just declared in the
client.cf
file. The two
Received:
headers form a trail that shows who first received the message and how it was passed from one machine to the other.
Also notice that the contents of the
From:
header have changed. Something has removed the angle brackets and added your full name. What happened was this:
On the hub machine the address in the envelope for the sender is taken from the RCPT message that the local machine sends during the SMTP conversation. That address is the value of
$g
with angle brackets added.
On the hub machine the address in the
From:
header is compared to the sender envelope address. The address in the
From:
header that
client.cf
supplied was the value of
$g
surrounded in angle brackets.
Whenever the address in the envelope for the sender and the address in the
From:
header are identical,
sendmail
removes the
From:
header and creates a new one. Thus
sendmail
on a correctly configured hub machine removes the
From:
header and creates a new one that includes your full name.
The definition of the
From:
header on a hub is more complex then that in the
client.cf
file. One possible definition might look like this:
From: $g $?x($x)$.
This is just like the local definition, but it has a macro
conditional
added. A macro conditional is simply an if-endif construction, where
$?
is the if and
$.
is the endif. The preceding definition, then, can be broken down like this:
$? if x the macro x contains a value ($x) add this to the definition $. endif
The macro
x
contains as its value the full name of the sender. If that full name is not known,
x
has no value and the full name is omitted. If
$x
does contain a value, the full name is added in parentheses. Macro conditionals are described in
Chapter 31
.