Login

SMTP sink server: prettier output

Author:
huwshimi
Posted:
May 5, 2010
Language:
Python
Version:
1.1
Tags:
email debug smtp server eml
Score:
1 (after 1 ratings)

A modified version of the original SMTP sink server: http://www.djangosnippets.org/snippets/96/. I've added some nicer, more verbose terminal messages.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
from datetime import datetime
import asyncore
from smtpd import SMTPServer

class EmlServer(SMTPServer):
    no = 0
    def process_message(self, peer, mailfrom, rcpttos, data):
        filename = '%s-%d.eml' % (datetime.now().strftime('%Y%m%d%H%M%S'),
                self.no)
        f = open(filename, 'w')
        f.write(data)
        f.close
        print 'Email received at %s and saved as %s' % (datetime.now().strftime('%H:%M:%S'), filename)
        self.no += 1


def run():
    print 'Python SMTP server'
    print 'Quit the server with CONTROL-C.'
    foo = EmlServer(('localhost', 25), None)
    try:
        asyncore.loop()
    except KeyboardInterrupt:
        pass


if __name__ == '__main__':
	run()

More like this

  1. SMTP sink server by twinsant 8 years ago
  2. One line SMTP sink server by Baguage 8 months, 1 week ago
  3. Another Memcache Status View by cmheisel 7 years, 1 month ago
  4. Logging solution for mod_python/FCGI by mikeivanov 7 years, 6 months ago
  5. Upload, Progressbar with sessions by revolunet 6 years, 7 months ago

Comments

Please login first before commenting.