1 <!doctype html public
"-//W3C//DTD HTML 4.01 Transitional//EN"
2 "http://www.w3.org/TR/html4/loose.dtd">
8 <title>Postfix VERP Howto
</title>
10 <meta http-equiv=
"Content-Type" content=
"text/html; charset=us-ascii">
16 <h1><img src=
"postfix-logo.jpg" width=
"203" height=
"98" ALT=
"">Postfix VERP Howto
</h1>
20 <h2>Postfix VERP support
</h2>
22 <p> Postfix versions
1.1 and later support variable envelope return
23 path addresses on request. When VERP style delivery is requested,
24 each recipient of a message receives a customized copy of the
25 message, with his/her own recipient address encoded in the envelope
28 <p> For example, when VERP style delivery is requested, Postfix
29 delivers mail from
"<tt>owner-listname@origin</tt>" for a recipient
30 "<tt>user@domain</tt>", with a sender address that encodes the
31 recipient as follows:
</p>
35 owner-listname+user=domain@origin
39 <p> Thus, undeliverable mail can reveal the undeliverable recipient
40 address without requiring the list owner to parse bounce messages.
43 <p> The VERP concept was popularized by the qmail MTA and by the ezmlm
44 mailing list manager. See http://cr.yp.to/proto/verp.txt for the
45 ideas behind this concept.
</p>
47 <p> Topics covered in this document:
</p>
51 <li> <a href=
"#config"> Postfix VERP configuration parameters
</a>
53 <li> <a href=
"#majordomo"> Using VERP with majordomo etc. mailing lists
</a>
55 <li> <a href=
"#smtp"> VERP support in the Postfix SMTP server
</a>
57 <li> <a href=
"#sendmail"> VERP support in the Postfix sendmail command
</a>
59 <li> <a href=
"#qmqp"> VERP support in the Postfix QMQP server
</a>
63 <h2> <a name=
"config"> Postfix VERP configuration parameters
</a> </h2>
65 With Postfix, the whole process is controlled by four configuration
70 <dt> default_verp_delimiters (default value: +=)
72 <dd> <p> What VERP delimiter characters Postfix uses when VERP
73 style delivery is requested but no explicit delimiters are
76 <dt> verp_delimiter_filter (default: -+=)
78 <dd> <p> What characters Postfix accepts as VERP delimiter
79 characters on the sendmail command line and in SMTP commands.
80 Many characters must not be used as VERP delimiter characters,
81 either because they already have a special meaning in email
82 addresses (such as the @ or the %), because they are used as
83 part of a username or domain name (such as alphanumerics), or
84 because they are non-ASCII or control characters. And who
85 knows, some characters may tickle bugs in vulnerable software,
86 and we would not want that to happen.
</p> </dd>
88 <dt> smtpd_authorized_verp_clients (default value: none)
90 <dd> <p> What SMTP clients are allowed to request VERP style
91 delivery. The Postfix QMQP server uses its own access control
92 mechanism, and local submission (via /usr/sbin/sendmail etc.)
93 is always authorized. To authorize a host, list its name, IP
94 address, subnet (net/mask) or parent .domain.
</p>
96 <p> With Postfix versions
1.1 and
2.0, this parameter is called
97 authorized_verp_clients (default: $mynetworks).
</p> </dd>
99 <dt> disable_verp_bounces (default: no)
101 <dd> <p> if Postfix sends one bounce report for multi-recipient
102 VERP mail, or one bounce report per recipient. The default,
103 one per recipient, is what ezmlm needs.
</p> </dd>
107 <h2> <a name=
"majordomo"> Using VERP with majordomo etc. mailing lists
</a> </h2>
109 <p> In order to make VERP useful with majordomo etc. mailing lists,
110 you would configure the list manager to submit mail according
111 to one of the following two forms:
</p>
113 <p> Postfix
2.3 and later:
</p>
117 % sendmail -XV -f owner-listname other-arguments...
119 % sendmail -XV+= -f owner-listname other-arguments...
123 <p> Postfix
2.2 and earlier (Postfix
2.3 understands the old syntax
124 for backwards compatibility, but will log a warning that reminds
125 you of the new syntax):
</p>
129 % sendmail -V -f owner-listname other-arguments...
131 % sendmail -V+= -f owner-listname other-arguments...
135 <p> The first form uses the default main.cf VERP delimiter characters.
136 The second form allows you to explicitly specify the VERP delimiter
137 characters. The example shows the recommended values.
</p>
139 <p> This text assumes that you have set up an owner-listname alias
140 that routes undeliverable mail to a real person:
</p>
145 owner-listname: yourname+listname
149 <p> In order to process bounces we are going to make extensive use
150 of address extension tricks.
</p>
152 <p> You need to tell Postfix that + is the separator between an
153 address and its optional address extension, that address extensions
154 are appended to .forward file names, and that address extensions
155 are to be discarded when doing alias expansions:
</p>
159 /etc/postfix/main.cf:
160 recipient_delimiter = +
161 forward_path = $home/.forward${recipient_delimiter}${extension},
163 propagate_unmatched_extensions = canonical, virtual
167 <p> (the last two parameter settings are default settings).
</p>
169 <p> You need to set up a file named .forward+listname with the
170 commands that process all the mail that is sent to the owner-listname
176 "|/some/where/command ..."
180 <p> With this set up, undeliverable mail for user@domain will be returned
181 to the following address:
</p>
185 owner-listname+user=domain@your.domain
189 <p> which is processed by the command in your .forward+listname file.
190 The message should contain, among others, a To: header with the
191 encapsulated recipient sender address:
</p>
195 To: owner-listname+user=domain@your.domain
199 <p> It is left as an exercise for the reader to parse the To: header
200 line and to pull out the user=domain part from the recipient address.
203 <h2> <a name=
"smtp"> VERP support in the Postfix SMTP server
</a> </h2>
205 <p> The Postfix SMTP server implements a command XVERP to enable
206 VERP style delivery. The syntax allows two forms:
</p>
210 MAIL FROM:
<sender@domain
> XVERP
212 MAIL FROM:
<sender@domain
> XVERP=+=
216 <p> The first form uses the default main.cf VERP delimiters, the
217 second form overrides them explicitly. The values shown are the
218 recommended ones.
</p>
220 <h2> <a name=
"sendmail"> VERP support in the Postfix sendmail command
</a> </h2>
222 <p> The Postfix sendmail command has a -V flag to request VERP style
223 delivery. Specify one of the following two forms:
</p>
225 <p> Postfix
2.3 and later:
</p>
228 % sendmail -XV -f owner-listname ....
230 % sendmail -XV+= -f owner-listname ....
234 <p> Postfix
2.2 and earlier (Postfix
2.3 understands the old syntax
235 for backwards compatibility, but will log a warning that reminds
236 you of the new syntax):
</p>
240 % sendmail -V -f owner-listname ....
242 % sendmail -V+= -f owner-listname ....
246 <p> The first form uses the default main.cf VERP delimiters, the
247 second form overrides them explicitly. The values shown are the
248 recommended ones.
</p>
250 <h2> <a name=
"qmqp"> VERP support in the Postfix QMQP server
</a> </h2>
252 <p> When the Postfix QMQP server receives mail with an envelope
253 sender address of the form:
</p>
257 listname-@your.domain-@[]
261 <p> Postfix generates sender addresses
262 "<tt>listname-user=domain@your.domain</tt>", using
"-=" as the VERP
263 delimiters because qmail/ezmlm expect this.
</p>
265 <p> More generally, a sender address of
"<tt>prefix@origin-@[]</tt>"
266 requests VERP style delivery with sender addresses of the form
267 "<tt>prefixuser=domain@origin</tt>". However, Postfix allows only
268 VERP delimiters that are specified with the verp_delimiter_filter
269 parameter. In particular, the
"=" delimiter is required for qmail
270 compatibility (see the qmail addresses(
5) manual page for details).