Table of Contents
=================

1.0: About Sun Sendmail 8.8
2.0: Debugging Sendmail 8.8
3.0: Common How Tos
4.0: Frequently Asked Questions
5.0: Patches
6.0: Bugs & RFEs
7.0: References

1.0 About Sun Sendmail 8.8


 1.0 Special patch README intructions 


                        SENDMAIL SPECIAL INSTRUCTIONS

Beginning with patch 105395-03 (Solaris 2.6) and 103594-16 (Solaris 2.5.1)
is upgraded from the old version  SMI-8.6 to the new version 8.8.8+Sun.  What
does this mean to you?  A lot if you are interested in using anti-spam,
security and other new features.  Or very little if you just want stability
and consistency.

Below you will find two sections.  "MIGRATION CHANGES" describes behavioral
changes in 8.8.8+Sun, and provides advice to system administrators in using
it.  "NEW FEATURES" lists the new features provided, and includes pointers
to additional information.


I. MIGRATION CHANGES

    1. Backwards compatibility

       There are many improvements in 8.8.8+Sun over SMI-8.6 (see below).
       New configuration files are provided which enable some of these new
       features; these are known as V7/Sun configuration files.  The old
       configuration files, known as V1/Sun, are still supported.

       Installing this patch will replace some of the old V1/Sun
       configuration files with new V7/Sun configuration files.  The old
       V1/Sun sendmail.cf will be renamed with a .old extension, and the
       new main.cf and subsidiary.cf files will be installed with a .new
       extension.  The old sendmail.cf can be used by restoring it.  Use
       of the new files, however, is strongly recommended.

    2. Hierarchy for building configuration files provided

       Modifying sendmail.cf directly is no longer necessary.  A new sub-
       directory, /usr/lib/mail, is provided, under which there is an
       infrastructure for building sendmail configuration files using the m4
       macro processor.  Full details are in /usr/lib/mail/README .  Note
       that the use of long option names has made sendmail.cf more human-
       readable, but it is still strongly recommended that the m4 macros
       be used instead of modifying the configuration files directly.

    3. Security

       Because of tightened security in 8.8.8+Sun, /etc/mail has been modified
       not to be group writable.  If certain other directories -- /etc, /var
       and /var/spool -- are group writable, warning messages to this effect
       will be displayed.


II. NEW FEATURES

New features available in 8.8.8+Sun

* Probably the most important set of new features are the user-visible
  changes, which are covered at:

        http://www.sendmail.org/sun-specific/migration+sun.html

  The sections covered are:

        * User-visible changes
                * owner- aliases
                * /etc/shells
                * DSNs
                * .forward.machine-name
                * NoRecipientAction
                * Tightened Security
                * Content-Length: header in messages sent to programs or files
                * Directory Permissions
        * Administrator-visible changes that may have a trickle effect
                * MaxAliasRecursion
                * Fully-qualified host names

* Another worthwhile document, which the above links to, is:

        http://www.sendmail.org/sun-specific/differences.html

  The sections cover the differences between:

        * SMI-8.6 and 8.8.8+Sun using the same V1/Sun configuration file
        * 8.8.8 and 8.8.8+Sun using the same V7/Berkeley configuration file
        * A V7/Sun configuration file and a V7/Berkeley configuration file
          when run by the same 8.8.8+Sun binary
        * Behavioral changes in 8.*+Sun when in V1/Sun Backwards
          Compatibility Mode
        * Default configuration files
                * Berkeley's generic-solaris2.cf vs. Solaris' main.cf
                * Solaris' main.cf vs. subsidiary.cf

* Other features added when going from SMI-8.6 to 8.8.8+Sun include:

        * Hierarchy for building configuration files

                http://www.sendmail.org/m4/readme.html

          covers this in detail; except for some mailers and non-Solaris
          OS types, almost all of this applies to our stuff as well.

        * A makemap binary is now shipped.

          This is need for some of the virtual-hosting and anti-spam
          configuration noted below.

        * Virtual hosting (8.8)

                http://www.sendmail.org/virtual-hosting.html

        * Anti-spam configurability (8.8)

                http://www.sendmail.org/antispam.html

        * Long option names (8.7)

          Though sendmail.cf is not supposed to be edited (see the m4 notes
          above), the options section is much more human-readable thanks to
          switching from single-character to long option names.

        * 8BITMIME support (8.7)

          Sendmail can deal with 8-bit message content properly.

        * Richer test mode syntax (8.7)


 1.1 /usr/lib/mail/README file 


                NEW SENDMAIL CONFIGURATION FILES

                Eric Allman <eric@CS.Berkeley.EDU>

                @(#)README      8.124 (Berkeley) 9/23/97


This document describes the sendmail configuration files being used
at Berkeley.  These use features in the new (R8) sendmail; they will
not work on other versions.

These configuration files are probably not as general as previous
versions, and don't handle as many of the weird cases automagically.
I was able to simplify them for two reasons.  First, the network
has become more consistent -- for example, at this point, everyone
on the internet is supposed to be running a name server, so hacks to
handle NIC-registered hosts can go away.  Second, I assumed that a
subdomain would be running SMTP internally -- UUCP is presumed to be
a long-haul protocol.  I realize that this is not universal, but it
does describe the vast majority of sites with which I am familiar,
including those outside the US.

Of course, the downside of this is that if you do live in a weird
world, things are going to get weirder for you.  I'm sorry about that,
but at the time we at Berkeley had a problem, and it seemed like the
right thing to do.

This package requires a post-V7 version of m4; if you are running the
4.2bsd, SysV.2, or 7th Edition version, I suggest finding a friend with
a newer version.  You can m4-expand on their system, then run locally.
SunOS's /usr/5bin/m4 or BSD-Net/2's m4 both work.  GNU m4 version 1.1
or later also works.  Unfortunately, I'm told that the M4 on BSDI 1.0
doesn't work -- you'll have to use a Net/2 or GNU version.  GNU m4 is
available from ftp://prep.ai.mit.edu/pub/gnu/m4-1.4.tar.gz (check for
the latest version).  EXCEPTIONS: DEC's m4 on Digital UNIX 4.x is broken
(3.x is fine).  Use GNU m4 on this platform.

IF YOU DON'T HAVE A BERKELEY MAKE, don't despair!  Just run
"m4 ../m4/cf.m4 foo.mc > foo.cf" -- that should be all you need.
There is also a fairly crude (but functional) Makefile.dist that works
on the old version of make.

To get started, you may want to look at tcpproto.mc (for TCP-only
sites), uucpproto.mc (for UUCP-only sites), and clientproto.mc (for
clusters of clients using a single mail host).  Others are versions
that we use at Berkeley, although not all are in current use.  For
example, ucbarpa has gone away, but I've left ucbarpa.mc in because
it demonstrates some interesting techniques.

I'm not pretending that this README describes everything that these
configuration files can do; clever people can probably tweak them
to great effect.  But it should get you started.

*******************************************************************
***  BE SURE YOU CUSTOMIZE THESE FILES!  They have some         ***
***  Berkeley-specific assumptions built in, such as the name   ***
***  of our UUCP-relay.  You'll want to create your own domain  ***
***  description, and use that in place of domain/Berkeley.m4.  ***
*******************************************************************


+--------------------------+
| INTRODUCTION AND EXAMPLE |
+--------------------------+

Configuration files are contained in the subdirectory "cf", with a
suffix ".mc".  They must be run through "m4" to produce a ".cf" file.
You must pre-load "cf.m4":

        m4 ${CFDIR}/m4/cf.m4 config.mc > config.cf

where ${CFDIR} is the root of the cf directory and config.mc is the
name of your configuration file.  If you are running a version of M4
that understands the __file__ builtin (versions of GNU m4 >= 0.75 do
this, but the versions distributed with 4.4BSD and derivatives do not)
or the -I flag (ditto), then ${CFDIR} can be in an arbitrary directory.
For "traditional" versions, ${CFDIR} ***MUST*** be "..", or you MUST
use -D_CF_DIR_=/path/to/cf/dir/ -- note the trailing slash!  For example:

        m4 -D_CF_DIR_=${CFDIR}/ ${CFDIR}/m4/cf.m4 config.mc > config.cf

Let's examine a typical .mc file:

        divert(-1)
        #
        # Copyright (c) 1983 Eric P. Allman
        # Copyright (c) 1988, 1993
        #       The Regents of the University of California.  All rights
reserve
d.
        #
        # Redistribution and use in source and binary forms, with or without
        # modification, are permitted provided that the following conditions
        # are met:
        # 1. Redistributions of source code must retain the above copyright
        #    notice, this list of conditions and the following disclaimer.
        # 2. Redistributions in binary form must reproduce the above copyright
        #    notice, this list of conditions and the following disclaimer in
        #    the documentation and/or other materials provided with the
        #    distribution.
        # 3. All advertising materials mentioning features or use of this
        #    software #    must display the following acknowledgement:
        #       This product includes software developed by the University of
        #       California, Berkeley and its contributors.
        # 4. Neither the name of the University nor the names of its
        #    contributors may be used to endorse or promote products derived
        #    from this software without specific prior written permission.
        #
        # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS''
        # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
        # THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
PARTICULAR
        # PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR
CONTRIBUTORS
        # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
        # OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
        # OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
        # BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
        # WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
        # OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
        # EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
        #

        #
        #  This is a Berkeley-specific configuration file for HP-UX 9.x.
        #  It applies only to the Computer Science Division at Berkeley,
        #  and should not be used elsewhere.   It is provided on the sendmail
        #  distribution as a sample only.  To create your own configuration
        #  file, create an appropriate domain file in ../domain, change the
        #  `DOMAIN' macro below to reference that file, and copy the result
        #  to a name of your own choosing.
        #
        divert(0)

The divert(-1) will delete the crud in the resulting output file.
The copyright notice can be replaced by whatever your lawyers require;
our lawyers require the one that I've included in my files.  A copyleft
is a copyright by another name.  The divert(0) restores regular output.

        VERSIONID(`<SCCS or RCS version id>')

VERSIONID is a macro that stuffs the version information into the
resulting file.  We use SCCS; you could use RCS, something else, or
omit it completely.  This is not the same as the version id included
in SMTP greeting messages -- this is defined in m4/version.m4.

        OSTYPE(hpux9)dnl

You must specify an OSTYPE to properly configure things such as the
pathname of the help and status files, the flags needed for the local
mailer, and other important things.  If you omit it, you will get an
error when you try to build the configuration.  Look at the ostype
directory for the list of known operating system types.

        DOMAIN(CS.Berkeley.EDU)dnl

This example is specific to the Computer Science Division at Berkeley.
You can use "DOMAIN(generic)" to get a sufficiently bland definition
that may well work for you, or you can create a customized domain
definition appropriate for your environment.

        MAILER(local)
        MAILER(smtp)

These describe the mailers used at the default CS site site.  The
local mailer is always included automatically.  Beware: MAILER
declarations should always be at the end of the configuration file,
and MAILER(smtp) should always precede MAILER(uucp).  The general
rules are that the order should be:

        VERSIONID
        OSTYPE
        DOMAIN
        FEATURE
        local macro definitions
        MAILER
        LOCAL_RULESET_*


+----------------------------+
| A BRIEF INTRODUCTION TO M4 |
+----------------------------+

Sendmail uses the M4 macro processor to ``compile'' the configuration
files.  The most important thing to know is that M4 is stream-based,
that is, it doesn't understand about lines.  For this reason, in some
places you may see the word ``dnl'', which standards for ``delete
through newline''; essentially, it deletes all characters starting
at the ``dnl'' up to and including the next newline character.  In
most cases sendmail uses this only to avoid lots of unnecessary
blank lines in the output.

Other important directives are define(A, B) which defines the macro
``A'' to have value ``B''.  Macros are expanded as they are read, so
one normally quotes both values to prevent expansion.  For example,

        define(`SMART_HOST', `smart.foo.com')

One word of warning:  M4 macros are expanded even in lines that appear
to be comments.  For example, if you have

        # See FEATURE(foo) above

