aboutsummaryrefslogtreecommitdiffstats
path: root/lang/python/examples/verifydetails.py
diff options
context:
space:
mode:
authorJustus Winter <[email protected]>2016-08-05 12:03:15 +0000
committerJustus Winter <[email protected]>2016-08-05 12:05:49 +0000
commit2a613e87156b23c4aa6aa5ce38505cb285de6a18 (patch)
tree2771ed69bf7299d1b1c9d89dca30b2e4119ac69a /lang/python/examples/verifydetails.py
parentcore: Extend gpgme_subkey_t to carry the keygrip. (diff)
downloadgpgme-2a613e87156b23c4aa6aa5ce38505cb285de6a18.tar.gz
gpgme-2a613e87156b23c4aa6aa5ce38505cb285de6a18.zip
python: Clean up and modernize examples.
* lang/python/examples/Examples.rst: Delete file. * lang/python/examples/t-edit.py: Likewise. This is actually a test case and has been moved to 'tests'. * lang/python/examples/assuan.py: New file. * lang/python/examples/decryption-filter.py: Likewise. * lang/python/examples/delkey.py: Modernize. * lang/python/examples/encrypt-to-all.py: Likewise. * lang/python/examples/exportimport.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/testCMSgetkey.py: Likewise. * lang/python/examples/verifydetails.py: Likewise. Signed-off-by: Justus Winter <[email protected]>
Diffstat (limited to 'lang/python/examples/verifydetails.py')
-rwxr-xr-xlang/python/examples/verifydetails.py93
1 files changed, 37 insertions, 56 deletions
diff --git a/lang/python/examples/verifydetails.py b/lang/python/examples/verifydetails.py
index 99e5e0a7..b57ed84f 100755
--- a/lang/python/examples/verifydetails.py
+++ b/lang/python/examples/verifydetails.py
@@ -1,27 +1,21 @@
#!/usr/bin/env python3
-# initial 20080123 build from the example:
-# very simple - probably INCOMPLETE
-# 20080703 Bernhard
-# added second usage for detached signatures.
-# added output of signature.summary (another bitfield)
-# printing signature bitfield in hex format
-#
#
+# Copyright (C) 2016 g10 Code GmbH
# Copyright (C) 2004,2008 Igor Belyi <[email protected]>
# Copyright (c) 2008 Bernhard Reiter <[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 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.
+# 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, see <http://www.gnu.org/licenses/>.
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, see <http://www.gnu.org/licenses/>.
import sys
import os
@@ -36,60 +30,47 @@ def print_engine_infos():
print(engine.file_name, engine.version)
for proto in [protocol.OpenPGP, protocol.CMS]:
- print(core.get_protocol_name(proto), core.engine_check_version(proto))
+ print("Have {}? {}".format(core.get_protocol_name(proto),
+ core.engine_check_version(proto)))
-def verifyprintdetails(sigfilename, filefilename=None):
+def verifyprintdetails(filename, detached_sig_filename=None):
"""Verify a signature, print a lot of details."""
- c = core.Context()
-
- # Create Data with signed text.
- sig2 = core.Data(file=sigfilename)
- if filefilename:
- file2 = core.Data(file=filefilename)
- plain2 = None
- else:
- file2 = None
- plain2 = core.Data()
-
- # Verify.
- c.op_verify(sig2, file2, plain2)
- result = c.op_verify_result()
-
- # List results for all signatures. Status equal 0 means "Ok".
- for index, sign in enumerate(result.signatures):
- print("signature", index, ":")
- print(" summary: %#0x" % (sign.summary))
- print(" status: %#0x" % (sign.status))
- print(" timestamp: ", sign.timestamp)
- print(" fingerprint:", sign.fpr)
- print(" uid: ", c.get_key(sign.fpr, 0).uids[0].uid)
+ with core.Context() as c:
+
+ # Verify.
+ data, result = c.verify(open(filename),
+ open(detached_sig_filename)
+ if detached_sig_filename else None)
+
+ # List results for all signatures. Status equal 0 means "Ok".
+ for index, sign in enumerate(result.signatures):
+ print("signature", index, ":")
+ print(" summary: %#0x" % (sign.summary))
+ print(" status: %#0x" % (sign.status))
+ print(" timestamp: ", sign.timestamp)
+ print(" fingerprint:", sign.fpr)
+ print(" uid: ", c.get_key(sign.fpr, 0).uids[0].uid)
# Print "unsigned" text if inline signature
- if plain2:
- #Rewind since verify put plain2 at EOF.
- plain2.seek(0, os.SEEK_SET)
- print("\n")
- sys.stdout.buffer.write(plain2.read())
+ if data:
+ sys.stdout.buffer.write(data)
def main():
print_engine_infos()
-
print()
- argc= len(sys.argv)
+ argc = len(sys.argv)
if argc < 2 or argc > 3:
- print("need a filename for inline signature")
- print("or two filename for detached signature and file to check")
- sys.exit(1)
+ sys.exit(
+ "Usage: {} <filename>[ <detached_signature_filename>]".format(
+ sys.argv[0]))
if argc == 2:
- print("trying to verify file: " + sys.argv[1])
+ print("trying to verify file {}.".format(sys.argv[1]))
verifyprintdetails(sys.argv[1])
if argc == 3:
- print("trying to verify signature %s for file %s" \
- % (sys.argv[1], sys.argv[2]))
-
+ print("trying to verify signature {1} for file {0}.".format(*sys.argv))
verifyprintdetails(sys.argv[1], sys.argv[2])
if __name__ == "__main__":