meillo@431: .TH masqmail.conf 5 2015-02-07 masqmail-0.3.5 "File Formats" meillo@34: meillo@0: .SH NAME meillo@0: masqmail.conf \- masqmail configuration file meillo@34: meillo@34: meillo@0: .SH DESCRIPTION meillo@0: meillo@34: This man page describes the syntax of the main configuration file of masqmail. meillo@34: Its usual location is \fI/etc/masqmail/masqmail.conf\fR meillo@0: meillo@0: The configuration consists of lines of the form meillo@0: meillo@398: .RS 8 meillo@34: \fBval\fR = \fIexpression\fR meillo@398: .RE meillo@0: meillo@34: Where \fBval\fR is a variable name and \fIexpression\fR a string, meillo@34: which can be quoted with double quotes `"'. meillo@398: If the expression is on multiple lines or contains characters other meillo@398: than letters, meillo@398: digits or the characters `.', `\-', `_', `/', ';', '@', ':', it must be quoted. meillo@34: You can use quotes inside quotes by escaping them with a backslash. meillo@0: meillo@174: Each \fBval\fP has a type, which can be boolean, numeric, string or list. meillo@398: A boolean variable can be set with one of the values `on', `yes', and `true' meillo@398: or `off', `no' and `false'. meillo@34: List items are separated with semicolons `;'. meillo@398: The spaces around the equal sign `=' are optional. meillo@0: meillo@398: All lists, except meillo@398: \fBquery_routes.\fIname\fR and \fBpermanent_routes\fR, accept absolute meillo@398: pathnames (leading slash `/') as entries, too. meillo@398: They can be intermixed with normal entries. meillo@398: The contents of these files will be included at this position in the list. meillo@398: This makes including large lists more convenient. meillo@398: Within these files, each line is one entry; the semicolon is no separator. meillo@0: meillo@34: Blank lines and lines starting with a hash `#' are ignored. meillo@34: meillo@0: meillo@0: .SH OPTIONS meillo@34: meillo@0: .TP meillo@34: \fBrun_as_user = \fIboolean\fR meillo@0: meillo@398: If this is set, masqmail runs with the user id of the user who meillo@398: invoked it and never changes it. meillo@34: This is for debugging purposes only. meillo@34: If the user is not root, masqmail will not be able to listen on a port < 1024 meillo@34: and will not be able to deliver local mail to others than the user. meillo@0: meillo@0: .TP meillo@34: \fBuse_syslog = \fIboolean\fR meillo@0: meillo@34: If this is set, masqmail uses syslogd for logging. meillo@34: It uses facility MAIL. meillo@34: You still have to set \fBlog_dir\fR for debug files. meillo@0: meillo@0: .TP meillo@34: \fBdebug_level = \fIn\fR meillo@0: meillo@34: Set the debug level. meillo@333: Valid values are 0 to 6 and 9. meillo@333: Be careful if you set this as high as 5 or higher, meillo@333: the logs may very soon fill your hard drive. meillo@333: Level 9 enables printing of debug messages to stderr during reading of meillo@333: the config file. meillo@333: The debug file comes available for the first time after this step. meillo@333: Thus nothing but stderr is available. meillo@333: Level 9 is almost never interesting. meillo@0: meillo@0: .TP meillo@44: \fBlog_dir = \fIfile\fR meillo@44: meillo@174: The directory where logs are stored, if syslog is not used. meillo@174: Debug files are always stored in this directory if debugging is enabled. meillo@44: \fIfile\fR must be an absolute path. meillo@44: meillo@151: Default: \fI/var/log/masqmail\fR meillo@151: meillo@44: .TP meillo@34: \fBmail_dir = \fIfile\fR meillo@0: meillo@398: The directory where local mail is stored, meillo@398: usually \fI/var/spool/mail\fR or \fI/var/mail\fR. meillo@44: \fIfile\fR must be an absolute path. meillo@0: meillo@152: Default: \fI/var/mail\fR meillo@152: meillo@0: .TP meillo@34: \fBspool_dir = \fIfile\fR meillo@0: meillo@398: The directory where masqmail stores its spool files meillo@421: (and lock files if \fIrun_as_user\fP). meillo@34: Masqmail needs read and write permissions for this directory. meillo@44: \fIfile\fR must be an absolute path. meillo@0: meillo@151: Default: \fI/var/spool/masqmail\fR meillo@151: meillo@0: .TP meillo@133: \fBlock_dir = \fIfile\fR meillo@133: meillo@133: The directory where masqmail stores its lock files. meillo@133: Masqmail needs read and write permissions for this directory. meillo@421: The default is \fI/var/lock/masqmail\fR for normal operation. meillo@133: \fIfile\fR must be an absolute path. meillo@421: The directory is created on startup if yet missing. meillo@421: meillo@421: If \fIrun_as_user\fP then lock files are stored in the \fIspool_dir\fP meillo@421: directly and the \fBlock_dir\fP setting is ignored. meillo@133: meillo@133: .TP meillo@34: \fBhost_name = \fIstring\fR meillo@0: meillo@398: This is used in different places: Masqmail identifies itself in meillo@398: the greeting banner on incoming connections and in the HELO/EHLO command meillo@398: for outgoing connections with this name, it is used in the Received: header meillo@398: and to qualify the sender of a locally originating message. meillo@0: meillo@34: If the string begins with a slash `/', it it assumed that it is a filename, meillo@34: and the first line of this file will be used. meillo@398: Usually this will be `/etc/mailname' to make masqmail conform to meillo@398: Debian policies. meillo@0: meillo@398: It is not used to find whether an address is local. meillo@398: Use \fBlocal_hosts\fR for that. meillo@0: meillo@156: Default: none; \fBhost_name\fP MUST be set in the config file meillo@156: meillo@0: .TP meillo@34: \fBlocal_hosts = \fIlist\fR meillo@0: meillo@34: A semicolon `;' separated list of hostnames which are considered local. meillo@375: Can contain glob patterns, like meillo@375: `*example.org' or `mail?.*mydomain.net'. meillo@153: Normally you should set it to "localhost;foo;foo.bar.com" if your host has the meillo@34: fully qualified domain name `foo.bar.com'. meillo@0: meillo@398: Default: localhost ; ; meillo@398: meillo@157: meillo@157: Example: \fIlocalhost;foo;foo.example.org\fR meillo@157: (if you have set \fBhost_name\fR to \fIfoo.example.org\fR) meillo@153: meillo@0: .TP meillo@34: \fBlocal_addresses = \fIlist\fR meillo@0: meillo@34: A semicolon `;' separated list of fully qualified email-addresses which are meillo@398: considered local although their domain name part is not in the list of meillo@398: \fBlocal_hosts\fR. meillo@238: This list can be seen as an addition to \fBlocal_hosts\fP. meillo@398: .IP meillo@306: Further more only the local part of the addresses will be regarded, meillo@306: seeing it as a local user. meillo@0: meillo@398: Example: meillo@0: meillo@398: .RS 8 meillo@398: .nf meillo@398: local_hosts = "localhost;myhost" meillo@398: local_addresses = "bob@somewhere;alice@foo" meillo@398: .fi meillo@398: .RE meillo@398: .IP meillo@306: This means mail to person1@yourdomain will effectively go to meillo@306: person1@localhost, if not redirected by an alias. meillo@34: meillo@0: .TP meillo@34: \fBnot_local_addresses = \fIlist\fR meillo@0: meillo@34: A semicolon `;' separated list of fully qualified email-addresses which are meillo@398: considered not local although their domain name part is in the list of meillo@398: \fBlocal_hosts\fR. meillo@238: This list can be seen as a substraction to \fBlocal_hosts\fP. meillo@0: meillo@34: This is the opposite of the previous case. meillo@34: The majority of addresses of a specific domain are local. meillo@34: But some users are not. meillo@34: With this option you can easily exclude these users. meillo@0: meillo@0: Example: meillo@0: meillo@398: .RS 8 meillo@398: .nf meillo@0: local_hosts = "localhost;myhost;mydomain.net" meillo@0: not_local_addresses = "eric@mydomain.net" meillo@398: .fi meillo@398: .RE meillo@398: .IP meillo@34: meillo@0: .TP meillo@34: \fBlisten_addresses = \fIlist\fR meillo@0: meillo@398: A semicolon `;' separated list of interfaces on which connections will meillo@398: be accepted. meillo@398: An interface ist defined by a hostname, optionally followed by a colon `:' meillo@398: and a number for the port. meillo@34: If this is left out, port 25 will be used. meillo@0: meillo@34: You can set this to "localhost:25;foo:25" if your hostname is `foo'. meillo@0: meillo@337: Note that the names are resolved to IP addresses. meillo@34: If your host has different names which resolve to the same IP, meillo@34: use only one of them, otherwise you will get an error message. meillo@0: meillo@329: Default: \fIlocalhost:25\fR (i.e. only local processes can connect) meillo@161: meillo@0: .TP meillo@34: \fBdo_save_envelope_to = \fIboolean\fR meillo@0: meillo@398: If this is set to true, a possibly existing Envelope-to: header in meillo@398: an incoming mail which is received via either pop3 or smtp will be saved meillo@398: as an X-Orig-Envelope-to: header. meillo@0: meillo@192: This is useful if you retrieve mail from a pop3 server with fetchmail, meillo@34: and the server supports Envelope-to: headers, meillo@34: and you want to make use of those with a mail filtering tool, e.g. procmail. meillo@34: It cannot be preserved because masqmail sets such a header by itself. meillo@0: meillo@0: Default is false. meillo@34: meillo@0: .TP meillo@34: \fBdo_relay = \fIboolean\fR meillo@0: meillo@398: If this is set to false, mail with a return path that is not local meillo@398: and a destination that is also not local will not be accepted via smtp meillo@398: and a 550 reply will be given. meillo@34: Default is true. meillo@0: meillo@34: Note that this will not protect you from spammers using open relays, meillo@34: but from users unable to set their address in their mail clients. meillo@0: meillo@0: .TP meillo@34: \fBdo_queue = \fIboolean\fR meillo@0: meillo@398: If this is set, masqmail will not try to deliver mail meillo@398: immediately when accepted. meillo@346: Instead it will always queue it. meillo@427: (Note: Masqmail will always automatically queue mail if necessary, meillo@346: i.e. if it cannot deliver because no suitable route was available for example.) meillo@346: meillo@34: Same as calling masqmail with the \fB\-odq\fR option. meillo@346: Usually you should leave this option unset. meillo@346: meillo@346: Default: false meillo@0: meillo@0: .TP meillo@354: \fBpermanent_routes\fR = \fIlist\fR meillo@0: meillo@354: Set this to the filename (or a semicolon-separated list of filenames) meillo@354: of the route configuration for always available connections. meillo@354: Main purpose is to define a mail server with mail_host in your local network, meillo@354: or if masqmail should send mail directly to the target host. meillo@354: If you have only a single host, you can leave it unset. meillo@354: meillo@354: A setting `\fBlocal_nets\fR = \fI"*home.net"\fR' in versions <= 0.3.3 meillo@354: is in newer versions configured as: meillo@354: `\fBpermanent_routes\fR = \fI"/etc/masqmail/homenet.route"\fR' meillo@354: and the route file `homenet.route' containing: meillo@398: meillo@398: .RS 8 meillo@354: .nf meillo@354: allowed_recipients = "*@*home.net" meillo@354: connect_error_fail = true meillo@354: resolve_list = byname meillo@354: .fi meillo@398: .RE meillo@398: .IP meillo@398: meillo@354: This is just as it had been with \fBlocal_net_route\fP, meillo@354: with the exception that the filtering for appropriate addresses meillo@354: is only in the route file and not with \fBlocal_nets\fR. meillo@354: meillo@354: .TP meillo@354: \fBquery_routes.\fIname\fR = \fIlist\fR meillo@354: meillo@354: Replace \fIname\fR with a name to identify the connection. meillo@354: Set this to a filename (or a semicolon-separated list of filenames) meillo@354: for the route configuration for that connection. meillo@354: meillo@354: Routes of this kind cannot be expected to be online always. meillo@354: Masqmail will query which of the routes are online. meillo@354: meillo@354: You can use the name to call masqmail with the \fB\-qo\fR option every time a meillo@354: connection to your ISP is set up, in order to send queued mail through this meillo@354: route. meillo@0: meillo@34: Example: Your ISP has the name FastNet. meillo@34: Then you write the following line in the main configuration: meillo@0: meillo@398: .RS 8 meillo@398: .nf meillo@354: \fBquery_routes.\fBFastNet\fR = \fI"/etc/masqmail/fastnet.route"\fR meillo@398: .fi meillo@398: .RE meillo@398: .IP meillo@0: meillo@354: \fI/etc/masqmail/fastnet.route\fR is the route configuration file, meillo@354: see \fBmasqmail.route(5)\fR. meillo@354: As soon as a link to FastNet has been set up, meillo@354: you call `masqmail \fB\-qo \fIFastNet\fR'. meillo@34: Masqmail will then read the specified file and send the mails. meillo@0: meillo@354: See \fBonline_query\fP. meillo@0: meillo@0: .TP meillo@34: \fBalias_file = \fIfile\fR meillo@0: meillo@34: Set this to the location of your alias file. meillo@238: If not set, no aliasing will be done. meillo@238: meillo@238: Default: (i.e. no aliasing is done) meillo@0: meillo@0: .TP meillo@387: \fBglobalias_file = \fIfile\fR meillo@387: meillo@387: Set this to the location of a glob-pattern alias file. meillo@387: This kind of aliasing matches glob patterns against full email addresses, meillo@387: not strings against local parts like in normal aliasing. meillo@387: You can use this to handle catch-all maildrops (``*@example.org'') meillo@387: and to split between virtual hosts on a single machine meillo@387: (e.g. ``info@foo.ex.org'' and ``info@bar.ex.org''). meillo@387: meillo@387: Glob aliasing is done before normal aliasing. meillo@387: If you have both kinds, glob and normal aliasing, then the results of the meillo@387: glob aliasing may be expanded further by the normal aliasing mechanism. meillo@387: meillo@387: Default: (i.e. no glob aliasing is done) meillo@387: meillo@387: .TP meillo@243: \fBcaseless_matching = \fIboolean\fR meillo@0: meillo@242: If this is set, aliasing and the matching for \fBlocal_addresses\fP and meillo@242: \fBnot_local_addresses\fP will be done caseless. meillo@242: meillo@242: Note: Be sure to change this option only if the queue is empty as meillo@242: correct processing of queued messages is not guaranteed otherwise. meillo@34: meillo@238: Default: false meillo@238: meillo@0: .TP meillo@34: \fBpipe_fromline = \fIboolean\fR meillo@0: meillo@34: If this is set, a from line will be prepended to the output stream whenever meillo@34: a pipe command is called after an alias expansion. meillo@34: Default is false. meillo@0: meillo@0: .TP meillo@34: \fBpipe_fromhack = \fIboolean\fR meillo@0: meillo@34: If this is set, each line beginning with `From ' is replaced with `>From ' meillo@34: whenever a pipe command is called after an alias expansion. meillo@34: You probably want this if you have set \fBpipe_fromline\fR above. meillo@34: Default is false. meillo@0: meillo@0: .TP meillo@34: \fBmbox_default = \fIstring\fR meillo@0: meillo@34: The default local delivery method. meillo@205: Can be mbox or mda. meillo@398: You can override this for each user by using the \fBmbox_users\fR or meillo@398: \fBmda_users\fR (see below). meillo@0: meillo@238: Default: mbox. meillo@238: meillo@0: .TP meillo@34: \fBmbox_users = \fIlist\fR meillo@0: meillo@0: A list of users which wish delivery to an mbox style mail folder. meillo@34: meillo@0: .TP meillo@34: \fBmda_users = \fIlist\fR meillo@0: meillo@34: A list of users which wish local delivery to an mda. meillo@34: You have to set \fBmda\fR (see below) as well. meillo@0: meillo@0: .TP meillo@34: \fBmda = \fIexpand string\fR meillo@0: meillo@34: If you want local delivery to be transferred to an mda (Mail Delivery Agent), meillo@34: set this to a command. meillo@34: The argument will be expanded on delivery time, meillo@398: you can use variables beginning with a dolloar sign `$', meillo@398: optionally enclosed in curly braces. meillo@34: Variables you can use are: meillo@0: meillo@398: .RS 8 meillo@398: .TP meillo@398: uid meillo@398: the unique message id. meillo@398: (This is not necessarily identical with the Message ID meillo@398: as given in the Message ID: header.) meillo@0: meillo@398: .TP meillo@398: received_host meillo@398: the host the mail was received from meillo@0: meillo@398: .TP meillo@398: ident meillo@398: the user id of the sender if the message was received locally. meillo@0: meillo@398: .TP meillo@398: return_path_local meillo@398: the local part of the return path (sender). meillo@0: meillo@398: .TP meillo@398: return_path_domain meillo@398: the domain part of the return path (sender). meillo@0: meillo@398: .TP meillo@398: return_path meillo@398: the complete return path (sender). meillo@0: meillo@398: .TP meillo@398: rcpt_local meillo@398: the local part of the recipient. meillo@0: meillo@398: .TP meillo@398: rcpt_domain meillo@398: the domain part of the recipient. meillo@0: meillo@398: .TP meillo@398: rcpt meillo@398: the complete recipient address. meillo@398: .RE meillo@398: .IP meillo@0: meillo@0: Example: meillo@0: meillo@398: .RS 8 meillo@16: mda="/usr/bin/procmail \-Y \-d ${rcpt_local}" meillo@398: .RE meillo@398: .IP meillo@0: meillo@398: For the mda, as for pipe commands, meillo@398: a few environment variables will be set as well. meillo@34: See \fBmasqmail(8)\fR. meillo@398: To use environment variables for the mda, meillo@398: the dollar sign `$' has to be escaped with a backslash, meillo@34: otherwise they will be tried to be expanded with the internal variables. meillo@34: meillo@0: .TP meillo@34: \fBmda_fromline = \fIboolean\fR meillo@0: meillo@34: If this is set, a from line will be prepended to the output stream whenever meillo@34: a message is delivered to an mda. meillo@34: Default is false. meillo@0: meillo@0: .TP meillo@34: \fBmda_fromhack = \fIboolean\fR meillo@0: meillo@34: If this is set, each line beginning with `From ' is replaced with `>From ' meillo@34: whenever a message is delivered to an mda. meillo@34: You probably want this if you have set \fBmda_fromline\fR above. meillo@34: Default is false. meillo@0: meillo@0: .TP meillo@310: \fBonline_query = \fIcommand line\fR meillo@0: meillo@398: Defines the method masqmail uses to detect whether there exists meillo@398: an online connection currently. meillo@0: meillo@310: Masqmail executes the command given and reads from its standard output. meillo@310: The command should just print a route name, as defined meillo@398: with \fBquery_routes.\fIname\fR, to standard output and return meillo@398: a zero status code. meillo@310: Masqmail assumes it is offline if the script returns with a non-zero status. meillo@310: Leading and trailing whitespace is removed from the output. meillo@0: meillo@310: Simple example: meillo@310: meillo@398: .RS 8 meillo@310: .nf meillo@310: #!/bin/sh meillo@418: test \-e /var/tmp/masqmail-route || exit 1 meillo@418: cat /var/tmp/masqmail-route meillo@310: exit 0 meillo@310: .fi meillo@398: .RE meillo@398: .IP meillo@0: meillo@34: No matter how masqmail detects the online status, meillo@398: only messages that are accepted at online time will be meillo@398: delivered using the connection. meillo@310: The mail spool still needs to be emptied manually meillo@310: (\fB\-qo\fIconnection\fR). meillo@0: meillo@310: \fIcommand line\fR must start with an absolute path to an executable program. meillo@158: It can contain optional arguments. meillo@0: meillo@310: To simulate the old online_method=file, use: meillo@398: meillo@398: .RS 8 meillo@310: \fI/bin/cat /path/to/file\fP meillo@398: .RE meillo@398: .IP meillo@158: meillo@310: To be always online with connection `foo', use: meillo@398: meillo@398: .RS 8 meillo@310: \fI/bin/echo foo\fP meillo@398: .RE meillo@398: .IP meillo@310: meillo@310: To query a masqdialer server meillo@310: (i.e. asking it whether a connection exists and what its name is) meillo@164: use: meillo@398: meillo@398: .RS 8 meillo@310: \fI/usr/bin/mservdetect localhost 224\fP meillo@398: .RE meillo@398: .IP meillo@92: meillo@0: .TP meillo@34: \fBerrmsg_file = \fIfile\fR meillo@0: meillo@34: Set this to a template which will be used to generate delivery failure reports. meillo@34: Variable parts within the template begin with a dollar sign and are identical meillo@398: to those which can be used as arguments for the mda command, meillo@398: see \fBmda\fR above. meillo@398: Additional information can be included with @failed_rcpts, meillo@398: @msg_headers and @msg_body, meillo@398: these must be at the beginning of a line and will be replaced meillo@398: with the list of the failed recipients, meillo@34: the message headers and the message body of the failed message. meillo@0: meillo@0: Default is /usr/share/masqmail/tpl/failmsg.tpl. meillo@34: meillo@0: .TP meillo@34: \fBwarnmsg_file = \fIfile\fR meillo@0: meillo@34: Set this to a template which will be used to generate delivery warning reports. meillo@34: It uses the same mechanisms for variables as \fBerrmsg_file\fR, see above. meillo@0: meillo@0: Default is /usr/share/masqmail/tpl/warnmsg.tpl. meillo@34: meillo@0: .TP meillo@34: \fBwarn_intervals\fR = \fIlist\fR meillo@0: meillo@34: Set this to a list of time intervals, at which delivery warnings meillo@34: (starting with the receiving time of the message) shall be generated. meillo@0: meillo@34: A warning will only be generated just after an attempt to deliver the mail meillo@34: and if that attempt failed temporarily. meillo@398: So a warning may be generated after a longer time, meillo@398: if there was no attempt before. meillo@0: meillo@0: Default is "1h;4h;8h;1d;2d;3d" meillo@34: meillo@0: .TP meillo@34: \fBmax_defer_time\fR = \fItime\fR meillo@0: meillo@398: This is the maximum time, meillo@398: in which a temporarily failed mail will be kept in the spool. meillo@34: When this time is exceeded, it will be handled as a delivery failure, meillo@34: and the message will be bounced. meillo@0: meillo@398: The excedence of this time will only be noticed if the message meillo@398: was actually tried to be delivered. meillo@34: If, for example, the message can only be delivered when online, meillo@34: but you have not been online for that time, no bounce will be generated. meillo@0: meillo@0: Default is 4d (4 days) meillo@34: meillo@0: .TP meillo@34: \fBlog_user = \fIname\fR meillo@0: meillo@34: Replace \fIname\fR with a valid local or remote mail address. meillo@0: meillo@44: If this option is set, then a copy of every mail, meillo@398: that passes through the masqmail system will also be sent meillo@398: to the given mail address. meillo@0: meillo@34: For example you can feed your mails into a program like hypermail meillo@398: for archiving purpose by placing an appropriate pipe command meillo@398: in masqmail.alias. meillo@0: meillo@117: .TP meillo@117: \fBmax_msg_size\fR = \fIbytes\fR meillo@117: meillo@117: This option sets the maximum size in bytes masqmail will accept for delivery. meillo@117: This value is advertised to the SMTP client by the `SIZE' message during SMTP meillo@117: session setup. meillo@117: Clients pretending to send, or actually send, meillo@117: more than \fIbytes\fR will get a 552 error message. meillo@117: meillo@398: A zero value disables the maximum size limit. meillo@120: meillo@120: Default is 0 (= unlimited). meillo@117: meillo@134: .TP meillo@134: \fBdefer_all\fR = \fIboolean\fR meillo@134: meillo@134: If set to true, masqmail replies with ``421 service temporarily unavailable'' meillo@134: to any SMTP request and shuts the connection down. meillo@134: Note: This option is for debugging purposes only. meillo@134: meillo@134: Default: false meillo@134: meillo@34: meillo@0: .SH AUTHOR meillo@0: meillo@34: Masqmail was written by Oliver Kurth. meillo@34: It is now maintained by Markus Schnalke . meillo@0: meillo@398: You will find the newest version of masqmail at meillo@398: \fBhttp://marmaro.de/prog/masqmail/\fR. meillo@398: There is also a mailing list, meillo@398: you will find information about it at masqmail's main site. meillo@0: meillo@34: meillo@0: .SH BUGS meillo@0: meillo@34: Please report bugs to the mailing list. meillo@34: meillo@0: meillo@0: .SH SEE ALSO meillo@0: meillo@192: \fBmasqmail(8)\fR, \fBmasqmail.route(5)\fR