Go to the first, previous, next, last section, table of contents.


Additional generic options for routers

The following additional generic options apply to all routers, in addition to the common generic options for both directors and routers which are described in chapter "Common generic options for directors and routers". Routers are concerned with addresses whose domains do not match something in `local_domains'.

pass_on_timeout (router) option

Option: pass_on_timeout
Type: boolean
Default: false

If a router times out during a host lookup, it normally causes deferral of the address. If `pass_on_timeout' is set, the address is instead passed on to the next router. This may be helpful for systems that are intermittently connected to the Internet, or those that want to pass to a smart host any messages that cannot immediately be delivered.

There are occasional other temporary errors that can occur while doing DNS lookups. They are treated in the same way as a timeout, and this option applies to all of them.

self (router) option

Option: self
Type: string
Default: "freeze"

This option specifies what is to happen if routing a remote address ends up pointing at the local host, or at a host whose name matches `hosts_treat_as_local'. Normally this indicates either an error in Exim's configuration (for example, the domain should be listed as local), or an error in the DNS (for example, the MX shouldn't point at this host). However, this situation is not confined to the use of MX records, and the `self' option can be used on any router.

The default action is to freeze the message. The following alternatives are provided for use in special cases:

When a router just rewrites, that is, does not set up IP addresses, the `self' option is not relevant.

translate_ip_address (router) option

Option: translate_ip_address
Type: string
Default: unset

There exist some rare networking situations (for example, packet radio) where it is helpful to be able to translate IP addresses generated by normal routing mechanisms into other IP addresses, thus performing a kind of manual IP routing. This should be done only if the normal IP routing of the TCP/IP stack is inadequate or broken. Because this is an extremely uncommon requirement, the code to support this option is not included in the Exim binary unless SUPPORT_TRANSLATE_IP_ADDRESS=yes is set in Local/Makefile.

The `translate_ip_address' string is expanded for every IP address generated by the router, with the generated address set in `$host_address'. If the expansion is forced to fail, no action is taken. If it returns an IP address, that replaces the original address; otherwise the result is assumed to be a host name -- this is looked up using `gethostbyname()' to produce one or more replacement IP addresses. For example, to subvert all IP addresses in some specific networks, this could be added to a router:

$smc{translate_ip_address = "\
  ${lookup{${mask:$host_address/26}}lsearch{/some/file}{$value}fail}"}

The file would contain lines like

10.2.3.128/26    some.host
10.8.4.34/26     10.44.8.15

You should not make use of this facility unless you really understand what you are doing.


Go to the first, previous, next, last section, table of contents.