<!DOCTYPE html PUBLIC "XSLT-compat"> <html lang="en-GB"> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <link rel="stylesheet" type="text/css" href="../../../../common.css"> <meta name="author" content="The Exim Project. <http://www.exim.org/>"> <meta name="copyright" content="Copyright ©2010 The Exim Project. All rights reserved"> <meta name="description" content="Exim is a message transfer agent (MTA) developed at the University of Cambridge for use on Unix systems connected to the Internet."> <meta name="keywords" content="exim,smtp,mta,email"> <meta name="robots" content="noodp,noydir,index,follow"> <meta name="viewport" content="width=device-width"> <title>20. The manualroute router</title> <link rel="stylesheet" type="text/css" href="../../../../doc/chapter.css"> <link rel="canonical" href="http://www.exim.org/exim-html-current/doc/html/spec_html/ch20.html"> </head> <body> <h1 id="header"><a href="../../../..">Exim Internet Mailer</a></h1> <div id="outer"> <ul id="nav_flow" class="nav"> <li><a href="../../../../index.html">Home</a></li> <li><a href="../../../../mirrors.html">Download</a></li> <li><a href="../../../../docs.html">Documentation</a></li> <li><a href="../../../../maillist.html">Mailing Lists</a></li> <li><a href="http://wiki.exim.org/">Wiki</a></li> <li><a href="http://www.exim.org/bugzilla/">Bugs</a></li> <li><a href="../../../../credits.html">Credits</a></li> <li class="search"><form action="http://www.google.com/search" method="get"> <span class="search_field_container"><input type="search" name="q" placeholder="Search Docs" class="search_field"></span><input type="hidden" name="hl" value="en"><input type="hidden" name="ie" value="UTF-8"><input type="hidden" name="as_qdr" value="all"><input type="hidden" name="q" value="site:www.exim.org"><input type="hidden" name="q" value="inurl:exim-html-current"> </form></li> </ul> <div id="inner"><div id="content"> <a class="previous_page" href="ch19.html"><-previous</a><a class="next_page" href="ch21.html">next-></a><div id="chapter" class="chapter"> <h2 id="CHID7" class="">Chapter 20 - The manualroute router</h2> <p> The <span class="docbook_command">manualroute</span> router is so-called because it provides a way of manually routing an address according to its domain. It is mainly used when you want to route addresses to remote hosts according to your own rules, bypassing the normal DNS routing that looks up MX records. However, <span class="docbook_command">manualroute</span> can also route to local transports, a facility that may be useful if you want to save messages for dial-in hosts in local files. </p> <p> The <span class="docbook_command">manualroute</span> router compares a list of domain patterns with the domain it is trying to route. If there is no match, the router declines. Each pattern has associated with it a list of hosts and some other optional data, which may include a transport. The combination of a pattern and its data is called a “routing rule”. For patterns that do not have an associated transport, the generic <span class="docbook_option">transport</span> option must specify a transport, unless the router is being used purely for verification (see <span class="docbook_option">verify_only</span>). </p> <p> In the case of verification, matching the domain pattern is sufficient for the router to accept the address. When actually routing an address for delivery, an address that matches a domain pattern is queued for the associated transport. If the transport is not a local one, a host list must be associated with the pattern; IP addresses are looked up for the hosts, and these are passed to the transport along with the mail address. For local transports, a host list is optional. If it is present, it is passed in $host as a single text string. </p> <p> The list of routing rules can be provided as an inline string in <span class="docbook_option">route_list</span>, or the data can be obtained by looking up the domain in a file or database by setting <span class="docbook_option">route_data</span>. Only one of these settings may appear in any one instance of <span class="docbook_command">manualroute</span>. The format of routing rules is described below, following the list of private options. </p> <div class="section"> <h3 id="SECTprioptman" class="">1. Private options for manualroute</h3> <p> The private options for the <span class="docbook_command">manualroute</span> router are as follows: </p> <p> </p> <table> <tr> <td><span class="docbook_option">host_all_ignored</span></td> <td>Use: <span class="docbook_emphasis">manualroute</span> </td> <td>Type: <span class="docbook_emphasis">string</span> </td> <td>Default: <span class="docbook_emphasis">defer</span> </td> </tr> </table> <p> See <span class="docbook_option">host_find_failed</span>. </p> <p> </p> <table> <tr> <td><span class="docbook_option">host_find_failed</span></td> <td>Use: <span class="docbook_emphasis">manualroute</span> </td> <td>Type: <span class="docbook_emphasis">string</span> </td> <td>Default: <span class="docbook_emphasis">freeze</span> </td> </tr> </table> <p> This option controls what happens when <span class="docbook_command">manualroute</span> tries to find an IP address for a host, and the host does not exist. The option can be set to one of the following values: </p> <div class="docbook_literallayout"><pre> decline defer fail freeze ignore pass </pre></div> <p> The default (“freeze”) assumes that this state is a serious configuration error. The difference between “pass” and “decline” is that the former forces the address to be passed to the next router (or the router defined by <span class="docbook_option">pass_router</span>), overriding <span class="docbook_option">no_more</span>, whereas the latter passes the address to the next router only if <span class="docbook_option">more</span> is true. </p> <p> The value “ignore” causes Exim to completely ignore a host whose IP address cannot be found. If all the hosts in the list are ignored, the behaviour is controlled by the <span class="docbook_option">host_all_ignored</span> option. This takes the same values as <span class="docbook_option">host_find_failed</span>, except that it cannot be set to “ignore”. </p> <p> The <span class="docbook_option">host_find_failed</span> option applies only to a definite “does not exist” state; if a host lookup gets a temporary error, delivery is deferred unless the generic <span class="docbook_option">pass_on_timeout</span> option is set. </p> <p> </p> <table> <tr> <td><span class="docbook_option">hosts_randomize</span></td> <td>Use: <span class="docbook_emphasis">manualroute</span> </td> <td>Type: <span class="docbook_emphasis">boolean</span> </td> <td>Default: <span class="docbook_emphasis">false</span> </td> </tr> </table> <p> If this option is set, the order of the items in a host list in a routing rule is randomized each time the list is used, unless an option in the routing rule overrides (see below). Randomizing the order of a host list can be used to do crude load sharing. However, if more than one mail address is routed by the same router to the same host list, the host lists are considered to be the same (even though they may be randomized into different orders) for the purpose of deciding whether to batch the deliveries into a single SMTP transaction. </p> <p> When <span class="docbook_option">hosts_randomize</span> is true, a host list may be split into groups whose order is separately randomized. This makes it possible to set up MX-like behaviour. The boundaries between groups are indicated by an item that is just <code class="docbook_literal">+</code> in the host list. For example: </p> <div class="docbook_literallayout"><pre> route_list = * host1:host2:host3:+:host4:host5 </pre></div> <p> The order of the first three hosts and the order of the last two hosts is randomized for each use, but the first three always end up before the last two. If <span class="docbook_option">hosts_randomize</span> is not set, a <code class="docbook_literal">+</code> item in the list is ignored. If a randomized host list is passed to an <span class="docbook_command">smtp</span> transport that also has <span class="docbook_option">hosts_randomize set</span>, the list is not re-randomized. </p> <p> </p> <table> <tr> <td><span class="docbook_option">route_data</span></td> <td>Use: <span class="docbook_emphasis">manualroute</span> </td> <td>Type: <span class="docbook_emphasis">string</span>†<span class="docbook_emphasis"></span> </td> <td>Default: <span class="docbook_emphasis">unset</span> </td> </tr> </table> <p> If this option is set, it must expand to yield the data part of a routing rule. Typically, the expansion string includes a lookup based on the domain. For example: </p> <div class="docbook_literallayout"><pre> route_data = ${lookup{$domain}dbm{/etc/routes}} </pre></div> <p> If the expansion is forced to fail, or the result is an empty string, the router declines. Other kinds of expansion failure cause delivery to be deferred. </p> <p> </p> <table> <tr> <td><span class="docbook_option">route_list</span></td> <td>Use: <span class="docbook_emphasis">manualroute</span> </td> <td>Type: <span class="docbook_emphasis">string list</span> </td> <td>Default: <span class="docbook_emphasis">unset</span> </td> </tr> </table> <p> This string is a list of routing rules, in the form defined below. Note that, unlike most string lists, the items are separated by semicolons. This is so that they may contain colon-separated host lists. </p> <p> </p> <table> <tr> <td><span class="docbook_option">same_domain_copy_routing</span></td> <td>Use: <span class="docbook_emphasis">manualroute</span> </td> <td>Type: <span class="docbook_emphasis">boolean</span> </td> <td>Default: <span class="docbook_emphasis">false</span> </td> </tr> </table> <p> Addresses with the same domain are normally routed by the <span class="docbook_command">manualroute</span> router to the same list of hosts. However, this cannot be presumed, because the router options and preconditions may refer to the local part of the address. By default, therefore, Exim routes each address in a message independently. DNS servers run caches, so repeated DNS lookups are not normally expensive, and in any case, personal messages rarely have more than a few recipients. </p> <p> If you are running mailing lists with large numbers of subscribers at the same domain, and you are using a <span class="docbook_command">manualroute</span> router which is independent of the local part, you can set <span class="docbook_option">same_domain_copy_routing</span> to bypass repeated DNS lookups for identical domains in one message. In this case, when <span class="docbook_command">manualroute</span> routes an address to a remote transport, any other unrouted addresses in the message that have the same domain are automatically given the same routing without processing them independently. However, this is only done if <span class="docbook_option">headers_add</span> and <span class="docbook_option">headers_remove</span> are unset. </p> </div> <div class="section"> <h3 id="SECID120" class="">2. Routing rules in route_list</h3> <p> The value of <span class="docbook_option">route_list</span> is a string consisting of a sequence of routing rules, separated by semicolons. If a semicolon is needed in a rule, it can be entered as two semicolons. Alternatively, the list separator can be changed as described (for colon-separated lists) in section <a href="ch06.html#SECTlistconstruct" title="6. The Exim run time configuration file">6.19</a>. Empty rules are ignored. The format of each rule is </p> <div class="docbook_literallayout"><pre> <<span class="docbook_emphasis">domain pattern</span>> <<span class="docbook_emphasis">list of hosts</span>> <<span class="docbook_emphasis">options</span>> </pre></div> <p> The following example contains two rules, each with a simple domain pattern and no options: </p> <div class="docbook_literallayout"><pre> route_list = \ dict.ref.example mail-1.ref.example:mail-2.ref.example ; \ thes.ref.example mail-3.ref.example:mail-4.ref.example </pre></div> <p> The three parts of a rule are separated by white space. The pattern and the list of hosts can be enclosed in quotes if necessary, and if they are, the usual quoting rules apply. Each rule in a <span class="docbook_option">route_list</span> must start with a single domain pattern, which is the only mandatory item in the rule. The pattern is in the same format as one item in a domain list (see section <a href="ch10.html#SECTdomainlist" title="10. Domain, host, address, and local part lists">10.8</a>), except that it may not be the name of an interpolated file. That is, it may be wildcarded, or a regular expression, or a file or database lookup (with semicolons doubled, because of the use of semicolon as a separator in a <span class="docbook_option">route_list</span>). </p> <p> The rules in <span class="docbook_option">route_list</span> are searched in order until one of the patterns matches the domain that is being routed. The list of hosts and then options are then used as described below. If there is no match, the router declines. When <span class="docbook_option">route_list</span> is set, <span class="docbook_option">route_data</span> must not be set. </p> </div> <div class="section"> <h3 id="SECID121" class="">3. Routing rules in route_data</h3> <p> The use of <span class="docbook_option">route_list</span> is convenient when there are only a small number of routing rules. For larger numbers, it is easier to use a file or database to hold the routing information, and use the <span class="docbook_option">route_data</span> option instead. The value of <span class="docbook_option">route_data</span> is a list of hosts, followed by (optional) options. Most commonly, <span class="docbook_option">route_data</span> is set as a string that contains an expansion lookup. For example, suppose we place two routing rules in a file like this: </p> <div class="docbook_literallayout"><pre> dict.ref.example: mail-1.ref.example:mail-2.ref.example thes.ref.example: mail-3.ref.example:mail-4.ref.example </pre></div> <p> This data can be accessed by setting </p> <div class="docbook_literallayout"><pre> route_data = ${lookup{$domain}lsearch{/the/file/name}} </pre></div> <p> Failure of the lookup results in an empty string, causing the router to decline. However, you do not have to use a lookup in <span class="docbook_option">route_data</span>. The only requirement is that the result of expanding the string is a list of hosts, possibly followed by options, separated by white space. The list of hosts must be enclosed in quotes if it contains white space. </p> </div> <div class="section"> <h3 id="SECID122" class="">4. Format of the list of hosts</h3> <p> A list of hosts, whether obtained via <span class="docbook_option">route_data</span> or <span class="docbook_option">route_list</span>, is always separately expanded before use. If the expansion fails, the router declines. The result of the expansion must be a colon-separated list of names and/or IP addresses, optionally also including ports. The format of each item in the list is described in the next section. The list separator can be changed as described in section <a href="ch06.html#SECTlistconstruct" title="6. The Exim run time configuration file">6.19</a>. </p> <p> If the list of hosts was obtained from a <span class="docbook_option">route_list</span> item, the following variables are set during its expansion: </p> <ul> <li> <p> If the domain was matched against a regular expression, the numeric variables $1, $2, etc. may be set. For example: </p> <div class="docbook_literallayout"><pre> route_list = ^domain(\d+) host-$1.text.example </pre></div> </li> <li> <p> $0 is always set to the entire domain. </p> </li> <li> <p> $1 is also set when partial matching is done in a file lookup. </p> </li> <li> <p> If the pattern that matched the domain was a lookup item, the data that was looked up is available in the expansion variable $value. For example: </p> <div class="docbook_literallayout"><pre> route_list = lsearch;;/some/file.routes $value </pre></div> </li> </ul> <p> Note the doubling of the semicolon in the pattern that is necessary because semicolon is the default route list separator. </p> </div> <div class="section"> <h3 id="SECTformatonehostitem" class="">5. Format of one host item</h3> <p> Each item in the list of hosts is either a host name or an IP address, optionally with an attached port number. When no port is given, an IP address is not enclosed in brackets. When a port is specified, it overrides the port specification on the transport. The port is separated from the name or address by a colon. This leads to some complications: </p> <ul> <li> <p> Because colon is the default separator for the list of hosts, either the colon that specifies a port must be doubled, or the list separator must be changed. The following two examples have the same effect: </p> <div class="docbook_literallayout"><pre> route_list = * "host1.tld::1225 : host2.tld::1226" route_list = * "<+ host1.tld:1225 + host2.tld:1226" </pre></div> </li> <li> <p> When IPv6 addresses are involved, it gets worse, because they contain colons of their own. To make this case easier, it is permitted to enclose an IP address (either v4 or v6) in square brackets if a port number follows. For example: </p> <div class="docbook_literallayout"><pre> route_list = * "</ [10.1.1.1]:1225 / [::1]:1226" </pre></div> </li> </ul> </div> <div class="section"> <h3 id="SECThostshowused" class="">6. How the list of hosts is used</h3> <p> When an address is routed to an <span class="docbook_command">smtp</span> transport by <span class="docbook_command">manualroute</span>, each of the hosts is tried, in the order specified, when carrying out the SMTP delivery. However, the order can be changed by setting the <span class="docbook_option">hosts_randomize</span> option, either on the router (see section <a href="ch20.html#SECTprioptman" title="20. The manualroute router">20.1</a> above), or on the transport. </p> <p> Hosts may be listed by name or by IP address. An unadorned name in the list of hosts is interpreted as a host name. A name that is followed by <code class="docbook_literal">/MX</code> is interpreted as an indirection to a sublist of hosts obtained by looking up MX records in the DNS. For example: </p> <div class="docbook_literallayout"><pre> route_list = * x.y.z:p.q.r/MX:e.f.g </pre></div> <p> If this feature is used with a port specifier, the port must come last. For example: </p> <div class="docbook_literallayout"><pre> route_list = * dom1.tld/mx::1225 </pre></div> <p> If the <span class="docbook_option">hosts_randomize</span> option is set, the order of the items in the list is randomized before any lookups are done. Exim then scans the list; for any name that is not followed by <code class="docbook_literal">/MX</code> it looks up an IP address. If this turns out to be an interface on the local host and the item is not the first in the list, Exim discards it and any subsequent items. If it is the first item, what happens is controlled by the <span class="docbook_option">self</span> option of the router. </p> <p> A name on the list that is followed by <code class="docbook_literal">/MX</code> is replaced with the list of hosts obtained by looking up MX records for the name. This is always a DNS lookup; the <span class="docbook_option">bydns</span> and <span class="docbook_option">byname</span> options (see section <a href="ch20.html#SECThowoptused" title="20. The manualroute router">20.7</a> below) are not relevant here. The order of these hosts is determined by the preference values in the MX records, according to the usual rules. Because randomizing happens before the MX lookup, it does not affect the order that is defined by MX preferences. </p> <p> If the local host is present in the sublist obtained from MX records, but is not the most preferred host in that list, it and any equally or less preferred hosts are removed before the sublist is inserted into the main list. </p> <p> If the local host is the most preferred host in the MX list, what happens depends on where in the original list of hosts the <code class="docbook_literal">/MX</code> item appears. If it is not the first item (that is, there are previous hosts in the main list), Exim discards this name and any subsequent items in the main list. </p> <p> If the MX item is first in the list of hosts, and the local host is the most preferred host, what happens is controlled by the <span class="docbook_option">self</span> option of the router. </p> <p> DNS failures when lookup up the MX records are treated in the same way as DNS failures when looking up IP addresses: <span class="docbook_option">pass_on_timeout</span> and <span class="docbook_option">host_find_failed</span> are used when relevant. </p> <p> The generic <span class="docbook_option">ignore_target_hosts</span> option applies to all hosts in the list, whether obtained from an MX lookup or not. </p> </div> <div class="section"> <h3 id="SECThowoptused" class="">7. How the options are used</h3> <p> The options are a sequence of words; in practice no more than three are ever present. One of the words can be the name of a transport; this overrides the <span class="docbook_option">transport</span> option on the router for this particular routing rule only. The other words (if present) control randomization of the list of hosts on a per-rule basis, and how the IP addresses of the hosts are to be found when routing to a remote transport. These options are as follows: </p> <ul> <li> <p> <span class="docbook_option">randomize</span>: randomize the order of the hosts in this list, overriding the setting of <span class="docbook_option">hosts_randomize</span> for this routing rule only. </p> </li> <li> <p> <span class="docbook_option">no_randomize</span>: do not randomize the order of the hosts in this list, overriding the setting of <span class="docbook_option">hosts_randomize</span> for this routing rule only. </p> </li> <li> <p> <span class="docbook_option">byname</span>: use <span class="docbook_function">getipnodebyname()</span> (<span class="docbook_function">gethostbyname()</span> on older systems) to find IP addresses. This function may ultimately cause a DNS lookup, but it may also look in <span class="docbook_filename">/etc/hosts</span> or other sources of information. </p> </li> <li> <p> <span class="docbook_option">bydns</span>: look up address records for the hosts directly in the DNS; fail if no address records are found. If there is a temporary DNS error (such as a timeout), delivery is deferred. </p> </li> </ul> <p> For example: </p> <div class="docbook_literallayout"><pre> route_list = domain1 host1:host2:host3 randomize bydns;\ domain2 host4:host5 </pre></div> <p> If neither <span class="docbook_option">byname</span> nor <span class="docbook_option">bydns</span> is given, Exim behaves as follows: First, a DNS lookup is done. If this yields anything other than HOST_NOT_FOUND, that result is used. Otherwise, Exim goes on to try a call to <span class="docbook_function">getipnodebyname()</span> or <span class="docbook_function">gethostbyname()</span>, and the result of the lookup is the result of that call. </p> <p> <span class="docbook_emphasis">Warning</span>: It has been discovered that on some systems, if a DNS lookup called via <span class="docbook_function">getipnodebyname()</span> times out, HOST_NOT_FOUND is returned instead of TRY_AGAIN. That is why the default action is to try a DNS lookup first. Only if that gives a definite “no such host” is the local function called. </p> <p> If no IP address for a host can be found, what happens is controlled by the <span class="docbook_option">host_find_failed</span> option. </p> <p> When an address is routed to a local transport, IP addresses are not looked up. The host list is passed to the transport in the $host variable. </p> </div> <div class="section"> <h3 id="SECID123" class="">8. Manualroute examples</h3> <p> In some of the examples that follow, the presence of the <span class="docbook_option">remote_smtp</span> transport, as defined in the default configuration file, is assumed: </p> <ul> <li> <p> The <span class="docbook_command">manualroute</span> router can be used to forward all external mail to a <span class="docbook_emphasis">smart host</span>. If you have set up, in the main part of the configuration, a named domain list that contains your local domains, for example: </p> <div class="docbook_literallayout"><pre> domainlist local_domains = my.domain.example </pre></div> <p> You can arrange for all other domains to be routed to a smart host by making your first router something like this: </p> <div class="docbook_literallayout"><pre> smart_route: driver = manualroute domains = !+local_domains transport = remote_smtp route_list = * smarthost.ref.example </pre></div> <p> This causes all non-local addresses to be sent to the single host <span class="docbook_emphasis">smarthost.ref.example</span>. If a colon-separated list of smart hosts is given, they are tried in order (but you can use <span class="docbook_option">hosts_randomize</span> to vary the order each time). Another way of configuring the same thing is this: </p> <div class="docbook_literallayout"><pre> smart_route: driver = manualroute transport = remote_smtp route_list = !+local_domains smarthost.ref.example </pre></div> <p> There is no difference in behaviour between these two routers as they stand. However, they behave differently if <span class="docbook_option">no_more</span> is added to them. In the first example, the router is skipped if the domain does not match the <span class="docbook_option">domains</span> precondition; the following router is always tried. If the router runs, it always matches the domain and so can never decline. Therefore, <span class="docbook_option">no_more</span> would have no effect. In the second case, the router is never skipped; it always runs. However, if it doesn’t match the domain, it declines. In this case <span class="docbook_option">no_more</span> would prevent subsequent routers from running. </p> </li> <li> <p> A <span class="docbook_emphasis">mail hub</span> is a host which receives mail for a number of domains via MX records in the DNS and delivers it via its own private routing mechanism. Often the final destinations are behind a firewall, with the mail hub being the one machine that can connect to machines both inside and outside the firewall. The <span class="docbook_command">manualroute</span> router is usually used on a mail hub to route incoming messages to the correct hosts. For a small number of domains, the routing can be inline, using the <span class="docbook_option">route_list</span> option, but for a larger number a file or database lookup is easier to manage. </p> <p> If the domain names are in fact the names of the machines to which the mail is to be sent by the mail hub, the configuration can be quite simple. For example: </p> <div class="docbook_literallayout"><pre> hub_route: driver = manualroute transport = remote_smtp route_list = *.rhodes.tvs.example $domain </pre></div> <p> This configuration routes domains that match <code class="docbook_literal">*.rhodes.tvs.example</code> to hosts whose names are the same as the mail domains. A similar approach can be taken if the host name can be obtained from the domain name by a string manipulation that the expansion facilities can handle. Otherwise, a lookup based on the domain can be used to find the host: </p> <div class="docbook_literallayout"><pre> through_firewall: driver = manualroute transport = remote_smtp route_data = ${lookup {$domain} cdb {/internal/host/routes}} </pre></div> <p> The result of the lookup must be the name or IP address of the host (or hosts) to which the address is to be routed. If the lookup fails, the route data is empty, causing the router to decline. The address then passes to the next router. </p> </li> <li> <p> You can use <span class="docbook_command">manualroute</span> to deliver messages to pipes or files in batched SMTP format for onward transportation by some other means. This is one way of storing mail for a dial-up host when it is not connected. The route list entry can be as simple as a single domain name in a configuration like this: </p> <div class="docbook_literallayout"><pre> save_in_file: driver = manualroute transport = batchsmtp_appendfile route_list = saved.domain.example </pre></div> <p> though often a pattern is used to pick up more than one domain. If there are several domains or groups of domains with different transport requirements, different transports can be listed in the routing information: </p> <div class="docbook_literallayout"><pre> save_in_file: driver = manualroute route_list = \ *.saved.domain1.example $domain batch_appendfile; \ *.saved.domain2.example \ ${lookup{$domain}dbm{/domain2/hosts}{$value}fail} \ batch_pipe </pre></div> <p> The first of these just passes the domain in the $host variable, which doesn’t achieve much (since it is also in $domain), but the second does a file lookup to find a value to pass, causing the router to decline to handle the address if the lookup fails. </p> </li> <li> <p> Routing mail directly to UUCP software is a specific case of the use of <span class="docbook_command">manualroute</span> in a gateway to another mail environment. This is an example of one way it can be done: </p> <div class="docbook_literallayout"><pre> # Transport uucp: driver = pipe user = nobody command = /usr/local/bin/uux -r - \ ${substr_-5:$host}!rmail ${local_part} return_fail_output = true # Router uucphost: transport = uucp driver = manualroute route_data = \ ${lookup{$domain}lsearch{/usr/local/exim/uucphosts}} </pre></div> <p> The file <span class="docbook_filename">/usr/local/exim/uucphosts</span> contains entries like </p> <div class="docbook_literallayout"><pre> darksite.ethereal.example: darksite.UUCP </pre></div> <p> It can be set up more simply without adding and removing “.UUCP” but this way makes clear the distinction between the domain name <span class="docbook_emphasis">darksite.ethereal.example</span> and the UUCP host name <span class="docbook_emphasis">darksite</span>. </p> </li> </ul> <p> </p> </div> </div> <a class="previous_page" href="ch19.html"><-previous</a><a class="next_page" href="ch21.html">next-></a> </div></div> <iframe id="branding" name="branding" src="../../../../branding/branding.html" height="0" frameborder="no" scrolling="no"></iframe><div id="footer">Website design by <a href="https://secure.grepular.com/">Mike Cardwell</a>, of <a href="http://cardwellit.com/">Cardwell IT Ltd.</a> </div> <div class="left_bar"></div> <div class="right_bar"></div> <div id="toc"> <ul class="hidden"></ul> <img src="../../../../doc/contents.png" width="16" height="155"> </div> </div> <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"></script><script type="text/javascript" src="../../../../common.js"></script><script type="text/javascript" src="../../../../doc/chapter.js"></script> </body> </html>