diff options
| author | Ben McGinnes <[email protected]> | 2018-03-21 18:40:02 +0000 | 
|---|---|---|
| committer | Ben McGinnes <[email protected]> | 2018-03-21 18:40:02 +0000 | 
| commit | 0ccc57c9512246d82d46e7732bfb0f95c18ca9d3 (patch) | |
| tree | 7ab1acf4a1ebc4ca44295e9ecfb389d4d166b44a | |
| parent | example: group key selection (diff) | |
| download | gpgme-0ccc57c9512246d82d46e7732bfb0f95c18ca9d3.tar.gz gpgme-0ccc57c9512246d82d46e7732bfb0f95c18ca9d3.zip | |
example: sign and encrypt to group
* Begins to string together some of the simpler examples to do more
  useful things.
* Signs and encrypts a file while encrypting to every key in a group
  specified in the gpg.conf file.
| -rwxr-xr-x | lang/python/examples/howto/group-encrypt-sign-file.py | 83 | 
1 files changed, 83 insertions, 0 deletions
| diff --git a/lang/python/examples/howto/group-encrypt-sign-file.py b/lang/python/examples/howto/group-encrypt-sign-file.py new file mode 100755 index 00000000..920e50da --- /dev/null +++ b/lang/python/examples/howto/group-encrypt-sign-file.py @@ -0,0 +1,83 @@ +#!/usr/bin/env python3 +# -*- coding: utf-8 -*- + +from __future__ import absolute_import, division, unicode_literals + +# Copyright (C) 2018 Ben McGinnes <[email protected]> +# +# This program is free software; you can redistribute it and/or modify it under +# the terms of the GNU General Public License as published by the Free Software +# Foundation; either version 2 of the License, or (at your option) any later +# version. +# +# This program is free software; you can redistribute it and/or modify it under +# the terms of the GNU Lesser General Public License as published by the Free +# Software Foundation; either version 2.1 of the License, or (at your option) +# any later version. +# +# This program is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS +# FOR A PARTICULAR PURPOSE.  See the GNU General Public License and the GNU +# Lesser General Public Licensefor more details. +# +# You should have received a copy of the GNU General Public License and the GNU +# Lesser General Public along with this program; if not, see +# <http://www.gnu.org/licenses/>. + +import gpg +import sys + +from groups import group_lists + +""" +Signs and encrypts a file to a specified group of keys.  If entering both the +group and the filename on the command line, the group must be entered first. + +Signs with and also encrypts to the default key of the user invoking the +script.  Will treat all recipients as trusted to permit encryption. + +Will produce both an ASCII armoured and GPG binary format copy of the signed +and encrypted file. +""" + +if len(sys.argv) > 3: +    group = sys.argv[1] +    filename = " ".join(sys.argv[2:]) +elif len(sys.argv) == 3: +    group = sys.argv[1] +    filename = sys.argv[2] +elif len(sys.argv) == 2: +    group = sys.argv[1] +    filename = input("Enter the path and filename to encrypt: ") +else: +    group = input("Enter the name of the group to select keys for: ") +    filename = input("Enter the path and filename to encrypt: ") + +keys = [] +a = [] + +for i in range(len(group_lists)): +    a.append(group_lists[i][0]) + +b = a.index(group) + +for i in range(len(group_lists[b][1])): +    logrus = group_lists[b][1][i] +    keys.append(gpg.Context().keylist(pattern=logrus)) + +with open(filename, "rb") as f: +    text = f.read() + +with gpg.Context(armor=True) as ca: +    ciphertext, result, sign_result = ca.encrypt(text, recipients=keys, +                                                 always_trust=True, +                                                     add_encrypt_to=True) +    with open("{0}.asc".format(filename), "wb") as fa: +        fa.write(ciphertext) + +with gpg.Context() as cg: +    ciphertext, result, sign_result = cg.encrypt(text, recipients=keys, +                                                 always_trust=True, +                                                     add_encrypt_to=True) +    with open("{0}.gpg".format(filename), "wb") as fg: +        fg.write(ciphertext) | 
