-
Notifications
You must be signed in to change notification settings - Fork 76
Open
Labels
vendorThis is a PKCS#11 vendor bugThis is a PKCS#11 vendor bug
Description
I have the following python script:
#! /usr/bin/env python3
import os
import pkcs11
from Crypto.Hash import SHA256
from Crypto.PublicKey import ECC
from Crypto.Signature import DSS
from pkcs11 import KeyType, ObjectClass, Mechanism
from pkcs11.util.ec import encode_ec_public_key
lib = pkcs11.lib(os.environ['PKCS11_MODULE'])
token = lib.get_token(token_label='SmartCard-HSM (UserPIN)')
with token.open(rw=True, user_pin='123456') as session:
priv = session.get_key(label='testkeyEC666', key_type=KeyType.EC, object_class=ObjectClass.PRIVATE_KEY)
pubkey = session.get_key(label='testkeyEC666', key_type=KeyType.EC, object_class=ObjectClass.PUBLIC_KEY)
with open('somefile.bin', 'rb') as f:
data = bytearray(f.read())
signature = priv.sign(bytes(data), mechanism=Mechanism.ECDSA_SHA256)
h = SHA256.new(data)
verifier = DSS.new(ECC.import_key(encode_ec_public_key(pubkey)), 'fips-186-3')
try:
verifier.verify(h, signature)
print("signature ok.")
except ValueError:
print("signature not ok!")
It throws me the following error:
Traceback (most recent call last):
File "/home/Projects/Playground/python-pkcs11/./pkcs11-sign.py", line 30, in <module>
signature = priv.sign(bytes(data), mechanism=Mechanism.ECDSA_SHA256)
File "/usr/local/lib/python3.10/dist-packages/pkcs11/types.py", line 939, in sign
return self._sign(data, **kwargs)
File "pkcs11/_pkcs11.pyx", line 1072, in pkcs11._pkcs11.SignMixin._sign
File "pkcs11/_pkcs11.pyx", line 1083, in pkcs11._pkcs11.SignMixin._sign
File "pkcs11/_errors.pyx", line 88, in pkcs11._pkcs11.assertRV
pkcs11.exceptions.DataLenRange
Metadata
Metadata
Assignees
Labels
vendorThis is a PKCS#11 vendor bugThis is a PKCS#11 vendor bug