diff --git a/lang/python/examples/howto/encrypt-file.py b/lang/python/examples/howto/encrypt-file.py index 017a3421..877226d0 100755 --- a/lang/python/examples/howto/encrypt-file.py +++ b/lang/python/examples/howto/encrypt-file.py @@ -1,70 +1,71 @@ #!/usr/bin/env python3 # -*- coding: utf-8 -*- from __future__ import absolute_import, division, unicode_literals # Copyright (C) 2018 Ben McGinnes # # 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 # . import gpg import sys """ Encrypts a file to a specified key. If entering both the key and the filename on the command line, the key must be entered first. -Will produce both an ASCII armoured and GPG binary format copy of the encrypted file. +Will produce both an ASCII armoured and GPG binary format copy of the encrypted +file. """ if len(sys.argv) > 3: a_key = sys.argv[1] filename = " ".join(sys.argv[2:]) elif len(sys.argv) == 3: a_key = sys.argv[1] filename = sys.argv[2] elif len(sys.argv) == 2: a_key = sys.argv[1] filename = input("Enter the path and filename to encrypt: ") else: a_key = input("Enter the fingerprint or key ID to encrypt to: ") filename = input("Enter the path and filename to encrypt: ") rkey = list(c.keylist(pattern=a_key, secret=False)) with open(filename, "rb") as f: text = f.read() with gpg.Context(armor=True) as ca: try: ciphertext, result, sign_result = ca.encrypt(text, recipients=rkey, sign=False) with open("{0}.asc".format(filename), "wb") as fa: fa.write(ciphertext) except gpg.errors.InvalidRecipients as e: print(e) with gpg.Context() as cg: try: ciphertext, result, sign_result = cg.encrypt(text, recipients=rkey, sign=False) with open("{0}.gpg".format(filename), "wb") as fg: fg.write(ciphertext) except gpg.errors.InvalidRecipients as e: print(e) diff --git a/lang/python/examples/howto/sign-file.py b/lang/python/examples/howto/sign-file.py index 8e2cdc2d..01006df0 100755 --- a/lang/python/examples/howto/sign-file.py +++ b/lang/python/examples/howto/sign-file.py @@ -1,63 +1,64 @@ #!/usr/bin/env python3 # -*- coding: utf-8 -*- from __future__ import absolute_import, division, unicode_literals # Copyright (C) 2018 Ben McGinnes # # 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 # . import gpg import sys """ Signs a file with a specified key. If entering both the key and the filename on the command line, the key must be entered first. -Will produce both an ASCII armoured and GPG binary format copy of the encrypted file. +Will produce both an ASCII armoured and GPG binary format copy of the signed +file. """ if len(sys.argv) > 3: logrus = sys.argv[1] filename = " ".join(sys.argv[2:]) elif len(sys.argv) == 3: logrus = sys.argv[1] filename = sys.argv[2] elif len(sys.argv) == 2: logrus = sys.argv[1] filename = input("Enter the path and filename to sign: ") else: logrus = input("Enter the fingerprint or key ID to sign with: ") filename = input("Enter the path and filename to sign: ") with open(filename, "rb") as f: text = f.read() key = list(gpg.Context().keylist(pattern=logrus)) with gpg.Context(armor=True, signers=key) as ca: signed_data, result = ca.sign(text, mode=gpg.constants.sig.mode.NORMAL) with open("{0}.asc".format(filename), "wb") as fa: fa.write(signed_data) with gpg.Context(signers=key) as cg: signed_data, result = cg.sign(text, mode=gpg.constants.sig.mode.NORMAL) with open("{0}.gpg".format(filename), "wb") as fg: fg.write(signed_data)