paul@31 | 1 | #!/usr/bin/env python |
paul@31 | 2 | |
paul@31 | 3 | from MoinMessage import * |
paul@31 | 4 | from email.mime.text import MIMEText |
paul@62 | 5 | from email.parser import Parser |
paul@31 | 6 | import sys |
paul@31 | 7 | |
paul@71 | 8 | def decrypt(message): |
paul@71 | 9 | |
paul@71 | 10 | "Decrypt 'message' if necessary." |
paul@71 | 11 | |
paul@71 | 12 | if is_encrypted(message): |
paul@71 | 13 | text = gpg.decryptMessage(message) |
paul@99 | 14 | return Parser().parsestr(text) |
paul@71 | 15 | else: |
paul@71 | 16 | return message |
paul@71 | 17 | |
paul@71 | 18 | def verify(message): |
paul@71 | 19 | |
paul@71 | 20 | "Verify 'message' if possible." |
paul@71 | 21 | |
paul@71 | 22 | if is_signed(message): |
paul@71 | 23 | return gpg.verifyMessage(message) |
paul@71 | 24 | else: |
paul@71 | 25 | return None, None, message |
paul@71 | 26 | |
paul@31 | 27 | if __name__ == "__main__": |
paul@31 | 28 | try: |
paul@31 | 29 | signer = sys.argv[1] |
paul@31 | 30 | recipient = sys.argv[2] |
paul@31 | 31 | url = sys.argv[3] + "?action=FetchMessages" |
paul@31 | 32 | args = sys.argv[4:] |
paul@31 | 33 | except IndexError: |
paul@31 | 34 | args = None |
paul@31 | 35 | |
paul@31 | 36 | if not args: |
paul@31 | 37 | print >>sys.stderr, "Need a signer, recipient, URL and some commands as arguments to this program." |
paul@31 | 38 | sys.exit(1) |
paul@31 | 39 | |
paul@31 | 40 | message = Message() |
paul@31 | 41 | parts = [] |
paul@31 | 42 | |
paul@31 | 43 | part = MIMEText("\n".join(args), "plain", sys.stdin.encoding) |
paul@31 | 44 | message.add_update(part) |
paul@31 | 45 | |
paul@31 | 46 | email_message = message.get_payload() |
paul@31 | 47 | gpg = GPG() |
paul@31 | 48 | |
paul@31 | 49 | try: |
paul@31 | 50 | signed_message = gpg.signMessage(email_message, signer) |
paul@31 | 51 | encrypted_message = gpg.encryptMessage(signed_message, recipient) |
paul@62 | 52 | text = sendMessage(encrypted_message, url, "PUT") |
paul@99 | 53 | mailbox = Parser().parsestr(text) |
paul@62 | 54 | |
paul@71 | 55 | mailbox = decrypt(mailbox) |
paul@71 | 56 | fingerprint, identity, content = verify(mailbox) |
paul@62 | 57 | |
paul@71 | 58 | if fingerprint and identity: |
paul@70 | 59 | print >>sys.stderr, "Messages signed by", fingerprint, identity |
paul@62 | 60 | else: |
paul@70 | 61 | print >>sys.stderr, "Message not signed!" |
paul@62 | 62 | |
paul@70 | 63 | print >>sys.stderr |
paul@71 | 64 | |
paul@71 | 65 | if content.is_multipart(): |
paul@71 | 66 | for part in content.get_payload(): |
paul@71 | 67 | part = decrypt(part) |
paul@71 | 68 | fingerprint, identity, part = verify(part) |
paul@71 | 69 | if fingerprint and identity: |
paul@71 | 70 | print >>sys.stderr, "Part signed by", fingerprint, identity |
paul@71 | 71 | print part |
paul@71 | 72 | else: |
paul@71 | 73 | print content |
paul@62 | 74 | |
paul@31 | 75 | except MoinMessageError, exc: |
paul@70 | 76 | print >>sys.stderr, exc |
paul@31 | 77 | |
paul@31 | 78 | # vim: tabstop=4 expandtab shiftwidth=4 |