it will not do what you expect, because the FEATURE(foo) will be
expanded.  This also applies to

        # And then define the $X macro to be the return address

because ``define'' is an M4 keyword.  If you want to use them, surround
them with directed quotes, `like this'.


+--------+
| OSTYPE |
+--------+

You MUST define an operating system environment, or the configuration
file build will puke.  There are several environments available; look
at the "ostype" directory for the current list.  This macro changes
things like the location of the alias file and queue directory.  Some
of these files are identical to one another.

It is IMPERATIVE that the OSTYPE occur before any MAILER definitions.
In general, the OSTYPE macro should go immediately after any version
information, and MAILER definitions should always go last.

Operating system definitions are usually easy to write.  They may define
the following variables (everything defaults, so an ostype file may be
empty).  Unfortunately, the list of configuration-supported systems is
not as broad as the list of source-supported systems, since many of
the source contributors do not include corresponding ostype files.

ALIAS_FILE              [/etc/aliases] The location of the text version
                        of the alias file(s).  It can be a comma-separated
                        list of names (but be sure you quote values with
                        commas in them -- for example, use
                                define(`ALIAS_FILE', `a,b')
                        to get "a" and "b" both listed as alias files;
                        otherwise the define() primitive only sees "a").
HELP_FILE               [/usr/lib/sendmail.hf] The name of the file
                        containing information printed in response to
                        the SMTP HELP command.
QUEUE_DIR               [/var/spool/mqueue] The directory containing
                        queue files.
STATUS_FILE             [/etc/sendmail.st] The file containing status
                        information.
LOCAL_MAILER_PATH       [/bin/mail] The program used to deliver local mail.
LOCAL_MAILER_FLAGS      [rmn] The flags used by the local mailer.  The
                        flags lsDFM are always included.
LOCAL_MAILER_ARGS       [mail -d $u] The arguments passed to deliver local
                        mail.
LOCAL_MAILER_MAX        [undefined] If defined, the maximum size of local
                        mail that you are willing to accept.
LOCAL_MAILER_CHARSET    [undefined] If defined, messages containing 8-bit data
                        that ARRIVE from an address that resolves to the
                        local mailer and which are converted to MIME will be
                        labelled with this character set.
LOCAL_SHELL_PATH        [/bin/sh] The shell used to deliver piped email.
LOCAL_SHELL_FLAGS       [eu] The flags used by the shell mailer.  The
                        flags lsDFM are always included.
LOCAL_SHELL_ARGS        [sh -c $u] The arguments passed to deliver "prog"
                        mail.
LOCAL_SHELL_DIR         [$z:/] The directory search path in which the
                        shell should run.
SMTP_MAILER_FLAGS       [undefined] Flags added to SMTP mailer.  Default
                        flags are `mDFMUX' for all SMTP-based mailers; the
                        "esmtp" mailer adds `a' and "smtp8" adds `8'.
SMTP_MAILER_MAX         [undefined] The maximum size of messages that will
                        be transported using the smtp, smtp8, or esmtp
                        mailers.
SMTP_MAILER_ARGS        [IPC $h] The arguments passed to the smtp mailer.
                        About the only reason you would want to change this
                        would be to change the default port.
ESMTP_MAILER_ARGS       [IPC $h] The arguments passed to the esmtp mailer.
SMTP8_MAILER_ARGS       [IPC $h] The arguments passed to the smtp8 mailer.
RELAY_MAILER_ARGS       [IPC $h] The arguments passed to the relay mailer.
SMTP_MAILER_CHARSET     [undefined] If defined, messages containing 8-bit data
                        that ARRIVE from an address that resolves to one of
                        the SMTP mailers and which are converted to MIME will
                        be labelled with this character set.
UUCP_MAILER_PATH        [/usr/bin/uux] The program used to send UUCP mail.
UUCP_MAILER_FLAGS       [undefined] Flags added to UUCP mailer.  Default
                        flags are `DFMhuU' (and `m' for uucp-new mailer,
                        minus `U' for uucp-dom mailer).
UUCP_MAILER_ARGS        [uux - -r -z -a$g -gC $h!rmail ($u)] The arguments
                        passed to the UUCP mailer.
UUCP_MAILER_MAX         [100000] The maximum size message accepted for
                        transmission by the UUCP mailers.
UUCP_MAILER_CHARSET     [undefined] If defined, messages containing 8-bit data
                        that ARRIVE from an address that resolves to one of
                        the UUCP mailers and which are converted to MIME will
                        be labelled with this character set.


+---------+
| DOMAINS |
+---------+

You will probably want to collect domain-dependent defines into one
file, referenced by the DOMAIN macro.  For example, our Berkeley
domain file includes definitions for several internal distinguished
hosts:

UUCP_RELAY      The host that will accept UUCP-addressed email.
                If not defined, all UUCP sites must be directly
                connected.
BITNET_RELAY    The host that will accept BITNET-addressed email.
                If not defined, the .BITNET pseudo-domain won't work.
DECNET_RELAY    The host that will accept DECNET-addressed email.
                If not defined, the .DECNET pseudo-domain and addresses
                of the form node::user will not work.
FAX_RELAY       The host that will accept mail to the .FAX pseudo-domain.
                The "fax" mailer overrides this value.
LOCAL_RELAY     DEPRECATED.  The site that will handle unqualified
                names -- that is, names with out an @domain extension.
                If not set, they are assumed to belong on this machine.
                This allows you to have a central site to store a
                company- or department-wide alias database.  This
                only works at small sites, and only with some user
                agents.
LUSER_RELAY     The site that will handle lusers -- that is, apparently
                local names that aren't local accounts or aliases.

Any of these can be either ``mailer:hostname'' (in which case the
mailer is the internal mailer name, such as ``uucp-new'' and the hostname
is the name of the host as appropriate for that mailer) or just a
``hostname'', in which case a default mailer type (usually ``relay'',
a variant on SMTP) is used.  WARNING: if you have a wildcard MX
record matching your domain, you probably want to define these to
have a trailing dot so that you won't get the mail diverted back
to yourself.

The domain file can also be used to define a domain name, if needed
(using "DD<domain>") and set certain site-wide features.  If all hosts
at your site masquerade behind one email name, you could also use
MASQUERADE_AS here.

You do not have to define a domain -- in particular, if you are a
single machine sitting off somewhere, it is probably more work than
it's worth.  This is just a mechanism for combining "domain dependent
knowledge" into one place.

+---------+
| MAILERS |
+---------+

There are fewer mailers supported in this version than the previous
version, owing mostly to a simpler world.  As a general rule, put the
MAILER definitions last in your .mc file, and always put MAILER(smtp)
before MAILER(uucp) -- several features and definitions will modify
the definition of mailers, and the smtp mailer modifies the UUCP
mailer.

local           The local and prog mailers.  You will almost always
                need these; the only exception is if you relay ALL
                your mail to another site.  This mailer is included
                automatically.

smtp            The Simple Mail Transport Protocol mailer.  This does
                not hide hosts behind a gateway or another other
                such hack; it assumes a world where everyone is
                running the name server.  This file actually defines
                four mailers: "smtp" for regular (old-style) SMTP to
                other servers, "esmtp" for extended SMTP to other
                servers, "smtp8" to do SMTP to other servers without
                converting 8-bit data to MIME (essentially, this is
                your statement that you know the other end is 8-bit
                clean even if it doesn't say so), and "relay" for
                transmission to our RELAY_HOST, LUSER_RELAY, or
                MAILER_HUB.

uucp            The Unix-to-Unix Copy Program mailer.  Actually, this
                defines two mailers, "uucp-old" (a.k.a. "uucp") and
                "uucp-new" (a.k.a. "suucp").  The latter is for when you
                know that the UUCP mailer at the other end can handle
                multiple recipients in one transfer.  If the smtp mailer
                is also included in your configuration, two other mailers
                ("uucp-dom" and "uucp-uudom") are also defined [warning:
                you MUST specify MAILER(smtp) before MAILER(uucp)].  When you
                include the uucp mailer, sendmail looks for all names in
                the $=U class and sends them to the uucp-old mailer; all
                names in the $=Y class are sent to uucp-new; and all
                names in the $=Z class are sent to uucp-uudom.  Note that
                this is a function of what version of rmail runs on
                the receiving end, and hence may be out of your control.
                See the section below describing UUCP mailers in more
                detail.

The local mailer accepts addresses of the form "user+detail", where
the "+detail" is not used for mailbox matching but is available
to certain local mail programs (in particular, see FEATURE(local_procmail)).
For example, "eric", "eric+sendmail", and "eric+sww" all indicate
the same user, but additional arguments <null>, "sendmail", and "sww"
may be provided for use in sorting mail.


+----------+
| FEATURES |
+----------+

Special features can be requested using the "FEATURE" macro.  For
example, the .mc line:

        FEATURE(use_cw_file)

tells sendmail that you want to have it read an /etc/sendmail.cw
file to get values for class $=w.  The FEATURE may contain a single
optional parameter -- for example:

        FEATURE(mailertable, dbm /usr/lib/mailertable)

Available features are:

use_cw_file     Read the file /etc/sendmail.cw file to get alternate
                names for this host.  This might be used if you were
                on a host that MXed for a dynamic set of other
                hosts.  If the set is static, just including the line
                "Cw<name1> <name2> ..." is probably superior.
                The actual filename can be overridden by redefining
                confCW_FILE.

use_ct_file     Read the file /etc/sendmail.ct file to get the names
                of users that will be ``trusted'', that is, able to
                set their envelope from address using -f without
                generating a warning message.
                The actual filename can be overridden by redefining
                confCT_FILE.

redirect        Reject all mail addressed to "address.REDIRECT" with
                a ``551 User not local; please try <address>'' message.
                If this is set, you can alias people who have left
                to their new address with ".REDIRECT" appended.

nouucp          Don't do anything special with UUCP addresses at all.

nocanonify      Don't pass addresses to $[ ... $] for canonification.
                This would generally only be used by sites that only
                act as mail gateways or which have user agents that do
                full canonification themselves.  You may also want to
                use "define(`confBIND_OPTS',`-DNSRCH -DEFNAMES')" to
                turn off the usual resolver options that do a similar
                thing.

stickyhost      If set, email sent to "user@local.host" are marked
                as "sticky" -- that is, the local addresses aren't
                matched against UDB and don't go through ruleset 5.
                This is used if you want a set up where "user" is
                not necessarily the same as "user@local.host", e.g.,
                to make a distinct domain-wide namespace.  Prior to
                8.7 this was the default, and notsticky was used to
                turn this off.

mailertable     Include a "mailer table" which can be used to override
                routing for particular domains.  The argument of the
                FEATURE may be the key definition.  If none is specified,
                the definition used is:
                        hash -o /etc/mailertable
                Keys in this database are fully qualified domain names
                or partial domains preceded by a dot -- for example,
                "vangogh.CS.Berkeley.EDU" or ".CS.Berkeley.EDU".
                Values must be of the form:
                        mailer:domain
                where "mailer" is the internal mailer name, and "domain"
                is where to send the message.  These maps are not
                reflected into the message header.

domaintable     Include a "domain table" which can be used to provide
                domain name mapping.  Use of this should really be
                limited to your own domains.  It may be useful if you
                change names (e.g., your company changes names from
                oldname.com to newname.com).  The argument of the
                FEATURE may be the key definition.  If none is specified,
                the definition used is:
                        hash -o /etc/domaintable
                The key in this table is the domain name; the value is
                the new (fully qualified) domain.  Anything in the
                domaintable is reflected into headers; that is, this
                is done in ruleset 3.

bitdomain       Look up bitnet hosts in a table to try to turn them into
                internet addresses.  The table can be built using the
                bitdomain program contributed by John Gardiner Myers.
                The argument of the FEATURE may be the key definition; if
                none is specified, the definition used is:
                        hash -o /etc/bitdomain.db
                Keys are the bitnet hostname; values are the corresponding
                internet hostname.

uucpdomain      Similar feature for UUCP hosts.  The default map definition
                is:
                        hash -o /etc/uudomain.db
                At the moment there is no automagic tool to build this
                database.

