diff options
Diffstat (limited to 'memoryhole')
-rw-r--r-- | memoryhole/gpg.py | 16 | ||||
-rw-r--r-- | memoryhole/protection.py | 17 |
2 files changed, 25 insertions, 8 deletions
diff --git a/memoryhole/gpg.py b/memoryhole/gpg.py index fcead9e..533d12a 100644 --- a/memoryhole/gpg.py +++ b/memoryhole/gpg.py @@ -1,4 +1,3 @@ -from gnupg import GPG from zope.interface import implementer from memoryhole.openpgp import OpenPGP @@ -7,16 +6,21 @@ from memoryhole.openpgp import OpenPGP @implementer(OpenPGP) class Gnupg(object): def __init__(self): + from gnupg import GPG self.gpg = GPG() - def encrypt(self, data, encraddr, singaddr): - # TODO - encfp = 0 - signfp = 0 - return self.gpg.encrypt(data, encfp, default_key=signfp) + def encrypt(self, data, encraddr, signaddr): + result = self.gpg.encrypt(data, *encraddr, default_key=signaddr) + self._assert_gpg_result_ok(result) + return result.data def decrypt(self, data): pass def verify(self, data, signature): pass + + def _assert_gpg_result_ok(self, result): + stderr = getattr(result, 'stderr', '') + if getattr(result, 'ok', False) is not True: + raise RuntimeError('Failed to encrypt/decrypt: %s' % stderr) diff --git a/memoryhole/protection.py b/memoryhole/protection.py index b179614..b064f47 100644 --- a/memoryhole/protection.py +++ b/memoryhole/protection.py @@ -30,13 +30,14 @@ def protect(msg, openpgp=Gnupg(), encrypt=True, obscure=True): def _encrypt_mime(msg, openpgp): + encraddr = _recipient_addresses(msg) + signaddr = _from_address(msg) + newmsg = MultipartEncrypted('application/pgp-encrypted') for hkey, hval in msg.items(): newmsg.add_header(hkey, hval) del(msg[hkey]) - encraddr = "" # TODO - signaddr = "" # TODO encstr = openpgp.encrypt(msg.as_string(unixfrom=False), encraddr, signaddr) encmsg = MIMEApplication( @@ -51,3 +52,15 @@ def _encrypt_mime(msg, openpgp): newmsg.attach(metamsg) newmsg.attach(encmsg) return newmsg + + +def _recipient_addresses(msg): + recipients = [] + for header in ('to', 'cc', 'bcc'): + recipients += msg.get_all(header, []) + return [r[1] for r in getaddresses(recipients)] + + +def _from_address(msg): + frm = msg.get_all('From', []) + return parseaddr(frm)[1] |