Haraka - a Node.js Mail Server
Haraka can be used either as an inbound SMTP server, and is designed with good anti-spam protections in mind (see the plugins directory), or it can be used as an outbound mail server (run it on port 587 with an "auth" plugin to authenticate your users).
What Haraka doesn't do is fully replace your mail system (yet). It currently has no built-in facilities for mapping email addresses to user accounts and delivering them to said accounts. For that we expect you to keep something like postfix, exim or any other user-based mail system, and have Haraka deliver mail to those systems for that mapping. However nothing is stopping someone writing a plugin which replicates that facility - it just has yet to be done.
Haraka does have a scalable outbound mail delivery engine in the
plugin, which should work well for most sites.
Why Use Haraka?
Haraka's primary purpose is to provide you with a much easier to extend mail server than most available SMTP servers out there such as Postfix, Exim or Microsoft Exchange, yet while still running those systems for their excellent ability to deliver mail to users.
The plugin system makes it trivial to code new features. A typical example
might be to provide qmail-like extended addresses to an Exchange system,
whereby you could receive mail as
firstname.lastname@example.org, and yet
still have it correctly routed to
email@example.com. This is a few lines of
code in Haraka, or maybe someone has already written this plugin.
Plugins are already provided for running mail through SpamAssassin, checking for known bad HELO patterns, checking DNS Blocklists, and watching for violators of the SMTP protocol via the "early_talker" plugin.
Furthermore Haraka comes with a simple plugin called "graph" which shows you real-time charts of which plugins rejected the most mail, allowing you to easily fine-tune your list of plugins to more effectively stop spam.
Starting Haraka is simple. First we need to tell Haraka our hostname. Make sure you are in the Haraka directory and enter the following commands:
$ hostname > config/me $ hostname > config/host_list
This assumes that
hostname gives you the correct host you want to receive
mail for. If not, edit the
host_list file (though leave the
me file alone).
Finally just start Haraka:
And it will run.
However the big thing you need to do next is to edit the
file. This determines what plugins run in Haraka, and controls the overall
behaviour of the server. By default the server is setup to receive mails for
host_list and deliver them via
qmail-queue. Queueing to
qmail is likely not what you need unless you have qmail installed, so this is
likely the first thing you want to change.
Each plugin has documentation in the
docs/plugins directory. Look there
for information about how each plugin is configured, edit your
file, and restart Haraka and enjoy!
Feel free to email me at
firstname.lastname@example.org with any questions.
I welcome other performance evaluations.
License and Author
Haraka is MIT licensed - see the LICENSE file for details.