always_add_domain
                Include the local host domain even on locally delivered
                mail.  Normally it is not added on unqualified names.
                However, if you use a shared message store but do not use
                the same user name space everywhere, you may need the host
                name on local names.

allmasquerade   If masquerading is enabled (using MASQUERADE_AS), this
                feature will cause recipient addresses to also masquerade
                as being from the masquerade host.  Normally they get
                the local hostname.  Although this may be right for
                ordinary users, it can break local aliases.  For example,
                if you send to "localalias", the originating sendmail will
                find that alias and send to all members, but send the
                message with "To: localalias@masqueradehost".  Since that
                alias likely does not exist, replies will fail.  Use this
                feature ONLY if you can guarantee that the ENTIRE
                namespace on your masquerade host supersets all the
                local entries.

limited_masquerade
                Normally, any hosts listed in $=w are masqueraded.  If this
                feature is given, only the hosts listed in $=M are masqueraded.
                This is useful if you have several domains with disjoint
                namespaces hosted on the same machine.

masquerade_entire_domain
                If masquerading is enabled (using MASQUERADE_AS) and 
                MASQUERADE_DOMAIN (see below) is set, this feature will
                cause addresses to be rewritten such that the masquerading
                domains are actually entire domains to be hidden.  All
                hosts within the masquerading domains will be rewritten
                to the masquerade name (used in MASQUERADE_AS).  For example,
                if you have:

                        MASQUERADE_AS(masq.com)
                        MASQUERADE_DOMAIN(foo.org)
                        MASQUERADE_DOMAIN(bar.com)

                then *foo.org and *bar.com are converted to masq.com.  Without
                this feature, only foo.org and bar.com are masqueraded.

                    NOTE: only domains within your jurisdiction and
                    current hierarchy should be masqueraded using this.

genericstable   This feature will cause certain addresses originating in the
                local domain or a domain listed in $=G to be looked up in a
                map and turned into another ("generic") form, which can change
                both the domain name and the user name.  This is similar to
                the userdb functionality.  The same types of addresses as for
                masquerading are looked up, i.e. only header sender addresses
                unless the allmasquerade and/or masquerade_envelope features
                are given.  The addresses must be in the list of names given
                by the macros GENERICS_DOMAIN or GENERICS_DOMAIN_FILE
                (analogously to MASQUERADE_DOMAIN and MASQUERADE_DOMAIN_FILE,
                see below).

                The argument of FEATURE(genericstable) may be the map
                defintion; the default map definition is:

                        hash -o /etc/genericstable

                The key for this table is either the full address or the
                unqualified username (the former is tried first); the
                value is the new user address.  If the new user address does
                not include a domain, $j is used.  Note that the address
                being looked up must be fully qualified.  For local mail, it
                is necessary to use FEATURE(always_add_domain) for the
                addresses to be qualified.

virtusertable   A domain-specific form of aliasing, allowing multiple
                virtual domains to be hosted on one machine.  For example,
                if the virtuser table contained:

                        info@foo.com    foo-info
                        info@bar.com    bar-info
                        @baz.org        jane@elsewhere.net

                then mail addressed to info@foo.com will be sent to the
                address foo-info, mail addressed to info@bar.com will be
                delivered to bar-info, and mail addressed to anyone at
                baz.org will be sent to jane@elsewhere.net.  The username
                from the original address is passed as %%1 allowing:

                        @foo.org        %%1@elsewhere.com

                meaning someone@foo.org will be sent to someone@elsewhere.com.

                All the host names on the left hand side (foo.com, bar.com,
                and baz.org) must be in $=w.  The default map definition is:

                        hash -o /etc/virtusertable

                A new definition can be specified as the second argument of
                the FEATURE macro, such as

                        FEATURE(virtusertable, dbm -o /etc/mail/virtusers)

nodns           We aren't running DNS at our site (for example,
                we are UUCP-only connected).  It's hard to consider
                this a "feature", but hey, it had to go somewhere.
                Actually, as of 8.7 this is a no-op -- remove "dns" from
                the hosts service switch entry instead.

nullclient      This is a special case -- it creates a stripped down
                configuration file containing nothing but support for
                forwarding all mail to a central hub via a local
                SMTP-based network.  The argument is the name of that
                hub.

                The only other feature that should be used in conjunction
                with this one is "nocanonify" (this causes addresses to
                be sent unqualified via the SMTP connection; normally
                they are qualifed with the masquerade name, which
                defaults to the name of the hub machine).  No mailers
                should be defined.  No aliasing or forwarding is done.

bestmx_is_local Accept mail as though locally addressed for any host that
                lists us as the best possible MX record.  This generates
                additional DNS traffic, but should be OK for low to
                medium traffic hosts.  THIS FEATURE IS FUNDAMENTALLY
                INCOMPATIBLE WITH WILDCARD MX RECORDS!!!  If you have
                a wildcard MX record that matches your domain, you
                cannot use this feature.

smrsh           Use the SendMail Restricted SHell (smrsh) provided
                with the distribution instead of /bin/sh for mailing
                to programs.  This improves the ability of the local
                system administrator to control what gets run via
                e-mail.  If an argument is provided it is used as the
                pathname to smrsh; otherwise, /usr/local/etc/smrsh is
                assumed.


+--------------------+
| USING UUCP MAILERS |
+--------------------+

It's hard to get UUCP mailers right because of the extremely ad hoc
nature of UUCP addressing.  These config files are really designed
for domain-based addressing, even for UUCP sites.

There are four UUCP mailers available.  The choice of which one to
use is partly a matter of local preferences and what is running at
the other end of your UUCP connection.  Unlike good protocols that
define what will go over the wire, UUCP uses the policy that you
should do what is right for the other end; if they change, you have
to change.  This makes it hard to do the right thing, and discourages
people from updating their software.  In general, if you can avoid
UUCP, please do.

The major choice is whether to go for a domainized scheme or a
non-domainized scheme.  This depends entirely on what the other
end will recognize.  If at all possible, you should encourage the
other end to go to a domain-based system -- non-domainized addresses
don't work entirely properly.

The four mailers are:

    uucp-old (obsolete name: "uucp")
        This is the oldest, the worst (but the closest to UUCP) way of
        sending messages accros UUCP connections.  It does bangify
        everything and prepends $U (your UUCP name) to the sender's
        address (which can already be a bang path itself).  It can
        only send to one address at a time, so it spends a lot of
        time copying duplicates of messages.  Avoid this if at all
        possible.

    uucp-new (obsolete name: "suucp")
        The same as above, except that it assumes that in one rmail
        command you can specify several recipients.  It still has a
        lot of other problems.

    uucp-dom
        This UUCP mailer keeps everything as domain addresses.
        Basically, it uses the SMTP mailer rewriting rules.  This mailer
        is only included if MAILER(smtp) is also specified.

        Unfortunately, a lot of UUCP mailer transport agents require
        bangified addresses in the envelope, although you can use
        domain-based addresses in the message header.  (The envelope
        shows up as the From_ line on UNIX mail.)  So....

    uucp-uudom
        This is a cross between uucp-new (for the envelope addresses)
        and uucp-dom (for the header addresses).  It bangifies the
        envelope sender (From_ line in messages) without adding the
        local hostname, unless there is no host name on the address
        at all (e.g., "wolf") or the host component is a UUCP host name
        instead of a domain name ("somehost!wolf" instead of
        "some.dom.ain!wolf").  This is also included only if MAILER(smtp)
        is also specified.

Examples:

We are on host grasp.insa-lyon.fr (UUCP host name "grasp").  The
following summarizes the sender rewriting for various mailers.

Mailer          sender          rewriting in the envelope
------          ------          -------------------------
uucp-{old,new}  wolf            grasp!wolf
uucp-dom        wolf            wolf@grasp.insa-lyon.fr
uucp-uudom      wolf            grasp.insa-lyon.fr!wolf

uucp-{old,new}  wolf@fr.net     grasp!fr.net!wolf
uucp-dom        wolf@fr.net     wolf@fr.net
uucp-uudom      wolf@fr.net     fr.net!wolf

uucp-{old,new}  somehost!wolf   grasp!somehost!wolf
uucp-dom        somehost!wolf   somehost!wolf@grasp.insa-lyon.fr
uucp-uudom      somehost!wolf   grasp.insa-lyon.fr!somehost!wolf

If you are using one of the domainized UUCP mailers, you really want
to convert all UUCP addresses to domain format -- otherwise, it will
do it for you (and probably not the way you expected).  For example,
if you have the address foo!bar!baz (and you are not sending to foo),
the heuristics will add the @uucp.relay.name or @local.host.name to
this address.  However, if you map foo to foo.host.name first, it
will not add the local hostname.  You can do this using the uucpdomain
feature.


+-------------------+
| TWEAKING RULESETS |
+-------------------+

For more complex configurations, you can define special rules.
The macro LOCAL_RULE_3 introduces rules that are used in canonicalizing
the names.  Any modifications made here are reflected in the header.

A common use is to convert old UUCP addreses to SMTP addresses using
the UUCPSMTP macro.  For example:

        LOCAL_RULE_3
        UUCPSMTP(decvax,        decvax.dec.com)
        UUCPSMTP(research,      research.att.com)

will cause addresses of the form "decvax!user" and "research!user"
to be converted to "user@decvax.dec.com" and "user@research.att.com"
respectively.

This could also be used to look up hosts in a database map:

        LOCAL_RULE_3
        R$* < @ $+ > $*         $: $1 < @ $(hostmap $2 $) > $3

This map would be defined in the LOCAL_CONFIG portion, as shown below.

Similarly, LOCAL_RULE_0 can be used to introduce new parsing rules.
For example, new rules are needed to parse hostnames that you accept
via MX records.  For example, you might have:

        LOCAL_RULE_0
        R$+ <@ host.dom.ain.>   $#uucp $@ cnmat $: $1 < @ host.dom.ain.>

You would use this if you had installed an MX record for cnmat.Berkeley.EDU
pointing at this host; this rule catches the message and forwards it on
using UUCP.

You can also tweak rulesets 1 and 2 using LOCAL_RULE_1 and LOCAL_RULE_2.
These rulesets are normally empty.

A similar macro is LOCAL_CONFIG.  This introduces lines added after the
boilerplate option setting but before rulesets, and can be used to
declare local database maps or whatever.  For example:

        LOCAL_CONFIG
        Khostmap hash /etc/hostmap.db
        Kyplocal nis -m hosts.byname


+---------------------------+
| MASQUERADING AND RELAYING |
+---------------------------+

You can have your host masquerade as another using

        MASQUERADE_AS(host.domain)

This causes mail being sent to be labeled as coming from the
indicated host.domain, rather than $j.  One normally masquerades as
one of one's own subdomains (for example, it's unlikely that I would
choose to masquerade as an MIT site).  This behaviour is modified by
a plethora of FEATUREs; in particular, see masquerade_envelope,
allmasquerade, limited_masquerade, and masquerade_entire_domain.

The masquerade name is not normally canonified, so it is important
that it be your One True Name, that is, fully qualified and not a
CNAME.  However, if you use a CNAME, the receiving side may canonify
it for you, so don't think you can cheat CNAME mapping this way.

Normally the only addresses that are masqueraded are those that come
from this host (that is, are either unqualified or in $=w, the list
of local domain names).  You can augment this list using

        MASQUERADE_DOMAIN(otherhost.domain)

The effect of this is that although mail to user@otherhost.domain
will not be delivered locally, any mail including any user@otherhost.domain
will, when relayed, be rewritten to have the MASQUERADE_AS address.
This can be a space-separated list of names.

If these names are in a file, you can use

        MASQUERADE_DOMAIN_FILE(filename)

to read the list of names from the indicated file.

Normally only header addresses are masqueraded.  If you want to
masquerade the envelope as well, use

        FEATURE(masquerade_envelope)

There are always users that need to be "exposed" -- that is, their
internal site name should be displayed instead of the masquerade name.
Root is an example.  You can add users to this list using

        EXPOSED_USER(usernames)

This adds users to class E; you could also use something like

        FE/etc/sendmail.cE

