When we were moving from mailman to sympa to be able to have true multi-domain support, I was shocked how difficult (and poorly documented) it is to get sympa properly integrated with postfix. I wanted a system where:
- mails to unknown recipients are rejected
- lists can be created and deleted by users (no manual editing of aliases)
- no patches to sympa or postfix are necessary.
For mailman, Debian ships with a setup that just works. For sympa, read on.
When you follow the sympa docs on postfix integration, you end up with a system that will accept all mails on the domain(s) sympa is expecting mails to arrive on. This makes it very difficult to have lists on the same domain as regular mailboxes, is a terrible practice because it leads to a lot of bounce-spam and may bring your server down if a spammer is guessing random emails from your domain.
The sympa FAQ contains an entry about this very problem, but the page is a mess and mostly outdated so it’s unfortunately not helpful. The following will rougly follow the howto from Folly Consulting, which you should read if you’re interested in an in-depth explanation of the problem and how postfix transports work. The code they use is not up-to-date however, redunant (they call postmap even though it’s unneccessary) and they patch files from sympa, which I wanted to avoid to make upgrades less painful.
My servers run Debian, so if you use sympa on a system that is not Debian-based you may have to change some paths. The following was confirmed to work on Debian 6 (squeeze) and Debian 7 (wheezy) and should work without modification for recent versions of Ubuntu and Mint (at least).
We will setup virtual transports for each of the six commands sympa uses and let them handle mail for corresponding virtual domains (sympalist, symparequest and so on). A modified
alias_manager.pl is provided that is able to create a regexp-type alias file for postfix which maps incoming mail to those virtual domains. This setup means we do not need to call a binary after changes (such as the suid-root aliaswrapper provided by sympa or even postmap) as regexp files are re-read everytime smtpd starts. See the notes at the end for what this means for low-traffic mailservers.
Let’s get started!
The alias manager
cd /opt git clone https://github.com/tribut/sympa-postfix-virtual.git cd sympa-postfix-virtual && sh make_public.sh cd /etc/sympa && ln -s /opt/sympa-postfix-virtual/templates/list_aliases.tt2 .
The version of
alias_manager.pl my version is based on is from sympa 6.12 and was last updated in svn revision 7542 on 07/30/2012. I tested it with both sympa versions 6.0 and 6.1. If you use a different version and encounter problems, it’s easy to review my changes.
Add the following options to your
And create the alias file with the correct permissions:
umask 077 touch /etc/sympa/sympa-alias.virtual chown sympa:sympa !!$
Finally, open sympa-alias.virtual in your favorite editor and add the following, replacing
my\.domain\.tld with your domain name and the escaped version of your domain name, respectively.
Pay attention to the dots at the end of the lines, marking the destination domains fully-qualified.
For the postfix configuration, first create the virtual transports by adding this to
transport_regexp with the following contents:
This file will tell postfix to actually use the transports for mail that is aliased to our virtual domains. Lastly, modify
main.cf and declare the two files we have created:
If you already have virtual_alias_maps or transport_maps in your config, you can list several values seperated by commas. Pay attention to the order of the maps though: First match wins.
Now, restart your services.
/etc/init.d/sympa reload /etc/init.d/postfix reload
To test if everything worked, create a mailing list and then run
/usr/sbin/sendmail -bv firstname.lastname@example.org. This will send a delivery report to the user account running the command (but not generate any real mail to the list). Ideally you should see something like this:
<mylist+my.domain.tld@sympalist> (expanded from <email@example.com>): delivery via sympalist: delivers to command: /usr/lib/sympa/bin/queue
A drawback of regexp-type maps is that they will be kept in memory for the lifetime of an smtpd process, so changes won’t be picked up immediately. If your mailserver is not very busy, it may take close to 3 hours (100*100s in the default configuration) before postfix notices a new list.
So if you run a server that is idle a lot, you could consider adding some options to the smtp process in
With those values it will take at most 10 minutes before your maps are re-read.