Contents:
Test the Configuration File
The Real Queue Directory
MX Records
Hub Accepts Mail for Client
Prevent the Daemon from Running
Install the client.cf File
Things to Try
In this chapter and the next, we tie up a few loose ends to install a client.cf file as the system configuration file.
Clearly, you won't want to install the client.cf file as the real sendmail.cf file until you've made sure it works properly. One of the better ways to test a new configuration file is to create a file of addresses for which you already know the correct outcome, then feed the contents of that file to sendmail in rule-testing mode:
/tryflags es /parse user@here /parse [email protected] /parse user@foo /parse foo!user /parse user
Each line begins with a special V8.7 rule-testing command.
[1]
The first line causes the tests that follow to parse the address
as an envelope sender (instead of the default envelope recipient).
The /parse
command causes each address to be rewritten
by rule sets 3 and 0 to select a delivery agent
and then by rule set 4 to clean up afterward.
The addresses listed that are humbly few but will suffice for
the needs of the client.cf file. No matter the form
of the address, each should be forwarded to the hub as is.
(The /parse
command is described in Section 38.5.5, "Parse an Address with /parse".)
[1] The same thing can be done in earlier versions, but with some difficulty. See a sample script in Section 38.8, "Batch Rule-Set Testing".
The way to test the client.cf file using this list looks like this:
%./sendmail -Cclient.cf -bt <
list
| grep ^mailer
Here, list
is the name of the file containing the
above list of rule tests and addresses. The output shows
that each will be passed as is to the hub:
mailer hub, host mailhost, user user@here mailer hub, host mailhost, user [email protected] mailer hub, host mailhost, user user@foo mailer hub, host mailhost, user here!user mailer hub, host mailhost, user user
Notice that mail to these addresses will be delivered by using the hub delivery
agent (mailer
). Also notice that each will be forwarded to
the hub machine (mailhost
) for delivery. Finally, note
that the user part will be the original address.
[2]
[2] This is the triple that we described in Section 9.2, "The RHS Triple", in which the RHS of rule set 0 returned the
mailer
with$#
, thehost
with$@
, and theuser
with$:
.
But why was the lone username in the last line not rewritten
to appear as though it was coming from the hub? Recall that
sender rewriting is done in the Hubset
rule set.
That rule set is called only by the S=
of the
delivery agent. To see Hubset
rewriting, you need to
run sendmail again, but this time use /try
instead of
/parse
:
[3]
[3] Under old versions of sendmail you must specify the rule sets by hand, for example,
3,Hubset
.
%./sendmail -Cclient.cf -bt
ADDRESS TEST MODE (ruleset 3 NOT automatically invoked) Enter <ruleset> <address> >/tryflags es
>/try hub user
rewrite: ruleset 3 input: user rewrite: ruleset 3 returns: user rewrite: ruleset 1 input: user rewrite: ruleset 1 returns: user rewrite: ruleset 199 input: user rewrite: ruleset 199 returns: user @ mail . us . edu rewrite: ruleset 4 input: user @ mail . us . edu rewrite: ruleset 4 returns: user @ mail . us . edu Rcode = 0, addr = [email protected]
Here, sendmail rewrites the lone username first
with rule set 3 (all addresses start with rule set 3), and then
with rule set 1 (all sender addresses pass through rule set 1).
The address is then rewritten by rule set Hubset
(which prints as 199 because it is a symbolic rule-set name).
As intended, a lone sender name has
the address of the hub machine appended to it.
(The rest of this /try
output is described in Section 38.5.6, "Try a Delivery Agent with /try".)
Further testing would be suggested if the output varied in unexpected ways. It might be necessary to run sendmail in rule-testing mode by hand, testing each rule and sequence of rules individually to find any mistakes in the client.cf file. If the client.cf file tests okay, you are now almost ready to install it as the official sendmail.cf file.