Search code examples
pythonemailsmtpsmtplibsmtpd

Send AND receive email in an python application (no IMAP or POP3)


I'm building a application that needs to send and receive emails.

However I do not want to have a separate email server (or use IMAP and POP3), since I need to create/delete/manage inboxes on the fly, with no email inbox passwords, etc.

I have an email storage database in place, and I can receive emails by using a custom smtpd server, replacing postfix. However, that way I'm not able to send emails via postfix (using smtplib, connecting through port 25 to postfix and sending emails)

Any solution to this problem? How to send emails with a custom smtp server? Can I configure postfix to relay all incoming emails to a custom smtp server running in another port, and still use postfix on port 25 to send emails?

Thanks for your time


Solution

  • By using a custom SMTP server, you run the risk of inadvertently creating security holes or violating the SMTP protocol in some way. With so many great SMTP servers out there (Postfix, exim, sendmail...), that doesn't sound like a good option to me.

    The easiest way I can think of to solve that issue is to use Postfix to relay inbound and outbound e-mail. Inbound e-mail can be configured to be piped to an application, and outbound e-mail can be configured to be delivered by Postfix, either directly or relayed through a different server.

    This way, you can use, instead of a custom SMTP server, an application that is able to parse RFC822-compliant message files. This is better than doing exactly the same thing, but with the overhead of having to implement the SMTP protocol.

    This approach probably won't scale well should you need to receive a high volume of messages - every message will fork+exec a new process. If that is a requirement, a good approach would be to keep a custom SMTP server to do that job, but let Postfix relay it the messages - you will then benefit from Postfix's architecture in front of your parser.

    Assuming you follow the approach of piping the messages to an application, all you need to do in Postfix is to

    1. Configure Postfix's alias_maps' parameter to look for such a map:

      alias_maps = hash:/etc/aliases, hash:/etc/postfix/app-aliases
      
    2. Then, configure the map to pipe messages sent to each address into an application:

      test:         "|/usr/local/bin/your-app"
      
    3. As usual, don't forget to $ postalias app-aliases.

    This will make a message sent to test@yourdomain be piped into /usr/local/bin/your-app, which acts as an e-mail gateway to your application.