You can also arrange to relay all unqualified names (that is, names
without @host) to a relay host.  For example, if you have a central
email server, you might relay to that host so that users don't have
to have .forward files or aliases.  You can do this using

        define(`LOCAL_RELAY', mailer:hostname)

The ``mailer:'' can be omitted, in which case the mailer defaults to
"relay".  There are some user names that you don't want relayed, perhaps
because of local aliases.  A common example is root, which may be
locally aliased.  You can add entries to this list using

        LOCAL_USER(usernames)

This adds users to class L; you could also use something like

        FL/etc/sendmail.cL

If you want all incoming mail sent to a centralized hub, as for a
shared /var/spool/mail scheme, use

        define(`MAIL_HUB', mailer:hostname)

Again, ``mailer:'' defaults to "relay".  If you define both LOCAL_RELAY
and MAIL_HUB _AND_ you have FEATURE(stickyhost), unqualified names will
be sent to the LOCAL_RELAY and other local names will be sent to MAIL_HUB.
Names in $=L will be delivered locally, so you MUST have aliases or
.forward files for them.

For example, if you are on machine mastodon.CS.Berkeley.EDU and you have
FEATURE(stickyhost), the following combinations of settings will have the
indicated effects:

email sent to....       eric                      eric@mastodon.CS.Berkeley.EDU

LOCAL_RELAY set to      mail.CS.Berkeley.EDU      (delivered locally)
mail.CS.Berkeley.EDU      (no local aliasing)       (aliasing done)

MAIL_HUB set to         mammoth.CS.Berkeley.EDU   mammoth.CS.Berkeley.EDU
mammoth.CS.Berkeley.EDU   (aliasing done)           (aliasing done)

Both LOCAL_RELAY and    mail.CS.Berkeley.EDU      mammoth.CS.Berkeley.EDU
MAIL_HUB set as above     (no local aliasing)       (aliasing done)

If you do not have FEATURE(stickyhost) set, then LOCAL_RELAY and
MAIL_HUB act identically, with MAIL_HUB taking precedence.

If you want all outgoing mail to go to a central relay site, define
SMART_HOST as well.  Briefly:

        LOCAL_RELAY applies to unqualifed names (e.g., "eric").
        MAIL_HUB applies to names qualified with the name of the
                local host (e.g., "eric@mastodon.CS.Berkeley.EDU").
        SMART_HOST applies to names qualified with other hosts.

However, beware that other relays (e.g., UUCP_RELAY, BITNET_RELAY,
DECNET_RELAY, and FAX_RELAY) take precedence over SMART_HOST, so if you
really want absolutely everything to go to a single central site you will
need to unset all the other relays -- or better yet, find or build a
minimal config file that does this.

For duplicate suppression to work properly, the host name is best
specified with a terminal dot:

        define(`MAIL_HUB', `host.domain.')
              note the trailing dot ---^


+--------------------------------+
| ADDING NEW MAILERS OR RULESETS |
+--------------------------------+

Sometimes you may need to add entirely new mailers or rulesets.  They
should be introduced with the constructs MAILER_DEFINITIONS and
LOCAL_RULESETS respectively.  For example:

        MAILER_DEFINITIONS
        Mmymailer, ...
        ...

        LOCAL_RULESETS
        Scheck_relay
        ...


+-------------------------------+
| NON-SMTP BASED CONFIGURATIONS |
+-------------------------------+

These configuration files are designed primarily for use by SMTP-based
sites.  I don't pretend that they are well tuned for UUCP-only or
UUCP-primarily nodes (the latter is defined as a small local net
connected to the rest of the world via UUCP).  However, there is one
hook to handle some special cases.

You can define a ``smart host'' that understands a richer address syntax
using:

        define(`SMART_HOST', mailer:hostname)

In this case, the ``mailer:'' defaults to "relay".  Any messages that
can't be handled using the usual UUCP rules are passed to this host.

If you are on a local SMTP-based net that connects to the outside
world via UUCP, you can use LOCAL_NET_CONFIG to add appropriate rules.
For example:

        define(`SMART_HOST', suucp:uunet)
        LOCAL_NET_CONFIG
        R$* < @ $* .$m. > $*    $#smtp $@ $2.$m. $: $1 < @ $2.$m. > $3

This will cause all names that end in your domain name ($m) via
SMTP; anything else will be sent via suucp (smart UUCP) to uunet.
If you have FEATURE(nocanonify), you may need to omit the dots after
the $m.  If you are running a local DNS inside your domain which is
not otherwise connected to the outside world, you probably want to
use:

        define(`SMART_HOST', smtp:fire.wall.com)
        LOCAL_NET_CONFIG
        R$* < @ $* . > $*       $#smtp $@ $2. $: $1 < @ $2. > $3

That is, send directly only to things you found in your DNS lookup;
anything else goes through SMART_HOST.


+-----------+
| WHO AM I? |
+-----------+

Normally, the $j macro is automatically defined to be your fully
qualified domain name (FQDN).  Sendmail does this by getting your
host name using gethostname and then calling gethostbyname on the
result.  For example, in some environments gethostname returns
only the root of the host name (such as "foo"); gethostbyname is
supposed to return the FQDN ("foo.bar.com").  In some (fairly rare)
cases, gethostbyname may fail to return the FQDN.  In this case
you MUST define confDOMAIN_NAME to be your fully qualified domain
name.  This is usually done using:

        Dmbar.com
        define(`confDOMAIN_NAME', `$w.$m')dnl


+--------------------+
| USING MAILERTABLES |
+--------------------+

To use FEATURE(mailertable), you will have to create an external
database containing the routing information for various domains.
For example, a mailertable file in text format might be:

        .my.domain              xnet:%%1.my.domain
        uuhost1.my.domain       suucp:uuhost1
        .bitnet                 smtp:relay.bit.net

This should normally be stored in /etc/mailertable.  The actual
database version of the mailertable is built using:

        makemap hash /etc/mailertable.db < /etc/mailertable

The semantics are simple.  Any LHS entry that does not begin with
a dot matches the full host name indicated.  LHS entries beginning
with a dot match anything ending with that domain name -- that is,
they can be thought of as having a leading "*" wildcard.  Matching
is done in order of most-to-least qualified -- for example, even
though ".my.domain" is listed first in the above example, an entry
of "uuhost1.my.domain" will match the second entry since it is
more explicit.

The RHS should always be a "mailer:host" pair.  The mailer is the
configuration name of a mailer (that is, an `M' line in the
sendmail.cf file).  The "host" will be the hostname passed to
that mailer.  In domain-based matches (that is, those with leading
dots) the "%%1" may be used to interpolate the wildcarded part of
the host name.  For example, the first line above sends everything
addressed to "anything.my.domain" to that same host name, but using
the (presumably experimental) xnet mailer.

In some cases you may want to temporarily turn off MX records,
particularly on gateways.  For example, you may want to MX
everything in a domain to one machine that then forwards it
directly.  To do this, you might use the DNS configuration:

        *.domain.       IN      MX      0       relay.machine

and on relay.machine use the mailertable:

        .domain         smtp:[gateway.domain]

The [square brackets] turn off MX records for this host only.
If you didn't do this, the mailertable would use the MX record
again, which would give you an MX loop.


+--------------------------------+
| USING USERDB TO MAP FULL NAMES |
+--------------------------------+

The user database was not originally intended for mapping full names
to login names (e.g., Eric.Allman => eric), but some people are using
it that way.  (I would recommend that you set up aliases for this
purpose instead -- since you can specify multiple alias files, this
is fairly easy.)  The intent was to locate the default maildrop at
a site, but allow you to override this by sending to a specific host.

If you decide to set up the user database in this fashion, it is
imperative that you not use FEATURE(stickyhost) -- otherwise,
e-mail sent to Full.Name@local.host.name will be rejected.

To build the internal form of the user database, use:

        makemap btree /usr/data/base.db < /usr/data/base.txt

As a general rule, I am adamantly opposed to using full names as
e-mail addresses, since they are not in any sense unique.  For example,
the Unix software-development community has two Andy Tannenbaums,
at least two well-known Peter Deutsches, and at one time Bell Labs
had two Stephen R. Bournes with offices along the same hallway.
Which one will be forced to suffer the indignity of being
Stephen_R_Bourne_2?  The less famous of the two, or the one that
was hired later?

Finger should handle full names (and be fuzzy).  Mail should use
handles, and not be fuzzy.  [Not that I expect anyone to pay any
attention to my opinions.]


+--------------------------------+
| MISCELLANEOUS SPECIAL FEATURES |
+--------------------------------+

Plussed users
        Sometimes it is convenient to merge configuration on a
        centralized mail machine, for example, to forward all
        root mail to a mail server.  In this case it might be
        useful to be able to treat the root addresses as a class
        of addresses with subtle differences.  You can do this
        using plussed users.  For example, a client might include
        the alias:

                root:  root+client1@server

        On the server, this will match an alias for "root+client1".
        If that is not found, the alias "root+*" will be tried,
        then "root".

LDAP
        For notes on use LDAP in sendmail, see
        http://www-leland.stanford.edu/~bbense/Inst.html



+----------------+
| SECURITY NOTES |
+----------------+

A lot of sendmail security comes down to you.  Sendmail 8 is much
more careful about checking for security problems than previous
versions, but there are some things that you still need to watch
for.  In particular:

* Make sure the aliases file isn't writable except by trusted
  system personnel.  This includes both the text and database
  version.

* Make sure that other files that sendmail reads, such as the
  mailertable, are only writable by trusted system personnel.

* The queue directory should not be world writable PARTICULARLY
  if your system allows "file giveaways" (that is, if a non-root
  user can chown any file they own to any other user).

* If your system allows file giveaways, DO NOT create a publically
  writable directory for forward files.  This will allow anyone
  to steal anyone else's e-mail.  Instead, create a script that
  copies the .forward file from users' home directories once a
  night (if you want the non-NFS-mounted forward directory).

* If your system allows file giveaways, you'll find that
  sendmail is much less trusting of :include: files -- in
  particular, you'll have to have /SENDMAIL/ANY/SHELL/ in
  /etc/shells before they will be trusted (that is, before
  files and programs listed in them will be honored).

In general, file giveaways are a mistake -- if you can turn them
off I recommend you do so.


+--------------------------------+
| TWEAKING CONFIGURATION OPTIONS |
+--------------------------------+

There are a large number of configuration options that don't normally
need to be changed.  However, if you feel you need to tweak them, you
can define the following M4 variables.  This list is shown in four
columns:  the name you define, the default value for that definition,
the option or macro that is affected (either Ox for an option or Dx
for a macro), and a brief description.  Greater detail of the semantics
can be found in the Installation and Operations Guide.

Some options are likely to be deprecated in future versions -- that is,
the option is only included to provide back-compatibility.  These are
marked with "*".

Remember that these options are M4 variables, and hence may need to
be quoted.  In particular, arguments with commas will usually have to
be ``double quoted, like this phrase'' to avoid having the comma
confuse things.  This is common for alias file definitions and for
the read timeout.

M4 Variable Name        Configuration   Description & [Default]
================        =============   =======================
confMAILER_NAME         $n macro        [MAILER-DAEMON] The sender name used
                                        for internally generated outgoing
                                        messages.
confDOMAIN_NAME         $j macro        If defined, sets $j.  This should
                                        only be done if your system cannot
                                        determine your local domain name,
                                        and then it should be set to
                                        $w.Foo.COM, where Foo.COM is your
                                        domain name.
confCF_VERSION          $Z macro        If defined, this is appended to the
                                        configuration version name.
confFROM_HEADER         From:           [$?x$x <$g>$|$g$.] The format of an 
                                        internally generated From: address.
confRECEIVED_HEADER     Received:
                [$?sfrom $s $.$?_($?s$|from $.$_)
                        $.by $j ($v/$Z)$?r with $r$. id $i$?u
                        for $u; $|;
                        $.$b]
                                        The format of the Received: header
                                        in messages passed through this host.
                                        It is unwise to try to change this.
confCW_FILE             Fw class        [/etc/sendmail.cw] Name of file used
                                        to get the local additions to the $=w
                                        (local host names) class.
confCT_FILE             Ft class        [/etc/sendmail.ct] Name of file used
                                        to get the local additions to the $=t
                                        (trusted users) class.
confTRUSTED_USERS       Ct class        [no default] Names of users to add to
                                        the list of trusted users.  This list
                                        always includes root, uucp, and daemon.
                                        See also FEATURE(use_ct_file).
confSMTP_MAILER         -               [esmtp] The mailer name used when
                                        SMTP connectivity is required.
                                        One of "smtp", "smtp8", or "esmtp".
confUUCP_MAILER         -               [uucp-old] The mailer to be used by
                                        default for bang-format recipient
                                        addresses.  See also discussion of
                                        $=U, $=Y, and $=Z in the MAILER(uucp)
                                        section.
confLOCAL_MAILER        -               [local] The mailer name used when
                                        local connectivity is required.
                                        Almost always "local".
confRELAY_MAILER        -               [relay] The default mailer name used
                                        for relaying any mail (e.g., to a
                                        BITNET_RELAY, a SMART_HOST, or
                                        whatever).  This can reasonably be
                                        "uucp-new" if you are on a
                                        UUCP-connected site.
confSEVEN_BIT_INPUT     SevenBitInput   [False] Force input to seven bits?
confEIGHT_BIT_HANDLING  EightBitMode    [pass8] 8-bit data handling
confALIAS_WAIT          AliasWait       [10m] Time to wait for alias file
                                        rebuild until you get bored and
                                        decide that the apparently pending
                                        rebuild failed.
confMIN_FREE_BLOCKS     MinFreeBlocks   [100] Minimum number of free blocks on
                                        queue filesystem to accept SMTP mail.
                                        (Prior to 8.7 this was minfree/maxsize,
                                        where minfree was the number of free
                                        blocks and maxsize was the maximum
                                        message size.  Use confMAX_MESSAGE_SIZE
                                        for the second value now.)
confMAX_MESSAGE_SIZE    MaxMessageSize  [infinite] The maximum size of messages
                                        that will be accepted (in bytes).
confBLANK_SUB           BlankSub        [.] Blank (space) substitution
                                        character.
confCON_EXPENSIVE       HoldExpensive   [False] Avoid connecting immediately
                                        to mailers marked expensive?
confCHECKPOINT_INTERVAL CheckpointInterval
                                        [10] Checkpoint queue files every N
                                        recipients.
confDELIVERY_MODE       DeliveryMode    [background] Default delivery mode.
confAUTO_REBUILD        AutoRebuildAliases
                                        [False] Automatically rebuild alias
                                        file if needed.
confERROR_MODE          ErrorMode       [print] Error message mode.
confERROR_MESSAGE       ErrorHeader     [undefined] Error message header/file.
confSAVE_FROM_LINES     SafeFromLine    Save extra leading From_ lines.
confTEMP_FILE_MODE      TempFileMode    [0600] Temporary file mode.
confMATCH_GECOS         MatchGECOS      [True] Match GECOS field.
confMAX_HOP             MaxHopCount     [25] Maximum hop count.
confIGNORE_DOTS*        IgnoreDots      [False; always False in -bs or -bd
mode]
                                        Ignore dot as terminator for incoming
                                        messages?
confBIND_OPTS           ResolverOptions [undefined] Default options for DNS
                                        resolver.
confMIME_FORMAT_ERRORS* SendMimeErrors  [True] Send error messages as MIME-
                                        encapsulated messages per RFC 1344.
confFORWARD_PATH        ForwardPath     [$z/.forward.$w:$z/.forward]
                                        The colon-separated list of places to
                                        search for .forward files.  N.B.: see
                                        the Security Notes section.
confMCI_CACHE_SIZE      ConnectionCacheSize
                                        [2] Size of open connection cache.
confMCI_CACHE_TIMEOUT   ConnectionCacheTimeout
                                        [5m] Open connection cache timeout.
confHOST_STATUS_DIRECTORY HostStatusDirectory
                                        [undefined] If set, host status is kept
                                        on disk between sendmail runs in the
                                        named directory tree.  This need not be
                                        a full pathname, in which case it is
                                        interpreted relative to the queue
                                        directory.
confSINGLE_THREAD_DELIVERY  SingleThreadDelivery
                                        [False] If this option and the
                                        HostStatusDirectory option are both
                                        set, single thread deliveries to other
                                        hosts.  That is, don't allow any two
                                        sendmails on this host to connect
                                        simultaneously to any other single
                                        host.  This can slow down delivery in
                                        some cases, in particular since a
                                        cached but otherwise idle connection
                                        to a host will prevent other sendmails
                                        from connecting to the other host.
confUSE_ERRORS_TO*      UserErrorsTo    [False] Use the Errors-To: header to
                                        deliver error messages.  This should
                                        not be necessary because of general
                                        acceptance of the envelope/header
                                        distinction.
confLOG_LEVEL           LogLevel        [9] Log level.
confME_TOO              MeToo           [False] Include sender in group
                                        expansions.
confCHECK_ALIASES       CheckAliases    [False] Check RHS of aliases when
                                        running newaliases.  Since this does
                                        DNS lookups on every address, it can
                                        slow down the alias rebuild process
                                        considerably on large alias files.
confOLD_STYLE_HEADERS*  OldStyleHeaders [True] Assume that headers without
                                        special chars are old style.
confDAEMON_OPTIONS      DaemonPortOptions
                                        [none] SMTP daemon options.
confPRIVACY_FLAGS       PrivacyOptions  [authwarnings] Privacy flags.
confCOPY_ERRORS_TO      PostmasterCopy  [undefined] Address for additional
                                        copies of all error messages.
confQUEUE_FACTOR        QueueFactor     [600000] Slope of queue-only function.
confDONT_PRUNE_ROUTES   DontPruneRoutes [False] Don't prune down route-addr
                                        syntax addresses to the minimum
                                        possible.
confSAFE_QUEUE*         SuperSafe       [True] Commit all messages to disk
                                        before forking.
confTO_INITIAL          Timeout.initial [5m] The timeout waiting for a response
                                        on the initial connect.
confTO_CONNECT          Timeout.connect [0] The timeout waiting for an initial
                                        connect() to complete.  This can only
                                        shorten connection timeouts; the kernel
                                        silently enforces an absolute maximum
                                        (which varies depending on the system).
confTO_ICONNECT         Timeout.iconnect
                                        [undefined] Like Timeout.connect, but
                                        applies only to the very first attempt
                                        to connect to a host in a message.
                                        This allows a single very fast pass
                                        followed by more careful delivery
                                        attempts in the future.
confTO_HELO             Timeout.helo    [5m] The timeout waiting for a response
                                        to a HELO or EHLO command.
confTO_MAIL             Timeout.mail    [10m] The timeout waiting for a
                                        response to the MAIL command.
confTO_RCPT             Timeout.rcpt    [1h] The timeout waiting for a response
                                        to the RCPT command.
confTO_DATAINIT         Timeout.datainit
                                        [5m] The timeout waiting for a 354
                                        response from the DATA command.
confTO_DATABLOCK        Timeout.datablock
                                        [1h] The timeout waiting for a block
                                        during DATA phase.
confTO_DATAFINAL        Timeout.datafinal
                                        [1h] The timeout waiting for a response
                                        to the final "." that terminates a
                                        message.
confTO_RSET             Timeout.rset    [5m] The timeout waiting for a response
                                        to the RSET command.
confTO_QUIT             Timeout.quit    [2m] The timeout waiting for a response
                                        to the QUIT command.
confTO_MISC             Timeout.misc    [2m] The timeout waiting for a response
                                        to other SMTP commands.
confTO_COMMAND          Timeout.command [1h] In server SMTP, the timeout
waiting
                                        for a command to be issued.
confTO_IDENT            Timeout.ident   [30s] The timeout waiting for a
response
                                        to an IDENT query.
confTO_FILEOPEN         Timeout.fileopen
                                        [60s] The timeout waiting for a file
                                        (e.g., :include: file) to be opened.
confTO_QUEUERETURN      Timeout.queuereturn
                                        [5d] The timeout before a message is
                                        returned as undeliverable.
confTO_QUEUERETURN_NORMAL
                        Timeout.queuereturn.normal
                                        [undefined] As above, for normal
                                        priority messages.
confTO_QUEUERETURN_URGENT
                        Timeout.queuereturn.urgent
                                        [undefined] As above, for urgent
                                        priority messages.
confTO_QUEUERETURN_NONURGENT
                        Timeout.queuereturn.non-urgent
                                        [undefined] As above, for non-urgent
                                        (low) priority messages.
confTO_QUEUEWARN        Timeout.queuewarn
                                        [4h] The timeout before a warning
                                        message is sent to the sender telling
                                        them that the message has been
deferred.
confTO_QUEUEWARN_NORMAL Timeout.queuewarn.normal
                                        [undefined] As above, for normal
                                        priority messages.
confTO_QUEUEWARN_URGENT Timeout.queuewarn.urgent
                                        [undefined] As above, for urgent
                                        priority messages.
confTO_QUEUEWARN_NONURGENT
                        Timeout.queuewarn.non-urgent
                                        [undefined] As above, for non-urgent
                                        (low) priority messages.
confTO_HOSTSTATUS       Timeout.hoststatus
                                        [30m] How long information about host
                                        statuses will be maintained before it
                                        is considered stale and the host should
                                        be retried.  This applies both within
                                        a single queue run and to persistent
                                        information (see below).
confTIME_ZONE           TimeZoneSpec    [USE_SYSTEM] Time zone info -- can be
                                        USE_SYSTEM to use the system's idea,
                                        USE_TZ to use the user's TZ envariable,
                                        or something else to force that value.
confDEF_USER_ID         DefaultUser     [1:1] Default user id.
confUSERDB_SPEC         UserDatabaseSpec
                                        [undefined] User database
specification.
confFALLBACK_MX         FallbackMXhost  [undefined] Fallback MX host.
confTRY_NULL_MX_LIST    TryNullMXList   [False] If we are the best MX for a
                                        host and haven't made other
                                        arrangements, try connecting to the
                                        host directly; normally this would be
                                        a config error.
confQUEUE_LA            QueueLA         [8] Load average at which queue-only
                                        function kicks in.
confREFUSE_LA           RefuseLA        [12] Load average at which incoming
                                        SMTP connections are refused.
confMAX_DAEMON_CHILDREN MaxDaemonChildren
                                        [undefined] The maximum number of
                                        children the daemon will permit.  After
                                        this number, connections will be
                                        rejected.  If not set or <= 0, there is
                                        no limit.
confCONNECTION_RATE_THROTTLE ConnectionRateThrottle
                                        [undefined] The maximum number of
                                        connections permitted per second.
                                        After this many connections are
                                        accepted, further connections will be
                                        delayed.  If not set or <= 0, there is
                                        no limit.
confWORK_RECIPIENT_FACTOR
                        RecipientFactor [30000] Cost of each recipient.
confSEPARATE_PROC       ForkEachJob     [False] Run all deliveries in a
separate
                                        process.
confWORK_CLASS_FACTOR   ClassFactor     [1800] Priority multiplier for class.
confWORK_TIME_FACTOR    RetryFactor     [90000] Cost of each delivery attempt.
confQUEUE_SORT_ORDER    QueueSortOrder  [Priority] Queue sort algorithm:
                                        Priority, Host, or Time.
confMIN_QUEUE_AGE       MinQueueAge     [0] The minimum amount of time a job
                                        must sit in the queue between queue
                                        runs.  This allows you to set the
                                        queue run interval low for better
                                        resposiveness without trying all
                                        jobs in each run.
confDEF_CHAR_SET        DefaultCharSet  [unknown-8bit] When converting
                                        unlabelled 8 bit input to MIME, the
                                        character set to use by default.
confSERVICE_SWITCH_FILE ServiceSwitchFile
                                        [/etc/service.switch] The file to use
                                        for the service switch on systems that
                                        do not have a system-defined switch.
confHOSTS_FILE          HostsFile       [/etc/hosts] The file to use when doing
                                        "file" type access of hosts names.
confDIAL_DELAY          DialDelay       [0s] If a connection fails, wait this
                                        long and try again.  Zero means "don't
                                        retry".  This is to allow "dial on
                                        demand" connections to have enough time
                                        to complete a connection.
confNO_RCPT_ACTION      NoRecipientAction
                                        [none] What to do if there are no legal
                                        recipient fields (To:, Cc: or Bcc:)
                                        in the message.  Legal values can
                                        be "none" to just leave the
                                        nonconforming message as is, "add-to"
                                        to add a To: header with all the
                                        known recipients (which may expose
                                        blind recipients), "add-apparently-to"
                                        to do the same but use Apparently-To:
                                        instead of To:, "add-bcc" to add an
                                        empty Bcc: header, or
                                        "add-to-undisclosed" to add the header
                                        ``To: undisclosed-recipients:;''.
confSAFE_FILE_ENV       SafeFileEnvironment
                                        [undefined] If set, sendmail will do a
                                        chroot() into this directory before
                                        writing files.
confCOLON_OK_IN_ADDR    ColonOkInAddr   [True unless Configuration Level > 6]
                                        If set, colons are treated as a regular
                                        character in addresses.  If not set,
                                        they are treated as the introducer to
                                        the RFC 822 "group" syntax.  Colons are
                                        handled properly in route-addrs.  This
                                        option defaults on for V5 and lower
                                        configuration files.
confMAX_QUEUE_RUN_SIZE  MaxQueueRunSize [0] If set, limit the maximum size of
                                        any given queue run to this number of
                                        entries.  Essentially, this will stop
                                        reading the queue directory after this
                                        number of entries are reached; it does
                                        _not_ pick the highest priority jobs,
                                        so this should be as large as your
                                        system can tolerate.  If not set, there
                                        is no limit.
confDONT_EXPAND_CNAMES  DontExpandCnames
                                        [False] If set, $[ ... $] lookups that
                                        do DNS based lookups do not expand
                                        CNAME records.  This currently violates
                                        the published standards, but the IETF
                                        seems to be moving toward legalizing
                                        this.  For example, if "FTP.Foo.ORG"
                                        is a CNAME for "Cruft.Foo.ORG", then
                                        with this option set a lookup of
                                        "FTP" will return "FTP.Foo.ORG"; if
                                        clear it returns "Cruft.FOO.ORG".  N.B.
                                        you may not see any effect until your
                                        downstream neighbors stop doing CNAME
                                        lookups as well.
confFROM_LINE           UnixFromLine    [From $g  $d] The From_ line used
                                        when sending to files or programs.
confOPERATORS           OperatorChars   [.:%%@!^/[]+] Address operator
                                        characters.
confSMTP_LOGIN_MSG      SmtpGreetingMessage
                                        [$j Sendmail $v/$Z; $b]
                                        The initial (spontaneous) SMTP
                                        greeting message.  The word "ESMTP"
                                        will be inserted between the first and
                                        second words to convince other
                                        sendmails to try to speak ESMTP.
confDONT_INIT_GROUPS    DontInitGroups  [False] If set, the initgroups(3)
                                        routine will never be invoked.  You
                                        might want to do this if you are
                                        running NIS and you have a large group
                                        map, since this call does a sequential
                                        scan of the map; in a large site this
                                        can cause your ypserv to run
                                        essentially full time.  If you set
                                        this, agents run on behalf of users
                                        will only have their primary
                                        (/etc/passwd) group permissions.
confUNSAFE_GROUP_WRITES UnsafeGroupWrites
                                        [False] If set, group-writable
                                        :include: and .forward files are
                                        considered "unsafe", that is, programs
                                        and files cannot be directly referenced
                                        from such files.  World-writable files
                                        are always considered unsafe.
confDOUBLE_BOUNCE_ADDRESS  DoubleBounceAddress
                                        [postmaster] If an error occurs when
                                        sending an error message, send that
                                        "double bounce" error message to this
                                        address.
confRUN_AS_USER         RunAsUser       [undefined] If set, become this user
                                        when reading and delivering mail.
                                        Causes all file reads (e.g., .forward
                                        and :include: files) to be done as
                                        this user.  Also, all programs will
                                        be run as this user, and all output
                                        files will be written as this user.
                                        Intended for use only on firewalls
                                        where users do not have accounts.

See also the description of OSTYPE for some parameters that can be
tweaked (generally pathnames to mailers).


+-----------+
| HIERARCHY |
+-----------+

Within this directory are several subdirectories, to wit:

m4              General support routines.  These are typically
                very important and should not be changed without
                very careful consideration.

cf              The configuration files themselves.  They have
                ".mc" suffixes, and must be run through m4 to
                become complete.  The resulting output should
                have a ".cf" suffix.

ostype          Definitions describing a particular operating
                system type.  These should always be referenced
                using the OSTYPE macro in the .mc file.  Examples
                include "bsd4.3", "bsd4.4", "sunos3.5", and
                "sunos4.1".

domain          Definitions describing a particular domain, referenced
                using the DOMAIN macro in the .mc file.  These are
                site dependent; for example, "CS.Berkeley.EDU.m4"
                describes hosts in the CS.Berkeley.EDU subdomain.

mailer          Descriptions of mailers.   These are referenced using
                the MAILER macro in the .mc file.

sh              Shell files used when building the .cf file from the
                .mc file in the cf subdirectory.

feature         These hold special orthogonal features that you might
                want to include.  They should be referenced using
                the FEATURE macro.


+------------------------+
| ADMINISTRATIVE DETAILS |
+------------------------+

The following sections detail usage of certain internal parts of the
sendmail.cf file.  Read them carefully if you are trying to modify
the current model.  If you find the above descriptions adequate, these
should be {boring, confusing, tedious, ridiculous} (pick one or more).

RULESETS (* means built in to sendmail)

   0 *  Parsing
   1 *  Sender rewriting
   2 *  Recipient rewriting
   3 *  Canonicalization
   4 *  Post cleanup
   5 *  Local address rewrite (after aliasing)
  1x    mailer rules (sender qualification)
  2x    mailer rules (recipient qualification)
  3x    mailer rules (sender header qualification)
  4x    mailer rules (recipient header qualification)
  5x    mailer subroutines (general)
  6x    mailer subroutines (general)
  7x    mailer subroutines (general)
  8x    reserved
  90    Mailertable host stripping
  96    Bottom half of Ruleset 3 (ruleset 6 in old sendmail)
  97    Hook for recursive ruleset 0 call (ruleset 7 in old sendmail)
  98    Local part of ruleset 0 (ruleset 8 in old sendmail)
  99    Guaranteed null (for debugging)


MAILERS

   0    local, prog     local and program mailers
   1    [e]smtp, relay  SMTP channel
   2    uucp-*          UNIX-to-UNIX Copy Program
   3    netnews         Network News delivery
   4    fax             Sam Leffler's HylaFAX software
   5    mail11          DECnet mailer


MACROS

   A
   B    Bitnet Relay
   C    DECnet Relay
   D    The local domain -- usually not needed
   E    reserved for X.400 Relay
   F    FAX Relay
   G
   H    mail Hub (for mail clusters)
   I
   J
   K
   L    Luser Relay
   M    Masquerade (who I claim to be)
   N
   O
   P
   Q
   R    Relay (for unqualified names)
   S    Smart Host
   T
   U    my UUCP name (if I have a UUCP connection)
   V    UUCP Relay (class V hosts)
   W    UUCP Relay (class W hosts)
   X    UUCP Relay (class X hosts)
   Y    UUCP Relay (all other hosts)
   Z    Version number


CLASSES

   A
   B    domains that are candidates for bestmx lookup
   C
   D
   E    addresses that should not seem to come from $M
   F    hosts we forward for
   G    domains that should be looked up in genericstable
   H
   I
   J
   K
   L    addresses that should not be forwarded to $R
   M    domains that should be mapped to $M
   N
   O    operators that indicate network operations (cannot be in local names)
   P    top level pseudo-domains: BITNET, DECNET, FAX, UUCP, etc.
   Q
   R    domains we are willing to relay (pass anti-spam filters)
   S
   T
   U    locally connected UUCP hosts
   V    UUCP hosts connected to relay $V
   W    UUCP hosts connected to relay $W
   X    UUCP hosts connected to relay $X
   Y    locally connected smart UUCP hosts
   Z    locally connected domain-ized UUCP hosts
   .    the class containing only a dot
   [    the class containing only a left bracket


M4 DIVERSIONS

   1    Local host detection and resolution
   2    Local Ruleset 3 additions
   3    Local Ruleset 0 additions
   4    UUCP Ruleset 0 additions
   5    locally interpreted names (overrides $R)
   6    local configuration (at top of file)
   7    mailer definitions
   8
   9    special local rulesets (1 and 2)


2.0 Debugging Sendmail 8.8


 2.1: Debugging using SMTP port 25 

------------------------

If you are having troubles with sendmail on a particular machine, you
can connect to it on port 25 to examine how it is functioning.

The following determines that sendmail is up and running:

  # telnet localhost 25
  connecting to host localhost (127.0.0.1), port 25
  connection open
  220 foo.sun.com ESMTP Sendmail 8.8.8+Sun/8.8.8; Mon, 12 Oct 1998 16:39:23
-0400 (EDT)

This also tells you what sendmail has its name set to (foo.sun.com)
and what version of sendmail you are running (8.8.8+Sun/8.8.8).

Once you have connected to the sendmail port, you may use the 'expn'
SMTP command to examine the expansion of addresses, such as you might
want to see when debugging mail alias problems.

  $ telnet localhost 25
  ...
  expn postmaster
  250 < root >
  expn appel
  250 Shannon Appel < appel@foo.sun.com >

Note: on suns, the command 'mconnect <machine>' does the same thing as
'telnet <machine> 25' and may be used as a sort of shorthand. Be aware
that this command is not standard though.

There are several SMTP commands available.  Use the HELP command to
find out what commands the sendmail host supports.  Note that most
mail locations directly attached to the Internet have disabled
the EXPN (EXPaNd alias) and VRFY (VeRiFY user).

2.1.1  How to use SMTP commands to send mail directly to port 25

The command sequence to use is:

helo sending-hostname
mail from:  yourname@yourdomain.com      (yourname@yourdomain.com is the
sender)
rcpt to: user@destination     (user@destination is where you want the mail to
go)
data
                (put in Subject: and body of email message here)
.      (this is a period on a line by itself)
quit

For example:

$ telnet test 25
Trying 192.151.24.1...
Connected to test.
Escape character is '^]'.
220 test.East.Sun.COM Sendmail SMI-8.6/SMI-SVR4 ready at Wed, 19 Feb 1997
18:01:20 -0500
helo mercedes
250 sunesc.East.Sun.COM Hello mercedes [192.151.24.64], pleased to meet you
mail from: hackley@east.sun.com
250 hackley@east.sun.com... Sender ok
rcpt to: user@testhack.com
250 user@testhack.com... Recipient ok
data
354 Enter mail, end with "." on a line by itself
Subject:  Testing from Sun Service Network Support, please ignore
testing...
.
250 SAA13622 Message accepted for delivery
quit
221 sunesc.East.Sun.COM closing connection
Connection closed by foreign host.

For those of you have used mailx -v or /usr/lib/sendmail -v to
debug sendmail, you will recognize the stand SMTP command sequence.





 2.2: /usr/ucb/mail -v, mailx -v or /usr/lib/sendmail -v 

---------------------

The "-v" arg to /usr/ucb/mail & mailx is passed to sendmail when mail or mailx
exec sendmail to deliver the message.  This causes sendmail to show the
delivery
attempt verbosely.  This is an easy way to get valuable info about how sendmail
is configured on the host.

It is particular helpful because, for outgoing mail, it will show you
where mail is going, and how it is communicating:

  rainbow%% mailx -v test@test.com
  Subject: test
  this is a test of outgoing mail.
  ^D
  EOT
  rainbow%% test@test.com... Connecting to mailhost (ether)...
  220 Corp.Sun.COM Sendmail 5.x/SMI-5.3 ready at Tue, 12 Mar 1996 10:26:26
-0800
  >>> HELO rainbow.Corp.Sun.COM
  250 Corp.Sun.COM Hello rainbow.Corp.Sun.COM (rainbow-bb.Corp.Sun.COM),
pleased
 to meet you
  >>> MAIL From:<appel@rainbow>
  250 <appel@rainbow>... Sender ok
  >>> RCPT To:<test@test.com>
  250 <test@test.com>... Recipient ok
  >>> DATA
  354 Enter mail, end with "." on a line by itself
  >>> .
  250 Ok
  >>> QUIT
  221 Corp.Sun.COM closing connection
  test@test.com... Sent (Ok)

In the above example, we see that the "ether" mailer is being used,
and that our local machine is connect to mailhsot.

/usr/ucb/mail, mailx, or sendmail in the verbose mode will often give 
you hints for easy sendmail problems, particularly "bounce" messages
If it is insufficient, sendmail itself provides
some much more robust verbose functionality.





 2.3: Sendmail Debug Functions 

-----------------------------

When debugging, consider the information provided by running sendmail
in verbose mode, and in debug mode

2.3.1 sendmail verbose mode mode:

This is an example of running sendmail interactive on a "subsidiary"
machine. Below in "{}" are comments of useful information.

        $ /usr/lib/sendmail -v jane@foo.com this is a test
        .        (or CTRL/D)
        jane@foo.com... Connecting to mailhost via ether...

    {The machine we are sending mail to^^^^^^^     ^^^^^the mailer
    used}

        Trying 129.151.21.1...  connected.

    {The connection to machine "mailhost" completed}

        220 sunesc.East.Sun.COM Sendmail 4.1/SMI-4.1 ready at Wed, 30
                        Aug 95 09:33:49 EDT >>> HELO
                        doghouse.East.Sun.COM

    {I identify myself: defined by the macro Dj$w.$m}

        250 sunesc.East.Sun.COM Hello doghouse.East.Sun.COM, pleased to
        meet you>>> MAIL From:<valante@doghouse>

    {Here is the address that will show in the mail's "from" line or
     "to" line when someone replies to it}

        250 <valante@doghouse>... Sender ok >>> RCPT To:<jane@foo.com>
        250 <jane@foo.com>... Recipient ok

    {The person receiving the mail is a valid address. NOTE: This is
     valid for the machine connected to, but may not be a valid final
     address. Running sendmail -v from the machine you are connecting
     to may give an error and will identify the real problem.}

        >>> DATA 354 Enter mail, end with "." on a line by itself >>>
        .  250 Mail accepted >>> QUIT 221 sunesc.East.Sun.COM
        delivering mail jane@foo.com... Sent

    {The mail has been sent to sunesc and is now the responsibility of the 
     sunesc to deliver or relay the mail to the destination}

2.3.2  sendmail debug mode to get basic sendmail info 

To find out what some basic macros, user debug level 0.1:


$ /usr/lib/sendmail -bt -d0.1 < /dev/null
Version SMI-8.6
SYSTEM IDENTITY (after readcf):
            (short domain name) $w = mercedes
        (canonical domain name) $j = $w.$m
               (subdomain name) $m = East.Sun.COM
                    (node name) $k = mercedes

This is very helpful in debugging "mail loops back to myself" problems,
which are caused by improper definition of $j.


2.3.3  sendmail debug to test address rulesets


To find where in a rule is matching, and how mail is being
routed, use debug level 21.12.  In this case, we are looking to
check on how the "From" address is being rewritten:

        doghouse -> /usr/lib/sendmail -bt -d21.12
        Version 5.x
        ADDRESS TEST MODE
        Enter <ruleset> <address>
        > 3,11 glen
        rewrite: ruleset  3   input: "glen"
        -----trying rule: $* "<" ">" $*
        ----- rule fails

        ... It runs thru the rules ...

        rewrite: ruleset 11   input: "glen"
        -----trying rule: $* "<" "@" $+ ">" $*
        ----- rule fails
        -----trying rule: $=D
        ----- rule fails
        -----trying rule: $+
        -----rule matches: $@ $1 "<" "@" "doghouse" ">"
        rewritten as: "glen" "<" "@" "doghouse" ">"
        rewrite: ruleset 11 returns: "glen" "<" "@" "doghouse" ">"

      This tells me that in ruleset 11 it matches:

        R$+                     $@$1<@$k>          tack on my mbox hostname

      And Here is were the address ^^^^^^ is getting rewritten.

2.3.4  The MOST COMMON input to address ruleset debug mode 

 Folks, when we troubleshoot sendmail problems, we find the
 most helpful ruleset rewriting modes are:

 1.  TO DEBUG WHERE MAIL IS GOING TO NEXT, WITH WHICH MAILER:

    3,0,4 user@wherever.you.want

 2.  To DEBUG YOUR "From" ADDRESS WITH THE "ddn" MAILER:

    3,22,4 user@sending.address

 3.  TO DEBUG YOUR "From" ADDRESS WITH THE "ether" MAILER:

    3,11,4 user@sending.address

2.3.5 Sendmail debug switches and what they mean?

27.1    aliases & NIS aliases & .forward
5.5     setevent timer, clear, tick
5.6     timer tivk parsing
30.1    header info
30.3    apparently to
30.2    eat from
15.15   network debugging
15.1    get requests
15.2    forking, returning
16.1    calling, remote
16.14   network debugging
10.1    deliver
10.1    sendto
38.1    before the wait() on pid, fork with pid
11.1    open mailer
13.1    send all
13.3    checking queue
13.4    errors to
8.2     MX options
8.1     MX search result
8.3     MX answer, type
8.1     MX get common host info
8.1     MX answers
50.1    drop envelope
45.1    set sender (From:), from domain
31.6    drop envelope
32.1    collected header
31.1    capitalised, message id
33.1    initial to: address
14.2    commasize
35.24   expand
35.9    define
0.4     canonical name, aka
0.15    configuration table
1.1     print from
2.1     finis
52.1    disconnect
52.5    don't
20.1    parseaddr
22.45   prescan
22.101  state
22.101  newstate
22.36   token is
21.2    rewrite rule
21.12   trying rule
21.35   op
21.10   rule fails
21.12   rule matches
21.15   ?
21.3    call subr
21.4    rewritten as
21.2    returns
12.1    remote name
40.1    queueing
41.2    orderq cannot open
40.1    qsort, dowork
40.4    control file
7.20    queuename
7.1     queuename is
51.4    queuename unlink
37.1    setoption
37.1    ignored
37.1    unsafe
25.1    sendto list
27.1    found self reference
27.1    found self alias
26.1    recipient
26.1    in sendq
6.1     savemail error mode, return to sender
6.5     print state
36.5    stats symbol table
36.9    print function
18.1    smtp init
18.1    reply
18.100  parse
18.1    message is ...
0.44    argv =



3.0 Common HowTos


 3.1  How to build a new config file. 


The first thing you should notice is that you now have a /usr/lib/mail
directory that contains a README file.  It is vital that you read this
file to gain a better understanding of the new suggested configuration
process to generate your own sendmail.cf file.

You might also want to check out http://www.sendmail.org and specifically
the link for 'vendor specific information' that pertains to Sun/Solaris.

In short, the basic steps to generate your own config file where you are
perhaps adding a new feature to the main.cf file, is as follows:

cd /usr/lib/mail/cf

cp main-v7sun.mc example.mc

make any necessary changes (this is where reading the README file will
        have proven beneficial since adding a new feature *must* come before
        before any mailer specifications)

/usr/ccs/bin/m4 ../m4/cf.m4 example.mc > example.cf

cp example.cf /etc/mail/sendmail.cf

/etc/init.d/sendmail stop ; /etc/init.d/sendmail start

You are now ready to test your new config file by sending mail and checking
that it has been received as well as using the -v (verbose option) and -d
(debug) options to sendmail.




 3.2  How do I configure anti-spamming? 


The most common "spam attacks" are where the hacker exploits the willingness of
some sites sendmail daemon to forward (relay) mail to another site(s) and the
ease of impersonating someone else by using SMTP protocol or, for that matter,
just a PC running a garden variety "mail reader" program where the "user
identity" and outgoing mailsever entries have been altered.  Then when the mail
is sent it is the content that the spammer wants to get out to the audience and
he doesn't care that the recipient can't reply to him, in fact, that's the
whole
idea.  This way someone else "takes the rap" for the unsolicited mail.  In
these scenarios, the method of combating it is to prevent people from
"unauthorized" relaying.

Sendmail 8.8.8 does not come preconfigured to prevent relaying however it is
built to support new rulesets that will block unauthorized relaying.  These
rulesets are available in the public domain and not supported directly by Sun.
You should start at the sendmail site www.sendmail.org and follow the link for
anti-spam provisions.  There you will find a "check_rcpt" ruleset which can be
added to your config file.  This ruleset takes advantage of one of the new
macros in sendmail ($&{client_name}).  This macro resolves to the name of the
machine that has connected to the sendmail daemon on this machine.  Then we put
together a file (/etc/sendmail.cR note that this isn't in the /etc/mail
subdirectory).  Then the new ruleset "check_rcpt" allows relaying if one of two
conditions exist:

First is: if the destination host is in this file, then it will accept the
mail.
Second is: if the connection is comming from a machine in this list (important:
this is not the SMTP "Mail From: " or "HELO <hostname>" since these are so
easily duped), it will accept the mail, otherwise, an SMPT "relaying denied"
message is issued and the connection is closed.  This dictates that all allowed
clients must be listed in this /etc/sendmail.cR

This doesn't work at many sites since the IP addrs of many PCs aren't mapped
to hostnames, thus they are considered a "spamer".

Below you will find a complete spam.mc file this is just a standard
/usr/lib/mail/cf/main-v7sun.mc file with spam & relay control code added.
This was also taken from the public domain and is not supported by Sun but is
offered here on an "as is" basis.  These rulesets use several additional files
to prevent spaming on your system.  The files are:

/etc/mail/sendmail.junkmail

One entry per line containing a full email address, eg spammer@aol.com or just
the domain name, eg cyberpromo.com

/etc/mail/sendmail.mxhosts

A complete list of every *domain* you MX for or otherwise allow to use your
system as a mail relay.

/etc/mail/sendmail.localip

Simple list, one entry per line, of IP addresses/prefixes you consider
local/trusted. e,g.

207.124.145
207.124.144.3

/etc/mail/sendmail.spamip

Simple list of IP addresses/prefixes you wish to block, sample entries from
another post

205.199.212
206.27.86.210
207.124.161.50
209.14.30

To use this, cd to /usr/lib/mail/cf and drop it into a new file ie.

/usr/lib/mail/cf/spam.mc

Replace the "<TAB>" strings with one or more tab characters.  Note: there are
TAB chars here as well but cut & paste usually convert TAB chars to the
equivilent number of SPACE chars which will render the rules inoperative.  Then
run the command "/usr/ccs/bin/m4 ../m4/cf.m4 spam.mc > spam.cf".  Next copy the
spam.cf file into /etc/mail/sendmail.cf.  Don't forget to populate whatever of
the files you need otherwise not much mail will pass through this host ;)  Of
course, stop and restart sendmail.


--------------- CUT HERE -----------------------------
divert(-1)
#
# Copyright (c) 1983 Eric P. Allman
# Copyright (c) 1988, 1993
#       The Regents of the University of California.  All rights reserved.
#
# Copyright (c) 1997
#       Sun Microsystems, Inc.  All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
# 1. Redistributions of source code must retain the above copyright
#    notice, this list of conditions and the following disclaimer.
# 2. Redistributions in binary form must reproduce the above copyright
#    notice, this list of conditions and the following disclaimer in the
#    documentation and/or other materials provided with the distribution.
# 3. All advertising materials mentioning features or use of this software
#    must display the following acknowledgement:
#       This product includes software developed by the University of
#       California, Berkeley and its contributors.
# 4. Neither the name of the University nor the names of its contributors
#    may be used to endorse or promote products derived from this software
#    without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
# SUCH DAMAGE.
#

divert(0)dnl
#
#  This is a configuration file for SunOS 5.x (a.k.a. Solaris 2.x)
#  It is an edited copy of /usr/lib/mail/cf/main-v7sun.mc with added
#  rulesets "check_rcpt" and "check_mail" to control unauthorized relaying
#  and spaming through this host.
#

VERSIONID(`@(#)main-v7sun.mc    1.2 (Sun) 01/27/98')
OSTYPE(solaris2.ml)dnl
DOMAIN(solaris-generic)dnl
LOCAL_CONFIG
# One entry per line containing a full email address, eg spammer@aol.com
# or just the domain name, eg cyberpromo.com
F{JunkMail}-o /etc/mail/sendmail.junkmail

# A complete list of every *domain* you MX for or otherwise allow
# to use your system as a mail relay.
F{Relay}-o /etc/mail/sendmail.mxhosts

# Simple list, one entry per line, of IP addresses/prefixes you
# consider local/trusted. e,g.
#
# 207.124.145
# 207.124.144.3
F{LocalIP}-o /etc/mail/sendmail.localip

# Simple list of IP addresses/prefixes you wish to block, sample
# entries from another post
# 
# 205.199.212
# 206.27.86.210
# 207.124.161.50
# 209.14.30
F{SpamIP}-o /etc/mail/sendmail.spamip

LOCAL_RULESETS

Scheck_rcpt
# verify that either the sender is local or the rcpt is local
R$+                             <TAB> $: $(dequote "" $&{client_addr} $) $| $1
R0 $| $*                        <TAB> $@ ok        no client addr: directly
invoked
R$={LocalIP}$* $| $*            <TAB> $@ ok        from here
R$={SpamIP}$* $| $*             <TAB> $#error $@ 5.7.1 $: 571 spammer access
denied
# not local, not known spammer. check rcpt
R$* $| $*                       <TAB> $: $>3 $2
# remove local part, maybe repeatedly


R$*<@$=w.>$*                    <TAB> $>3 $1 $3
R$*<@$*$={Relay}.>$*            <TAB> $>3 $1 $4
# still something left?
R$*<@$+>$*                      <TAB> $#error $@ 5.7.1 $: 571 no relay $1 $2 $3

Scheck_mail
# Bounce junk mail by email address and/or domain name
R<$={JunkMail}>                 <TAB> $#error $@ 5.7.1 $: "571 rejected sender
address"
R$={JunkMail}                   <TAB> $#error $@ 5.7.1 $: "571 rejected sender
address"
R$*                             <TAB> $: $>3 $1
R$* < @ $* $={JunkMail} > $*    <TAB> $#error $@ 5.7.1 $: "571 rejected sender
domain"
R$* < @ $* $={JunkMail} . > $*  <TAB> $#error $@ 5.7.1 $: "571 rejected sender
domain"
MAILER(local)dnl
MAILER(smtp)dnl





 3.3 How to use MX records to internal domains and "smarthost" for external. 


OK let's' say you have the domain 'foo.com' and it has many subdomains ie.
eng.foo.com and corp.foo.com etc. There is a firewall between the top level
foo.com and the internet and this must be used as the "smarthost" (relay).
The machine in question is part of the corp.foo.com domain and you want to
send mail to other internal domains directly and to external domains through
the smarthost.

First, you would start out by copying an existing main.mc file:

# cd /usr/lib/mail/cf
# ls
main-v7sun.cf        subsidiary-v7sun.cf
main-v7sun.mc        subsidiary-v7sun.mc
# cp main-v7sun.mc new.mc
#

next you would add the "SMART_HOST" and "LOCAL_NET_CONFIG" to the file so it
might end up looking like this:

<snip>
divert(0)dnl
VERSIONID(`@(#)main-v7sun.mc    1.2 (Sun) 01/27/98')
OSTYPE(solaris2.ml)dnl
define(`SMART_HOST',`firewall.foo.com')
LOCAL_NET_CONFIG
R$* < @ $* .foo.com. > $*       $#smtp $@ $2.foo.com. $: $1 < @ $2.foo.com. >
$3
DOMAIN(solaris-generic)dnl
MAILER(local)dnl
MAILER(smtp)dnl

after adding these lines, you can then run the following command:

# /usr/ccs/bin/m4 ../m4/cf.m4 new.mc > new.cf
# cp new.cf /etc/mail/sendmail.cf
# /etc/init.d/sendmail stop
# /etc/init.d/sendmail start
#

this should cause the desired effect.




 3.4 How to set up a machine as a "internet mailhost" 


By "internet mailhost" I men a machine that is capable of exchanging mail with
other machines connected to the internet.  This machine must be running a dns
resolver and there shouldn't be a firewall blocking this machine from access
to the internet (at least on port 25).

All you need to do is use the new /etc/mail/main.cf 





 3.5 What if I need my mail to go through a relay? 


In that case you need to define a "smart host".  So lets say you are a host in
"foo.com" and you need to send external mail through the machine called
"firewall.foo.com" 

First, you would start out by copying an existing main.mc file:

# cd /usr/lib/mail/cf
# ls
main-v7sun.cf        subsidiary-v7sun.cf
main-v7sun.mc        subsidiary-v7sun.mc
# cp main-v7sun.mc new.mc
#

next you would add the "SMART_HOST" to the file so it might end up looking
like this:

<snip>
divert(0)dnl
VERSIONID(`@(#)main-v7sun.mc    1.2 (Sun) 01/27/98')
OSTYPE(solaris2.ml)dnl
define(`SMART_HOST',`firewall.foo.com')
DOMAIN(solaris-generic)dnl
MAILER(local)dnl
MAILER(smtp)dnl

after adding this line, you can then run the following command:

# /usr/ccs/bin/m4 ../m4/cf.m4 new.mc > new.cf
# cp new.cf /etc/mail/sendmail.cf
# /etc/init.d/sendmail stop
# /etc/init.d/sendmail start
#

this should cause the desired effect.






 3.6 How do I hide hostnames (masquerade) 


You can have your host masquerade as another using

        MASQUERADE_AS(host.domain)

This causes mail being sent to be labeled as coming from the
indicated host.domain, rather than $j.  This behaviour is modified by
a plethora of FEATUREs; in particular, see masquerade_envelope,
allmasquerade, limited_masquerade, and masquerade_entire_domain.

The masquerade name is not normally canonified, so it is important
that it be your One True Name, that is, fully qualified and not a
CNAME.

Normally the only addresses that are masqueraded are those that come
from this host (that is, are either unqualified or in $=w, the list
of local domain names).  You can augment this list using

        MASQUERADE_DOMAIN(otherhost.domain)

The effect of this is that although mail to user@otherhost.domain
will not be delivered locally, any mail including any user@otherhost.domain
will, when relayed, be rewritten to have the MASQUERADE_AS address.

Normally only header addresses are masqueraded.  If you want to
masquerade the envelope as well, use

        FEATURE(masquerade_envelope)

There are always users that need to be "exposed" -- that is, their
internal site name should be displayed instead of the masquerade name.
Root is an example.  You can add users to this list using

        EXPOSED_USER(usernames)




 3.5 All the mail addrs now have FQHNs how do I make stop doing that. 


Here is what you should do to build a new client sendmail config file for
sendmail version 8.8

cd /usr/lib/mail/cf
cp subsidiary-v7sun.mc test.mc
vi test.mc  and add  FEATURE(nocanonify)   to a line by itself above the
"mailer" lines (these need to be lact in the .mc file) and save it off.
Next, build a new .cf file:

/usr/ccs/bin/m4 ../m4/cf.m4 test.mc > test.cf
cp /etc/mail/sendmail.cf /etc/mail/old.sendmail.cf (so you dont lose it just
in case)
cp test.cf /etc/mail/sendmail.cf
/etc/init.d/sendmail stop ; /etc/init.d/sendmail start

test the results.


4.0 Frequently Asked Questions


 4.1  My sendmail complains it 'cannot get a fully qualified hostname', how do
I fix this? 


You may get this error on bootup and every time you attempt to send a message.

If you truely do not have a DNS domain that you are part of you should
do the following:

# cd /usr/lib/mail/cf
# cp subsidiary-v7sun.mc nocan.mc
add "FEATURE(`nocanonify')dnl" so it looks like:

.
.
.
divert(0)dnl
VERSIONID(`@(#)subsidiary-v7sun.mc      1.3 (Sun) 07/02/98')
FEATURE(`remote_mode')dnl
FEATURE(`nocanonify')dnl
define(`SMART_HOST', `mailhost.$m')
OSTYPE(solaris2.ml)dnl
DOMAIN(solaris-generic)dnl
MAILER(local)dnl
MAILER(smtp)dnl

and build a new config file similar to the example in section 3.1

Keep in mind that the new binary is insistent in determining/resolving
the host to being a FQHN. If you are not using either NIS or NIS+
then the easiest workaround is to add a fully qualified hostname to
the /etc/hosts file. 


ex. /etc/hosts
127.0.0.1  localhost
129.151.21.85 ruready ruready.sunesc.East.Sun.COM

This is the easiest workaround. There is also a reference to sendmail
requiring a fully qualified hostname at:

http://www.sendmail.org/sun-specific/migration+sun.html#FQHN

This also contains a shell script that customers can download which does
the same thing as sendmail does to determine the FQHN and it even makes
suggestions on how to resolve this problem. The script is called 
"check-hostname.sh".


Note: There is a bug where if you have dns listed after files in the
/etc/nsswitch.conf sendmail will not be able to resolve a FQHN. (It
should be able to) the fix is NOT to put dns first, but to use a FQHN
in the /etc/hosts file.



 4.2 When I use an old config file, remote mode doesn't work correctly. 


see infodoc # 17929

5.0 Patches


 5.0 Sendmail 8.8.8+sun patches 


Sendmail 8.8.8 is the current version for Solaris 2.5.1 and Solaris 2.6

The patch for Solaris 2.5.1 is: (rev 16 and above)
103594 SunOS 5.5.1: /usr/lib/sendmail fixes 
103595 SunOS 5.5.1_x86: /usr/lib/sendmail fixes
103596 SunOS 5.5.1_ppc: /usr/lib/sendmail fixes

The patch for Solaris 2.6 is: (rev 03 and above)
105395 SunOS 5.6: /usr/lib/sendmail patch
105396 SunOS 5.5.1_x86: /usr/lib/sendmail fixes


6.0 Known Bugs And RFEs



7.0 References


 7.1 Man pages 


aliases         aliases (4)     - addresses and aliases for sendmail
mail            mail (1)        - read mail or send mail to users
mail.local      mail.local (1m) - store mail in a mailbox
mailstats       mailstats (1)   - print statistics collected by sendmail
mailx           mailx (1)       - interactive message processing system
mconnect        mconnect (1)    - connect to SMTP mail server socket
newaliases      newaliases (1)  - rebuild the data base for the mail aliases
file
sendmail        sendmail (1m)   - send mail over the internet
vacation        vacation (1)    - reply to mail automatically
mailtool        mailtool (1)    - OpenWindows interface for the mail program
dtmail          dtmail (1)      - the CDE Mailer .sp 1





 7.2 SunSolve Documents 


 7.3: Sun Educational Services  


Solaris 2.X Network Administration (1-800-422-8020)


 7.4: Solaris Documentation  


Solaris documentation is available on the web via a browser at:

        http://docs.sun.com

Solaris documentation can be purchased in hard copy or through the
System Administrator AnswerBook. (These are specifically Solaris 2.6
answerbooks of interest).

_Mail Administration Guide_

_Solaris Naming Setup and Configuration Guide_

_Solaris Naming Administration Guide_

_TCP/IP and Data Communications Guide_


 7.5: Third Party Documentation  

_Sendmail_, Bryan Costales with Eric Allman & Neil Rickert O'Reilly &
Associates, Inc.

_DNS and Bind_, Paul Albitz & Cricket Liu O'Reilly & Associates, Inc.

_Managing UUCP and Usenet_, Tim O'Reiley and Grace Todino O'Reilly &
Associates, Inc.


 7.6 Other References 

http://www.sendmail.org