get postfwd1 | postfwd2 | tarball
postfwd page
News
Apr 18 2013: New versions postfwd-1.35 and postfwd2-1.35
(tarball with both versions) available.
Please read the Changelog.v1 or Changelog.v2 for details.
Apr 18 2013: postfwd.org has moved to a new infrastructure.
Aug 01 2012: Additional rate limit examples available.
Description
postfwd is written in perl to combine complex postfix restrictions in a ruleset
similar to those of the most firewalls. The program uses the postfix policy delegation protocol to control access to the mail system before a message has been
accepted (please visit http://www.postfix.org/SMTPD_POLICY_README.html for more information).
It allows you to choose an action (e.g. reject, dunno) for a combination of several smtp parameters
(like sender and recipient address, size or the client's TLS fingerprint).
Features
- Complex combinations of smtp parameters in a single rule
- Macros/ACLs/Groups for frequently used statements
- Combined asynchronous dnsbl lookups with arbitrary actions depending on the results
(e.g. allows dns whitelists or selective greylisting based on rbl lookup results)
- Automatic deactivation of non-responding dnsbls
- Rate limits for message count and size for any available item (user, client, sender, recipient, ...)
- Scoring system for fine granular access control
- Date/time based rules
- Conditional jumps to certain rules (like iptables -j)
- Internal caching for requests and dns lookups
- Runs as network daemon (no need to spawn processes)
- Built in statistics for rule efficiency analysis
Get it
Help
- postfwd-news
Here you will receive the latest announcements regarding new versions
and related topics. Volume will be very low. Subscribe to this list at
http://listi.jpberlin.de/mailman/listinfo/postfwd-news.
- postfwd-users
Here users will be able to share their experiences and ask questions regarding the
setup or configuration of postfwd. Volume will be low. Subscribe to this list at
http://listi.jpberlin.de/mailman/listinfo/postfwd-users.
- contact the developer
If you don't want to use the public mailinglists you are welcome to share your experiences
with postfwd by e-mail to info (AT) postfwd (DOT) org.
Required PERL modules
postfwd1 (1.10pre8+)
- Net::Server::Multiplex
- Net::DNS
postfwd2 (0.07+)
- Net::Server::Daemonize
- Net::Server::Multiplex
- Net::Server::PreFork
- Net::DNS
optional (since version 1.30)
optional (since version 1.32)
previous versions (up to 1.10pre7c)
- Net::Server::Multiplex
- Net::DNS::Async
- Net::CIDR::Lite
To install them you may either run:
perl -MCPAN -e shell
install <Module>
or get them from CPAN archive and run:
perl Makefile.pl
make
make test
make install
License
postfwd is free software and released under BSD license, which basically means that you can do what you want as long as you keep the copyright notice:
Copyright (c) 2007, 2008, Jan Peter Kessler
All rights reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:
- Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
- Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.
- Neither the name of the authors nor the names of his contributors may
be used to endorse or promote products derived from this software
without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY ME ``AS IS'' AND ANY
EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.