Graeme Walker 3ce0ea8b14 v1.0.1
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2002-04-25 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2001-09-08 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2002-08-16 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2003-01-18 12:00:00 +00:00
2002-08-16 12:00:00 +00:00
2003-01-18 12:00:00 +00:00

E-MailRelay Readme
==================

Abstract
--------
E-MailRelay is a simple SMTP store-and-forward message transfer agent (MTA).
It runs as an SMTP server, storing e-mail in a local spool directory, and
then forwarding the stored messages to the next SMTP server on request. 
It can also run as a proxy server, forwarding (and optionally pre-processing)
e-mail as soon as it is received. It does not do any message routing, other
than to a local postmaster. Because of this functional simplicity it is 
extremely easy to configure, typically only requiring the address of the 
next-hop SMTP server to be put on the command line.

C++ source code is available for Linux, FreeBSD (etc) and Windows. 
Distribution is under the GNU General Public License.

Quick start
-----------
E-MailRelay can be built and installed from source using the ususal
"./configure ; make ; make install" incantation. The program runs as an SMTP 
server daemon using the "emailrelay --as-server" command, and stored mail is 
forwarded to the next-hop server by running "emailrelay --as-client <isp-mail-server>:smtp". 

The "--as-server" command is typically run automatically at boot time, using
the boot scripts under "/etc/init.d" or "/sbin/init.d", while the "--as-client"
command is normally put into pppd's "ip-up" script ("/etc/ppp/ip-up") 
in place of "sendmail -q".

The program can also run as a proxy server ("--as-proxy") so that e-mail 
messages are forwarded immediately to the next-hop server -- usually the local 
system's default MTA. This can be usefully combined with a mail pre-processor 
program by using the "--filter" switch.

The program requires a writeable spool directory to store e-mail messages.
The directory defaults to "/usr/local/var/spool/emailrelay", but it
can be changed by using the "--spool-dir" switch.

By default the server will try to listen on TCP port 25. If another SMTP
server is running then it will fail to start up, with a "cannot bind" error 
message. The port number can be changed by using the "--port" switch.

To test the program out without a full installation:
(1) run the server as "emailrelay --no-daemon --no-syslog --log --spool-dir ${HOME} --port 10025 &"
(2) reconfigure your e-mail client to use port 10025 rather than 25 ("smtp")
(3) send some test messages to addressees on the Internet
(4) connect to the Internet
(5) forward the stored messages using "emailrelay --spool-dir ${HOME} --as-client <your-isp-smtp-host>:smtp"
(6) clean up with "killall emailrelay ; rm ${HOME}/emailrelay.*"

Documentation
-------------
The following documentation is provided in the source distribution:
* README             -- this document
* COPYING            -- the GNU General Public License
* INSTALL            -- build & install instructions (including the generic GNU text)
* AUTHORS            -- authors, credits and additional copyrights
* copyright          -- main copyright and GPL reference 
* doc/userguide.txt  -- user guide
* doc/reference.txt  -- reference document
* ChangeLog          -- change log for releases

Additional documents, including source-code documentation generated by 
doxygen (www.doxygen.org), is available in a separate package,
"emailrelay-doc".

Configurations
--------------
The code was originally developed on SuSE Linux 7.1 using:
* linux 2.4.10
* gcc 2.95.3
* glibc 2.2.4 (libc.so.6)
* gnu make 3.79.1
* autoconf 2.52

and ported to Windows 98 using:
* MSVC 6.0

Recent releases were developed on SuSE Linux 8.0 and 
RedHat Linux 8.0 using:
* gcc 2.95.3 and 3.2
* autoconf 2.53

The code has also been built successfully on:
* Windows NT 4.0
* MacOS X
* FreeBSD on Intel hardware
* Solaris 8, using gcc, on Sparc hardware
* Linux on Alpha hardware (Debian 2.2)
* Linux on Sparc hardware
* Linux on RS6000 PPC hardware


Feedback
--------
Please feel free to email the author at 
"mailto:graeme_walker@users.sourceforge.net".

Languages
C++ 68.7%
Makefile 16.2%
Perl 7.8%
M4 2.8%
Shell 2.6%
Other 1.8%