.\" Copyright (C) 2001-2022 Graeme Walker .\" .\" This program is free software: you can redistribute it and/or modify .\" it under the terms of the GNU General Public License as published by .\" the Free Software Foundation, either version 3 of the License, or .\" (at your option) any later version. .\" .\" This program is distributed in the hope that it will be useful, .\" but WITHOUT ANY WARRANTY; without even the implied warranty of .\" MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the .\" GNU General Public License for more details. .\" .\" You should have received a copy of the GNU General Public License .\" along with this program. If not, see . .TH EMAILRELAY 1 local .SH NAME emailrelay \- e-mail transfer agent and proxy .SH SYNOPSIS .B emailrelay [OPTIONS] .LP .B emailrelay --as-server .LP .B emailrelay --as-client .I server-address .LP .B emailrelay --as-proxy .I server-address .SH DESCRIPTION .I emailrelay is a simple SMTP proxy and store-and-forward message transfer agent. It does store-and-forward mail relay to a fixed next-hop server, without any routing. .LP It runs in two main modes: a storage daemon .RI ( --as-server ) and a forwarding agent .RI ( --as-client ). The storage daemon is an SMTP server which stores e-mail messages in a local spool directory. The forwarding agent acts as an SMTP client sending the spooled e-mail messages on to the next SMTP server in the chain. .LP It can also run in a third mode, as a proxy server .RI ( --as-proxy ). In this mode all e-mail messages are spooled temporarily while the client is connected and forwarded as soon as the client disconnects. .SH OPTIONS .SS Basic options .TP .B \-q, --as-client \fI\fR This is equivalent to \fI--log\fR, \fI--no-syslog\fR, \fI--no-daemon\fR, \fI--dont-serve\fR, \fI--forward\fR and \fI--forward-to\fR. It is a convenient way of running a forwarding agent that forwards spooled mail messages and then terminates. .TP .B \-y, --as-proxy \fI\fR This is equivalent to \fI--log\fR, \fI--close-stderr\fR, \fI--forward-on-disconnect\fR and \fI--forward-to\fR. It is a convenient way of running a store-and-forward daemon. Use \fI--log\fR, \fI--forward-on-disconnect\fR and \fI--forward-to\fR instead of \fI--as-proxy\fR to keep the standard error stream open. .TP .B \-d, --as-server This is equivalent to \fI--log\fR and \fI--close-stderr\fR. It is a convenient way of running a background storage daemon that accepts mail messages and spools them. Use \fI--log\fR instead of \fI--as-server\fR to keep standard error stream open. .TP .B \-s, --spool-dir \fI\fR Specifies the directory used for holding mail messages that have been received but not yet forwarded. .TP .B \-h, --help Displays help text and then exits. Use with \fI--verbose\fR for more complete output. .TP .B \-V, --version Displays version information and then exits. .SS SMTP client options .TP .B \-f, --forward Causes spooled mail messages to be forwarded when the program first starts. .TP .B \-1, --forward-on-disconnect Causes spooled mail messages to be forwarded whenever a SMTP client connection disconnects. .TP .B \-o, --forward-to \fI\fR Specifies the transport address of the remote SMTP server that spooled mail messages are forwarded to. .TP .B \-O, --poll \fI\fR Causes forwarding of spooled mail messages to happen at regular intervals (with the time given in seconds). .TP .B \-Y, --client-filter \fI\fR Runs the specified external filter program whenever a mail message is forwarded. The filter is passed the name of the message file in the spool directory so that it can edit it as required. A network filter can be specified as \fInet:\fR and prefixes of \fIspam:\fR, \fIspam-edit:\fR and \fIexit:\fR are also allowed. The \fIspam:\fR and \fIspam-edit:\fR prefixes require a SpamAssassin daemon to be running. For store-and-forward applications the \fI--filter\fR option is normally more useful than \fI--client-filter\fR. .TP .B \-6, --client-interface \fI\fR Specifies the IP network address to be used to bind the local end of outgoing SMTP connections. By default the address will depend on the routing tables in the normal way. Use \fI0.0.0.0\fR to use only IPv4 addresses returned from DNS lookups of the \fI--forward-to\fR address, or \fI::\fR for IPv6. .TP .B \-U, --connection-timeout \fI