2015-05-05 17:09:44 +00:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
# Copyright (C) 2004,2008 Igor Belyi <belyi@users.sourceforge.net>
|
|
|
|
#
|
|
|
|
# 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
|
|
|
|
|
|
|
|
# Sample of unattended signing/verifying of a message.
|
2015-05-16 16:35:24 +00:00
|
|
|
# It uses keys for joe@example.org generated by genkey.pl script
|
2015-05-05 17:09:44 +00:00
|
|
|
|
|
|
|
import sys
|
2016-05-17 12:15:21 +00:00
|
|
|
import os
|
|
|
|
from pyme import core
|
2015-05-05 17:09:44 +00:00
|
|
|
from pyme.constants.sig import mode
|
|
|
|
|
|
|
|
core.check_version(None)
|
|
|
|
|
2015-05-16 19:07:12 +00:00
|
|
|
plain = core.Data(b"Test message")
|
2015-05-05 17:09:44 +00:00
|
|
|
sig = core.Data()
|
|
|
|
c = core.Context()
|
2016-05-17 12:15:21 +00:00
|
|
|
user = "joe"
|
2015-05-05 17:09:44 +00:00
|
|
|
|
|
|
|
c.signers_clear()
|
2015-05-16 16:35:24 +00:00
|
|
|
# Add joe@example.org's keys in the list of signers
|
2015-05-05 17:09:44 +00:00
|
|
|
for sigkey in c.op_keylist_all(user, 1):
|
|
|
|
if sigkey.can_sign:
|
|
|
|
c.signers_add(sigkey)
|
|
|
|
if not c.signers_enum(0):
|
|
|
|
print("No secret %s's keys suitable for signing!" % user)
|
|
|
|
sys.exit(0)
|
|
|
|
|
|
|
|
# This is a map between signer e-mail and its password
|
|
|
|
passlist = {
|
2015-05-16 19:07:12 +00:00
|
|
|
b"<joe@example.org>": b"Crypt0R0cks"
|
2015-05-05 17:09:44 +00:00
|
|
|
}
|
2016-05-10 11:30:30 +00:00
|
|
|
|
2015-05-05 17:09:44 +00:00
|
|
|
# callback will return password based on the e-mail listed in the hint.
|
|
|
|
c.set_passphrase_cb(lambda x,y,z: passlist[x[x.rindex("<"):]])
|
|
|
|
|
|
|
|
c.op_sign(plain, sig, mode.CLEAR)
|
|
|
|
|
|
|
|
# Print out the signature (don't forget to rewind since signing put sig at EOF)
|
2016-05-17 12:15:21 +00:00
|
|
|
sig.seek(0, os.SEEK_SET)
|
2015-05-05 17:09:44 +00:00
|
|
|
signedtext = sig.read()
|
2016-05-17 12:15:21 +00:00
|
|
|
sys.stdout.buffer.write(signedtext)
|
2015-05-05 17:09:44 +00:00
|
|
|
|
|
|
|
# Create Data with signed text.
|
|
|
|
sig2 = core.Data(signedtext)
|
|
|
|
plain2 = core.Data()
|
|
|
|
|
|
|
|
# Verify.
|
|
|
|
c.op_verify(sig2, None, plain2)
|
|
|
|
result = c.op_verify_result()
|
|
|
|
|
|
|
|
# List results for all signatures. Status equal 0 means "Ok".
|
2016-05-17 12:15:21 +00:00
|
|
|
for index, sign in enumerate(result.signatures):
|
2015-05-05 17:09:44 +00:00
|
|
|
print("signature", index, ":")
|
|
|
|
print(" summary: ", sign.summary)
|
|
|
|
print(" status: ", sign.status)
|
|
|
|
print(" timestamp: ", sign.timestamp)
|
|
|
|
print(" fingerprint:", sign.fpr)
|
|
|
|
print(" uid: ", c.get_key(sign.fpr, 0).uids[0].uid)
|
|
|
|
|
|
|
|
# Print "unsigned" text. Rewind since verify put plain2 at EOF.
|
2016-05-17 12:15:21 +00:00
|
|
|
plain2.seek(0, os.SEEK_SET)
|
|
|
|
print("\n")
|
|
|
|
sys.stdout.buffer.write(plain2.read())
|