From 8ec5671025e0651e2808c67e66c634b2d46b77b4 Mon Sep 17 00:00:00 2001 From: mathieui Date: Tue, 4 Mar 2014 21:59:11 +0100 Subject: Add a script that generates a [keys] section for the gpg plugin --- scripts/poezio_gpg_export | 82 +++++++++++++++++++++++++++++++++++++++++++++++ setup.py | 2 +- 2 files changed, 83 insertions(+), 1 deletion(-) create mode 100755 scripts/poezio_gpg_export diff --git a/scripts/poezio_gpg_export b/scripts/poezio_gpg_export new file mode 100755 index 00000000..5b18218f --- /dev/null +++ b/scripts/poezio_gpg_export @@ -0,0 +1,82 @@ +#!/usr/bin/env python3 + +""" +Parses the output of gpg into a list suitable for the poezio +GPG plugin. Double-check the output and use at your own risk. +""" + +import subprocess +import pprint +import re +import os + +addr_re = re.compile(r'^uid\s+\[\s+full\s+\]\s.*<(.*@.*)>$') +id_re = re.compile(r'^pub\s+.*/(........) .*') + +def extract_block(total): + """ + GPG output blocks are separated by newlines + """ + if '' in total: + index = total.index('') + else: + index = len(total) + block = total[:index] + total = total[index+1:] + return (block, total) + +def parse_block(blocks, block): + """ + Keep the blocks with trusted keys + and extract addresses and UIDs + """ + + uid = '' + addrs = [] + blocksize = len(block) + + for i, line in enumerate(reversed(block)): + if line.startswith('uid'): + match = addr_re.match(line) + if match: + addr = match.groups()[0] + if addr not in addrs: + addrs.append(addr) + else: + del block[blocksize-1-i] + elif line.startswith('pub'): + uid = id_re.match(line).groups()[0] + + if addrs: + blocks[uid] = addrs + +def output(blocks): + print('[keys]') + for uid in blocks: + for addr in blocks[uid]: + print('%s = %s' % (addr, uid)) + +def main(): + + os.putenv('LANG', 'en_US.UTF-8') + + gpg_proc = subprocess.Popen( + [ + "/usr/bin/gpg", + "--list-keys", + "--list-options", + "show-uid-validity" + ], + stdout=subprocess.PIPE) + + result, _ = gpg_proc.communicate() + result = result.decode().strip().splitlines()[2:] + blocks = {} + + while result: + block, result = extract_block(result) + parse_block(blocks, block) + output(blocks) + +if __name__ == '__main__': + main() diff --git a/setup.py b/setup.py index 36170530..01a1b3bd 100644 --- a/setup.py +++ b/setup.py @@ -43,7 +43,7 @@ setup(name="poezio", packages = ['poezio', 'poezio_plugins', 'poezio_plugins.gpg', 'poezio_themes'], package_dir = {'poezio': 'src', 'poezio_plugins': 'plugins', 'poezio_themes': 'data/themes'}, package_data = {'poezio': ['default_config.cfg']}, - scripts = ['scripts/poezio'], + scripts = ['scripts/poezio', 'scripts/poezio_gpg_export'], data_files = [('share/poezio/themes/', ['data/themes/dark.py']), ('share/man/man1/', ['data/poezio.1'])], ) -- cgit v1.2.3