PKCS11 Keys classes for cryptography
This module provide cryptography compatible proxy class for using a crypto smartcard , (such as yubi key, or PKCS#11 token) to process the actually cryptographic workload.
These are normally considered to be ‘secure’ tokens and the private key they are normally configured so the private key is not extractable from the token’s hardware. As a result you need to request the token to do any cryptographic operation for which you would normally use the private key.
In this module you will find a new abstraction of cryptography’s RSAPrivateKey class called RSAPrivateToken which instead using one the normal cryptography provided backend uses an hardware token directly.
Currently this means the PKCS#11 API, as provided on Linux by the opensc-pkcs11  package. TokenCrypt uses the PyKCS11 library to wrap the opensc PKCS#11 library and needs a environment variable set so the library can be found on debian that would be
A use case of this library would be to use a yubikey to provide Oauth identity services to python applications which use the requests-Oauth2 library. This is quite common if you are accessing 3rd party APIs to cloud service systems.
In this case a RSAPrivateToken can be provided to the library in the place of the usual RSAPrivateKey.
Many library examples show providing an PEM encoded string, but they also work with a subclass of cryptography’s RSAPrivateKey, as shown below.
import TokenCrypt from ThierAPI import APIConection, PrivateCredentials # Not a working example. rsa_key = TokenCrypt.RSAPrivateToken(slot = 0 , key = 0, pin = '123456' ) with rsa_key: credentials = PrivateCredentials(args.consumer_key, rsa_key) api = APIConection(credentials) do_something_with(api)
|||This is the package name in debian Stretch, Buster, Bullseye(so far), your distribution may vary.|
This is an initial proof of concept release which is design to have enough code to support working as an Oauth client. As a result the only action currently implemented on the key is signing.
But there is a lot todo, Pull requests and bug reports welcome.
- Implement RSAPublicToken .
- Dynamically select the signing mechanism based to the provided padding and hash.
- Implement decrypt.
- Implement certificate extraction.
|Filename, size||File type||Python version||Upload date||Hashes|
|Filename, size tokencrypt-0.1.2-py3-none-any.whl (4.0 kB)||File type Wheel||Python version py3||Upload date||Hashes View hashes|
|Filename, size tokencrypt-0.1.2.tar.gz (4.0 kB)||File type Source||Python version None||Upload date||Hashes View hashes|
Hashes for tokencrypt-0.1.2-py3-none-any.whl