Как я могу подписать данные с Pyme? - PullRequest
0 голосов
/ 07 октября 2009

Я только что установил pyme в моей системе Ubuntu. это было легко (спасибо apt-get), и я могу воспроизвести пример кода (шифрование с использованием открытого ключа в моей связке ключей). теперь я хотел бы подписать некоторые данные, и мне не удалось найти ни пример кода, ни много документации.

вот что я делал:

>>> plain = pyme.core.Data('this is just some sample text\n')
>>> cipher = pyme.core.Data()
>>> c = pyme.core.Context()
>>> c.set_armor(1)
>>> name='me@office.com'
>>> c.op_keylist_start(name, 0)
>>> r = c.op_keylist_next()
>>> c.op_sign(???)

Я не знаю, что давать в качестве параметров, метод op_sign подсказывает мне

>>> help(c.op_sign)
Help on function _funcwrap in module pyme.util:

_funcwrap(*args, **kwargs)
    gpgme_op_sign(ctx, plain, sig, mode) -> gpgme_error_t

но я не знаю, как создавать такие объекты.

1 Ответ

0 голосов
/ 07 октября 2009

Вы можете следовать примеру из pyme doc и немного его изменить:

import pyme.core
import pyme.pygpgme

plaintext = pyme.core.Data('this is a test message')
ciphertext = pyme.core.Data()
ctx = pyme.core.Context()
ctx.set_armor(1)
name = 'me@office.com'
ctx.op_keylist_start(name, 0)
key = ctx.op_keylist_next()
# first argument is message to sign, second argument is buffer where to write
# the signature, third argument is signing mode, see
# http://www.gnupg.org/documentation/manuals/gpgme/Creating-a-Signature.html#Creating-a-Signature for more details.
ctx.op_sign(plaintext, ciphertext, pyme.pygpgme.GPGME_SIG_MODE_CLEAR)
ciphertext.seek(0, 0)
print ciphertext.read()
...