463 lines
19 KiB
Plaintext
463 lines
19 KiB
Plaintext
E-MailRelay Reference
|
|
=====================
|
|
|
|
Introduction
|
|
------------
|
|
This is the E-MailRelay reference guide. It contains material which is
|
|
supplementary to the user guide.
|
|
|
|
Command line usage
|
|
------------------
|
|
The "emailrelay" program supports the following command-line usage:
|
|
|
|
emailrelay [<switch> [<switch> ...]]
|
|
|
|
where <switch> is:
|
|
|
|
# --admin (-a)
|
|
Enables the administration interface and specifies its listening port number.
|
|
|
|
# --as-client (-q)
|
|
Equivalent to "--log --no-syslog --no-daemon --dont-serve --forward --forward-to".
|
|
|
|
# --as-proxy (-y)
|
|
Equivalent to "--log --close-stderr --immediate --forward-to".
|
|
|
|
# --as-server (-d)
|
|
Equivalent to "--log --close-stderr".
|
|
|
|
# --client-auth (-C)
|
|
Enables authentication with remote server, using the given secrets file.
|
|
|
|
# --close-stderr (-e)
|
|
Closes the standard error stream after start-up.
|
|
|
|
# --connection-timeout (-U)
|
|
Sets the timeout (in seconds) when connecting to a remote server (default is 40).
|
|
|
|
# --domain (-D)
|
|
Sets an override for the host's fully qualified domain name.
|
|
|
|
# --dont-serve (-x)
|
|
Stops the process acting as a server (usually used with --forward).
|
|
|
|
# --filter (-z)
|
|
Defines a mail pre-processor.
|
|
|
|
# --forward (-f)
|
|
Forwards stored mail on startup (requires --forward-to).
|
|
|
|
# --forward-to (-o)
|
|
Specifies the remote smtp server (required by --forward and --admin).
|
|
|
|
# --help (-h)
|
|
Displays help text and exits.
|
|
|
|
# --immediate (-m)
|
|
Forwards each message as soon as it is received (requires --forward-to).
|
|
|
|
# --log (-l)
|
|
Writes log information on standard error (if open) and syslog (if not disabled).
|
|
|
|
# --log-time (-L)
|
|
Adds a timestamp to the logging output.
|
|
|
|
# --no-daemon (-t)
|
|
Does not detach from the terminal.
|
|
|
|
# --no-syslog (-n)
|
|
Disables syslog output.
|
|
|
|
# --pid-file (-i)
|
|
Records the daemon process-id in the given file.
|
|
|
|
# --port (-p)
|
|
Specifies the smtp listening port number.
|
|
|
|
# --remote-clients (-r)
|
|
Allows remote clients to connect.
|
|
|
|
# --response-timeout (-T)
|
|
Sets the response timeout (in seconds) when talking to a remote server (default is 1800).
|
|
|
|
# --server-auth (-S)
|
|
Enables authentication of remote clients, using the given secrets file.
|
|
|
|
# --spool-dir (-s)
|
|
Specifies the spool directory (default is "/usr/local/var/spool/emailrelay").
|
|
|
|
# --user (-u)
|
|
Names the effective user to switch to when started as root (default is "daemon").
|
|
|
|
# --verbose (-v)
|
|
Generates more verbose logging (if compiled-in and logging enabled and stderr open).
|
|
|
|
# --version (-V)
|
|
Displays version information and exits.
|
|
|
|
If no command-line switches are supplied at all then the default
|
|
behaviour is:
|
|
* to run as a daemon, detached from the terminal
|
|
* listen on the standard SMTP port (25)
|
|
* store e-mail messages in "/usr/local/var/spool/emailrelay"
|
|
* reject connections from remote clients
|
|
* disable the administration interface
|
|
* generate no logging or diagnostic messages
|
|
|
|
The "--as-server" switch makes sure that logging is enabled and that
|
|
the standard error stream is closed.
|
|
|
|
To foward spooled messages to the ISP the command-line switch "--as-client"
|
|
is provided to run the program...
|
|
* in foreground, exiting when all spooled mail has been processed
|
|
* forwarding spooled mail from "/usr/local/var/spool/emailrelay"
|
|
* without listening on any port
|
|
* with error, warning and information messages sent to stderr
|
|
* without using syslog
|
|
|
|
Message store
|
|
-------------
|
|
Mail messages are stored as text files in the configured spool directory. Each
|
|
message is represented as an envelope file and a content file. The envelope
|
|
file contains parameters relevant to the SMTP dialogue, and the content file
|
|
contains the RFC822 headers and body text.
|
|
|
|
The filenames used in the message store have a prefix of "emailrelay", followed
|
|
by a process-id and sequence number, followed by "envelope" or "content". The
|
|
envelope files then have an additional suffix to implement a simple locking
|
|
scheme.
|
|
|
|
The envelope suffixes are:
|
|
* ".new" -- while the envelope is first being written
|
|
* <none> -- while the message is spooled
|
|
* ".busy" -- while the message is being forwarded
|
|
* ".bad" -- if the message cannot be forwarded
|
|
* ".local" -- for copies of the envelope file for delivery to local recipients
|
|
|
|
Copies of the content file for delivery to local recipients will also have
|
|
a "local" suffix.
|
|
|
|
If a message cannot be forwarded the envelope file is given a "bad" suffix,
|
|
and the failure reason is written into the file.
|
|
|
|
SMTP issues
|
|
-----------
|
|
# Authentication:
|
|
|
|
The AUTH extension is supported, providing the CRAM-MD5 and LOGIN mechanisms.
|
|
|
|
# Local delivery:
|
|
|
|
Recipient addresses like "postmaster", "postmaster@localhost" and "postmaster@fqdn"
|
|
(where "fqdn" is the host's fully qualified domain name) are treated as the local
|
|
postmaster, resulting in local delivery rather than mail forwarding.
|
|
|
|
Recipient addresses (other than "postmaster" addresses) with no "at" sign (@) or
|
|
ending in "@localhost" will be rejected at the time the message is submitted by the
|
|
e-mail front-end. This is in line with E-MailRelay's intended purpose as a simple
|
|
mail relay, rather than a fully-fledged routing MTA.
|
|
|
|
Delivery of mail to a local "postmaster" is a feature of E-MailRelay which is
|
|
provided for completeness and for comformance to the SMTP specification.
|
|
Note that the E-MailRelay daemon does not actually deliver mail to the postmaster
|
|
mailbox. All it does is create an envelope and content file in the spool
|
|
directory with a ".local" suffix. Some external system, such as a shell
|
|
script run from cron calling "procmail", should be used to process the
|
|
".local" files. An example script is provided.
|
|
|
|
# Timeouts:
|
|
|
|
A simple client-side timeout is implemented which will abort the transaction
|
|
if the server fails to respond to any of the client's SMTP commands within the
|
|
given time period.
|
|
|
|
# Message loops:
|
|
|
|
Message loops are not detected.
|
|
|
|
# Eight bit messages:
|
|
|
|
The 8BITMIME SMTP extension is supported, however no attempt is made to
|
|
re-encode 8-bit messages into 7-bit messages if the next-hop server
|
|
does not.
|
|
|
|
Administration interface
|
|
------------------------
|
|
If enabled, the server will provide a network interface for performing
|
|
administration tasks. This is a simple command-line interface which is
|
|
compatible with "telnet".
|
|
|
|
Currently the only supported commands are "flush" and "info". The "flush" command
|
|
is used to forward spooled mail to the configured next-hop SMTP server. The
|
|
next-hop server address must have been defined on the "emailrelay" command
|
|
line at start-up using the "--forward-to" switch; it cannot be specified through
|
|
the administration interface.
|
|
|
|
The "flush" command allows you to run a single process which combines the
|
|
functionality of storage daemon and forwarding client. This might be useful
|
|
in systems which are low on memory: the memory footprint of "telnet" or
|
|
"emailrelay-poke" will be much smaller than "emailrelay --as-client".
|
|
|
|
Mail pre-processing
|
|
-------------------
|
|
The "--filter" command-line switch allows you to specify a pre-processor program
|
|
which operates on mail messages as they pass through the E-MailRelay system. The
|
|
pre-processor program is run as soon as the mail message has been stored in the
|
|
spool directory, with the full path of the content file specified on the command
|
|
line.
|
|
|
|
This can be combined with the "--immediate" (or "--as-proxy") switch to implement
|
|
personal mail pre-processing, without replacing or reconfiguring the system's
|
|
default MTA.
|
|
|
|
For example, the following command will start a proxy server on port 10025
|
|
which pre-processes mail using the specified filter program, and then
|
|
forwards the mail on to the system's default MTA (on port 25):
|
|
|
|
emailrelay --as-proxy localhost:smtp --port 10025 --no-syslog \
|
|
--filter ${HOME}/.emailrelay/filter \
|
|
--spool-dir ${HOME}/.emailrelay/spool
|
|
|
|
The pre-processor program should terminate with an exit code of zero to indicate
|
|
success. An exit code of 100 can be used to cancel all further processing of the
|
|
message, and any other non-zero exit code is used to indicate an error.
|
|
|
|
For example, the following pre-processor shell script examines the client's
|
|
IP address and conditionally dumps the message into "sendmail" (using the
|
|
sendmail command-line interface rather than SMTP):
|
|
|
|
#!/bin/sh
|
|
#
|
|
content="${1}"
|
|
envelope="`echo \"${content}\" | sed 's/content/envelope/'`"
|
|
ip="`awk '/MailRelay-Client:/ {print $2;exit}' \"${envelope}\"`"
|
|
if test "${ip}" = "192.168.0.2"
|
|
then
|
|
cat "${content}" | /usr/sbin/sendmail -t
|
|
rm -f "${envelope}" "${content}"
|
|
exit 100 # <= cancel further processing by emailrelay
|
|
fi
|
|
exit 0
|
|
|
|
An example pre-processor script which does simple rot-13 masking of messages is
|
|
also provided in the distribution ("share/emailrelay/emailrelay-process.sh").
|
|
This could be used as a template for a more sophisticated message encryption
|
|
system.
|
|
|
|
Security issues
|
|
---------------
|
|
A major security concern is the use of an external mail pre-processor (using the
|
|
"--filter" switch), and so the following precautions are taken:
|
|
|
|
# effective userid
|
|
|
|
Suid privileges are revoked at start-up, switching the effective userid/groupid
|
|
to be the real userid/groupid values. If started as "root" then the effective
|
|
userid/groupid are taken from the "daemon" user. Special privileges are only
|
|
reclaimed when needed to bind sockets and do file i/o. Normally this means
|
|
temporarily switching the userid and groupid back to what they were at start-up.
|
|
However, when writing spool files only the effective userid is changed, not the
|
|
groupid.
|
|
|
|
# execution environment
|
|
|
|
The pre-processor runs with an almost empty set of environment variables ("PATH"
|
|
and "IFS"), and with no open file descriptors other than "stdin"/"stdout"/"stderr"
|
|
open onto "/dev/null".
|
|
|
|
# configuration
|
|
|
|
The pre-processor filename has to be configured using a full path, so there is
|
|
no dependence on the current working directory or the PATH environment variable.
|
|
|
|
Security issues which relate to the SMTP protocol itself are beyond the scope of
|
|
this document, but RFC2821 makes the following observation: "SMTP mail is
|
|
inherently insecure in that it is feasible for even [..] casual users to [..]
|
|
create messages that will trick a [..] recipient into believing that they came
|
|
from somewhere else. [..] Real [..] security lies [..] in end-to-end methods [..]
|
|
such as those which use digital signatures."
|
|
|
|
The "Authentication" section below also relates to security.
|
|
|
|
Some other points are:
|
|
* The program runs for most of the time with a "umask" of 177, switching to 117 when creating spool files.
|
|
* Strings are dynamically allocated, so buffer overflow/truncation issues are avoided.
|
|
* By default connections to the SMTP and administrative ports will be rejected if they come from remote machines.
|
|
* No configuration parameters can be changed through the administrative interface.
|
|
* No exec(), system() or popen() calls are used other than execve() to spawn the mail pre-processor.
|
|
* The submit utility is installed as set-group-id with group ownership of "daemon".
|
|
|
|
Authentication
|
|
--------------
|
|
E-MailRelay supports the ESMTP "AUTH" extension, as defined in RFC2554, on both
|
|
the server-side and client-side. The only authentication mechanisms currently
|
|
provided are the non-standard but widely used "LOGIN" mechanism, which uses
|
|
plaintext passwords, and the "CRAM-MD5" mechanism, as defined in RFC2195.
|
|
|
|
Authentication is enabled with the "--auth-client" and "--auth-server"
|
|
command-line switches. The switch parameter is the name of a "secrets" file,
|
|
containing usernames and passwords.
|
|
|
|
The secrets file has a line-based format: blank lines are ignored and the hash
|
|
character (#) is used for comments. Lines have four white-space delimited
|
|
fields: "mechanism", "client-or-server", "userid", and "secret". The "mechanism"
|
|
field must be "LOGIN" or "CRAM-MD5" (case-insensitive); the "client-or-server"
|
|
field must be "client" or "server"; the "userid" field is xtext-encoded user
|
|
identifier; and the "secret" field is the xtext-encoded "LOGIN" password or
|
|
"CRAM-MD5" key. The "xtext" encoding scheme is defined in RFC1891. The
|
|
"CRAM-MD5" keys can be generated using the "emailrelay-passwd" utility.
|
|
|
|
A client-side secrets file should contain at least one "LOGIN client" or
|
|
"CRAM-MD5 client" entry. A server-side secrets file should contain zero or
|
|
more "LOGIN server" or "CRAM-MD5 server" entries. The same secrets file may
|
|
be specified for both "--auth-client" and "--auth-server" switches.
|
|
|
|
For example, the following secrets file defines "jsmith" as the username to be
|
|
used when E-MailRelay authenticates with a next-hop server, and defines two
|
|
usernames ("user1" and "user2") which can be used by clients when they
|
|
authenticate with the E-MailRelay server:
|
|
|
|
#
|
|
# emailrelay secrets file
|
|
#
|
|
LOGIN client jsmith my+20password
|
|
LOGIN server user1 secret
|
|
LOGIN server user2 e+3Dmc2
|
|
|
|
A "CRAM-MD5" version would look like this:
|
|
|
|
#
|
|
# emailrelay secrets file
|
|
#
|
|
CRAM-MD5 client jsmith 688498119.2977922305.1278051807.3015243256.2216875978.2833592318.2902375592.3156808220
|
|
CRAM-MD5 server user1 4059553961.2316091643.3282746241.1444639637.3735501773.3404060330.2760590371.1201092398
|
|
CRAM-MD5 server user2 2798539199.3144534242.3784876256.2879973305.2327113479.216533878.2436460291.2361831919
|
|
|
|
When using the LOGIN mechanism you have to store plaintext passwords in a file
|
|
and then send them unencypted over a network. This is a bad thing. You should at
|
|
least make sure that the secrets file has tight permissions, and that the
|
|
passwords in it are not also used for anything important (such as root access).
|
|
|
|
On the server side authentication is advertised in the response to the SMTP
|
|
"EHLO" command if the "--auth-server" command line switch is used, but
|
|
authentication by the client is optional. If the client does authenticate then
|
|
the authenticated user-id is stored with the message and then passed on to a
|
|
next-hop server using an "AUTH=userid" parameter on the SMTP "MAIL FROM"
|
|
command. If the client chooses not to authenticate then the submitted messages
|
|
will be forwarded using "AUTH=<>" on the "MAIL FROM" command. Note that any
|
|
"AUTH=userid" information on incoming submitted messages is ignored and
|
|
discarded: it is the authorised userid from the AUTH command which is
|
|
propagated, not the userid from the incoming "MAIL FROM" command's "AUTH="
|
|
parameter.
|
|
|
|
On the client side authentication is performed when the client has connected to
|
|
a server which supports the AUTH extension with the LOGIN or CRAM-MD5 mechanism.
|
|
If client authentication is enabled (with the "--auth-client" switch) but the
|
|
server does not support the AUTH extension, or does not support the LOGIN or
|
|
CRAM-MD5 mechanism, then the client will fail the first message and terminate
|
|
with an error message.
|
|
|
|
Note that some ISPs require separate POP/IMAP authentication before SMTP access
|
|
from a particular IP address is allowed. This type of POP-before-SMTP
|
|
authentication can be done outside the E-MailRelay system by POP/IMAP utilities
|
|
such as "fetchmail".
|
|
|
|
Installation directories
|
|
------------------------
|
|
By default "make install" installs files in the following locations:
|
|
* /usr/local/libexec/emailrelay-poke
|
|
* /usr/local/libexec/emailrelay-notify.sh
|
|
* /usr/local/libexec/emailrelay-deliver.sh
|
|
* /usr/local/libexec/emailrelay-resubmit.sh
|
|
* /usr/local/libexec/emailrelay
|
|
* /usr/local/libexec/emailrelay-process.sh
|
|
* /usr/local/sbin/emailrelay
|
|
* /usr/local/sbin/emailrelay-passwd
|
|
* /usr/local/sbin/emailrelay-submit
|
|
* /usr/local/var/spool/emailrelay/*
|
|
* /usr/local/share/emailrelay/doc/developer.txt
|
|
* /usr/local/share/emailrelay/doc/reference.txt
|
|
* /usr/local/share/emailrelay/doc/userguide.txt
|
|
* /usr/local/share/emailrelay/doc/windows.txt
|
|
* /usr/local/share/emailrelay/doc/readme.html
|
|
* /usr/local/share/emailrelay/doc/developer.html
|
|
* /usr/local/share/emailrelay/doc/reference.html
|
|
* /usr/local/share/emailrelay/doc/userguide.html
|
|
* /usr/local/share/emailrelay/doc/windows.html
|
|
* /usr/local/share/emailrelay/doc/emailrelay-man.html
|
|
* /usr/local/share/emailrelay/doc/index.html
|
|
* /usr/local/share/emailrelay/doc/changelog.html
|
|
* /usr/local/share/emailrelay/doc/emailrelay.css
|
|
* /usr/local/share/emailrelay/doc/NEWS
|
|
* /usr/local/share/emailrelay/doc/README
|
|
* /usr/local/share/emailrelay/doc/changelog.gz
|
|
* /usr/local/share/emailrelay/doc/doxygen/*
|
|
* /usr/local/man/man1/emailrelay.1.gz
|
|
* /usr/local/man/man1/emailrelay-passwd.1.gz
|
|
* /usr/local/man/man1/emailrelay-poke.1.gz
|
|
* /usr/local/man/man1/emailrelay-submit.1.gz
|
|
|
|
This directory structure is constrained by the GNU/"autoconf" conventions rather
|
|
than the Filesystem Hierarchy Standard (FHS).
|
|
|
|
To force FHS compliance you can use the "--enable-fhs" switch when running
|
|
"configure". This results in the following file locations:
|
|
* /usr/lib/emailrelay/emailrelay-poke
|
|
* /usr/sbin/emailrelay
|
|
* /usr/sbin/emailrelay-passwd
|
|
* /usr/sbin/emailrelay-submit
|
|
* /usr/share/doc/emailrelay/examples/emailrelay-notify.sh
|
|
* /usr/share/doc/emailrelay/examples/emailrelay-deliver.sh
|
|
* /usr/share/doc/emailrelay/examples/emailrelay-resubmit.sh
|
|
* /usr/share/doc/emailrelay/examples/emailrelay-process.sh
|
|
* /usr/share/doc/emailrelay/developer.txt
|
|
* /usr/share/doc/emailrelay/reference.txt
|
|
* /usr/share/doc/emailrelay/userguide.txt
|
|
* /usr/share/doc/emailrelay/windows.txt
|
|
* /usr/share/doc/emailrelay/readme.html
|
|
* /usr/share/doc/emailrelay/developer.html
|
|
* /usr/share/doc/emailrelay/reference.html
|
|
* /usr/share/doc/emailrelay/userguide.html
|
|
* /usr/share/doc/emailrelay/windows.html
|
|
* /usr/share/doc/emailrelay/emailrelay-man.html
|
|
* /usr/share/doc/emailrelay/index.html
|
|
* /usr/share/doc/emailrelay/changelog.html
|
|
* /usr/share/doc/emailrelay/emailrelay.css
|
|
* /usr/share/doc/emailrelay/NEWS
|
|
* /usr/share/doc/emailrelay/README
|
|
* /usr/share/doc/emailrelay/changelog.gz
|
|
* /usr/share/doc/emailrelay/doxygen/*
|
|
* /usr/share/man/man1/emailrelay.1.gz
|
|
* /usr/share/man/man1/emailrelay-passwd.1.gz
|
|
* /usr/share/man/man1/emailrelay-poke.1.gz
|
|
* /usr/share/man/man1/emailrelay-submit.1.gz
|
|
* /var/spool/emailrelay/*
|
|
* /etc/init.d/emailrelay
|
|
|
|
For finer control of the directory structure the following variables
|
|
can be specified on the "configure" command line (but note that the
|
|
"--enable-fhs" will override them):
|
|
* e_sbindir
|
|
* e_libexecdir
|
|
* e_docdir
|
|
* e_initdir
|
|
* e_spooldir
|
|
* e_man1dir
|
|
* e_examplesdir
|
|
|
|
For example, running "./configure --prefix=/usr e_spooldir=/tmp/spool" will
|
|
create the GNU-style directory structure under "/usr" rather than "/usr/local",
|
|
and create the E-MailRelay spool directory as "/tmp/spool" rather than
|
|
"/usr/local/var/spool/emailrelay".
|
|
|
|
The default spool directory path which is built into the executables and scripts
|
|
comes from "configure", via the makefiles. So if you re-run "configure" with a
|
|
different spool directory you should also do a "make clean" in at least
|
|
"src/main" and "bin".
|
|
|
|
The "emailrelay" script in "init.d" creates a pid file in "/var/run" if the
|
|
directory exists, or in "/tmp" otherwise.
|
|
|
|
|
|
Copyright (C) 2001-2002 Graeme Walker <graeme_walker@users.sourceforge.net>. All rights reserved.
|