2016-01-10 22:33:43 +01:00
|
|
|
Freeposte.io
|
|
|
|
============
|
|
|
|
|
|
|
|
Simple yet functional and full-featured mail server as a single Docker image.
|
|
|
|
The idea behing Freeposte.io is identical to motivations that led to poste.io:
|
|
|
|
even though it looks like a Docker anti-pattern, single upgradable image
|
|
|
|
running a full-featured mail server is a truly amazing advantage for hosting
|
|
|
|
mails on modern cloud services or home-brewed Docker servers.
|
|
|
|
|
|
|
|
People from poste.io did an amazing job at accomplishing this ; any company
|
|
|
|
looking for a serious yet simple mail server with professional support should
|
|
|
|
turn to them.
|
|
|
|
|
|
|
|
This project is meant for free software supporters and hackers to reach the
|
|
|
|
same level of functionality and still be able to host a complete mail server
|
|
|
|
at little cost while running only FOSS, applying the KISS principle and being
|
|
|
|
able to fine-tune some details if needed.
|
|
|
|
|
2016-02-17 23:29:32 +01:00
|
|
|
General architecture
|
|
|
|
====================
|
2016-01-10 22:33:43 +01:00
|
|
|
|
|
|
|
The mail infrastructure is based on a standard MTA-LDA :
|
|
|
|
|
2016-02-17 22:56:40 +01:00
|
|
|
* Postfix with an SQLite database for transport ;
|
|
|
|
* Dovecot with an SQLite database for delivery and access ;
|
2016-01-10 22:33:43 +01:00
|
|
|
* Spamassassin for spam filtering ;
|
|
|
|
* ClamAV for malware filtering.
|
|
|
|
|
|
|
|
Additional Web UI :
|
|
|
|
|
|
|
|
* Roundcube Webmail (can easily be replaced) ;
|
2016-02-17 22:56:40 +01:00
|
|
|
* Administration UI based on Flask.
|
2016-01-10 22:33:43 +01:00
|
|
|
|
|
|
|
All components are monitored by supervisord.
|
|
|
|
|
2016-02-17 23:29:32 +01:00
|
|
|
Incoming e-mail
|
|
|
|
===============
|
|
|
|
|
|
|
|
Incoming e-mail is received by postfix, according to the workflow:
|
|
|
|
- ``smtpd`` receives the message;
|
|
|
|
- the domain is checked against the ``domains`` table;
|
|
|
|
- if the domain matches an active domain or the source address is allowed relay, continue;
|
|
|
|
- the mail is forwarded to Spamassassin, which appends some headers;
|
|
|
|
- the mail is fowarded to Dovecot using ``lmtp``;
|
|
|
|
- the local part and domain are checked against the ``users`` table;
|
|
|
|
- the user quota is checked;
|
|
|
|
- the mail is delivered to the local maildir.
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-01-10 22:33:43 +01:00
|
|
|
TODO
|
|
|
|
====
|
|
|
|
|
|
|
|
The project is still at a very (very !) early stage.
|
|
|
|
This is more of a roadmap than a proper TODO list. Please poke me or pull
|
|
|
|
request if you would like to join the effort.
|
|
|
|
|
2016-02-17 22:56:40 +01:00
|
|
|
- [x] Import vmm configuration files and get a simple postfix/dovecot running with SQLite.
|
2016-02-17 23:29:32 +01:00
|
|
|
- [x] Add support for spamassassin.
|
2016-02-17 22:56:40 +01:00
|
|
|
- [ ] Add support for clamav.
|
2016-02-17 23:29:32 +01:00
|
|
|
- [ ] Learn from user-defined spam or ham.
|
2016-01-10 22:33:43 +01:00
|
|
|
- [ ] Draft a Web administration UI.
|
|
|
|
- [ ] Implement basic features from the free (as in beer) poste.io.
|
|
|
|
- [ ] Start using on a couple production mail servers.
|
|
|
|
- [ ] Implement some fancy features.
|