From f4ba16b31ea282d0787a40be3f37b951584143a1 Mon Sep 17 00:00:00 2001 From: Justus Winter Date: Tue, 10 May 2016 13:19:26 +0200 Subject: python: Rename bindings. -- Signed-off-by: Justus Winter --- lang/python/examples/encrypt-to-all.py | 68 ++++++++++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100755 lang/python/examples/encrypt-to-all.py (limited to 'lang/python/examples/encrypt-to-all.py') diff --git a/lang/python/examples/encrypt-to-all.py b/lang/python/examples/encrypt-to-all.py new file mode 100755 index 00000000..8f9d2500 --- /dev/null +++ b/lang/python/examples/encrypt-to-all.py @@ -0,0 +1,68 @@ +#!/usr/bin/env python3 +# $Id$ +# Copyright (C) 2008 Igor Belyi +# Copyright (C) 2002 John Goerzen +# +# 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 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 for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + +""" +This program will try to encrypt a simple message to each key on your +keyring. If your keyring has any invalid keys on it, those keys will +be skipped and it will re-try the encryption.""" + +from pyme import core +from pyme.core import Data, Context +from pyme.constants import validity + +core.check_version(None) + +plain = Data(b'This is my message.') + +c = Context() +c.set_armor(1) + +def sendto(keylist): + cipher = Data() + c.op_encrypt(keylist, 1, plain, cipher) + cipher.seek(0,0) + return cipher.read() + +names = [] +for key in c.op_keylist_all(None, 0): + try: + print(" *** Found key for %s" % key.uids[0].uid) + valid = 0 + for subkey in key.subkeys: + keyid = subkey.keyid + if keyid == None: + break + can_encrypt = subkey.can_encrypt + valid += can_encrypt + print(" Subkey %s: encryption %s" % \ + (keyid, can_encrypt and "enabled" or "disabled")) + except UnicodeEncodeError as e: + print(e) + + if valid: + names.append(key) + else: + print(" This key cannot be used for encryption; skipping.") + +passno = 0 + +print("Encrypting to %d recipients" % len(names)) +print(sendto(names)) + + -- cgit v1.2.3 From aade53a12b9716997684b872bc2ac87229f73fb3 Mon Sep 17 00:00:00 2001 From: Justus Winter Date: Tue, 10 May 2016 13:30:30 +0200 Subject: python: Delete trailing whitespace. -- Signed-off-by: Justus Winter --- lang/python/examples/encrypt-to-all.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'lang/python/examples/encrypt-to-all.py') diff --git a/lang/python/examples/encrypt-to-all.py b/lang/python/examples/encrypt-to-all.py index 8f9d2500..c890df4f 100755 --- a/lang/python/examples/encrypt-to-all.py +++ b/lang/python/examples/encrypt-to-all.py @@ -54,7 +54,7 @@ for key in c.op_keylist_all(None, 0): (keyid, can_encrypt and "enabled" or "disabled")) except UnicodeEncodeError as e: print(e) - + if valid: names.append(key) else: -- cgit v1.2.3 From 11392a80d9a85bcd8718b105e6d58038e61beaac Mon Sep 17 00:00:00 2001 From: Justus Winter Date: Tue, 10 May 2016 14:45:44 +0200 Subject: python: PEP8 fixes. Cherry picked from 0267c151. Signed-off-by: Justus Winter --- lang/python/examples/encrypt-to-all.py | 17 ++++++++--------- 1 file changed, 8 insertions(+), 9 deletions(-) (limited to 'lang/python/examples/encrypt-to-all.py') diff --git a/lang/python/examples/encrypt-to-all.py b/lang/python/examples/encrypt-to-all.py index c890df4f..672e6614 100755 --- a/lang/python/examples/encrypt-to-all.py +++ b/lang/python/examples/encrypt-to-all.py @@ -3,10 +3,10 @@ # Copyright (C) 2008 Igor Belyi # Copyright (C) 2002 John Goerzen # -# 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 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 distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -15,7 +15,8 @@ # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software -# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA +# 02111-1307 USA """ This program will try to encrypt a simple message to each key on your @@ -46,11 +47,11 @@ for key in c.op_keylist_all(None, 0): valid = 0 for subkey in key.subkeys: keyid = subkey.keyid - if keyid == None: + if keyid is None: break can_encrypt = subkey.can_encrypt valid += can_encrypt - print(" Subkey %s: encryption %s" % \ + print(" Subkey %s: encryption %s" % (keyid, can_encrypt and "enabled" or "disabled")) except UnicodeEncodeError as e: print(e) @@ -64,5 +65,3 @@ passno = 0 print("Encrypting to %d recipients" % len(names)) print(sendto(names)) - - -- cgit v1.2.3 From 10328324c8fc9725cd0c885eaebfc80dc32c1ff6 Mon Sep 17 00:00:00 2001 From: Justus Winter Date: Tue, 17 May 2016 14:15:21 +0200 Subject: python: Clean up examples. * lang/python/examples/delkey.py: Clean up example. * lang/python/examples/encrypt-to-all.py: Likewise. * lang/python/examples/genkey.py: Likewise. * lang/python/examples/inter-edit.py: Likewise. * lang/python/examples/sign.py: Likewise. * lang/python/examples/signverify.py: Likewise. * lang/python/examples/simple.py: Likewise. * lang/python/examples/t-edit.py: Likewise. * lang/python/examples/verifydetails.py: Likewise. * lang/python/pyme/__init__.py: Likewise. Signed-off-by: Justus Winter --- lang/python/examples/encrypt-to-all.py | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) (limited to 'lang/python/examples/encrypt-to-all.py') diff --git a/lang/python/examples/encrypt-to-all.py b/lang/python/examples/encrypt-to-all.py index 672e6614..331933e4 100755 --- a/lang/python/examples/encrypt-to-all.py +++ b/lang/python/examples/encrypt-to-all.py @@ -23,13 +23,14 @@ This program will try to encrypt a simple message to each key on your keyring. If your keyring has any invalid keys on it, those keys will be skipped and it will re-try the encryption.""" +import sys +import os from pyme import core from pyme.core import Data, Context -from pyme.constants import validity core.check_version(None) -plain = Data(b'This is my message.') +plain = Data('This is my message.') c = Context() c.set_armor(1) @@ -37,7 +38,7 @@ c.set_armor(1) def sendto(keylist): cipher = Data() c.op_encrypt(keylist, 1, plain, cipher) - cipher.seek(0,0) + cipher.seek(0, os.SEEK_SET) return cipher.read() names = [] @@ -64,4 +65,4 @@ for key in c.op_keylist_all(None, 0): passno = 0 print("Encrypting to %d recipients" % len(names)) -print(sendto(names)) +sys.stdout.buffer.write(sendto(names)) -- cgit v1.2.3