GPG Mailgate 0.11

This commit is contained in:
mcmaster 2010-01-20 16:09:34 -05:00
parent 782cda3639
commit 47d748cb7c

View file

@ -34,6 +34,7 @@ def send_msg( message, recipients = None ):
sys.exit(0) sys.exit(0)
gpg_to = list() gpg_to = list()
ungpg_to = list()
keys = GnuPG.public_keys( cfg['gpg']['keyhome'] ) keys = GnuPG.public_keys( cfg['gpg']['keyhome'] )
for to in to_addrs: for to in to_addrs:
domain = to.split('@')[1] domain = to.split('@')[1]
@ -42,12 +43,17 @@ for to in to_addrs:
gpg_to.append( (to, to) ) gpg_to.append( (to, to) )
elif cfg.has_key('keymap') and cfg['keymap'].has_key(to): elif cfg.has_key('keymap') and cfg['keymap'].has_key(to):
gpg_to.append( (to, cfg['keymap'][to]) ) gpg_to.append( (to, cfg['keymap'][to]) )
else:
ungpg_to.append(to)
if gpg_to == list(): if gpg_to == list():
if cfg['default'].has_key('add_header') and cfg['default']['add_header'] == 'yes': if cfg['default'].has_key('add_header') and cfg['default']['add_header'] == 'yes':
raw_message['X-GPG-Mailgate'] = 'Not encrypted, public key not found' raw_message['X-GPG-Mailgate'] = 'Not encrypted, public key not found'
send_msg( raw_message ) send_msg( raw_message )
if ungpg_to != list():
send_msg( raw_message, ungpg_to )
if raw_message.is_multipart(): if raw_message.is_multipart():
payload = list() payload = list()
for part in raw_message.get_payload(): for part in raw_message.get_payload():
@ -63,7 +69,13 @@ if cfg.has_key('logging') and cfg['logging'].has_key('file'):
if cfg['default'].has_key('add_header') and cfg['default']['add_header'] == 'yes': if cfg['default'].has_key('add_header') and cfg['default']['add_header'] == 'yes':
raw_message['X-GPG-Mailgate'] = 'Encrypted by GPG Mailgate 0.1' raw_message['X-GPG-Mailgate'] = 'Encrypted by GPG Mailgate 0.1'
gpg = GnuPG.GPGEncryptor( cfg['gpg']['keyhome'], map(lambda x: x[1], gpg_to) ) gpg_to_cmdline = list()
gpg_to_smtp = list()
for rcpt in gpg_to:
gpg_to_smtp.append(rcpt[0])
gpg_to_cmdline.extend(rcpt[1].split(','))
gpg = GnuPG.GPGEncryptor( cfg['gpg']['keyhome'], gpg_to_cmdline )
gpg.update( raw_message.get_payload() ) gpg.update( raw_message.get_payload() )
raw_message.set_payload( gpg.encrypt() ) raw_message.set_payload( gpg.encrypt() )
send_msg( raw_message, map(lambda x: x[0], gpg_to) ) send_msg( raw_message, gpg_to_smtp )