You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
JSON Web Token (JWT) Authentication module for CircuitPython. JSON Web Tokens are an open, industry standard
RFC 7519 method for representing claims securely between two parties.
This library currently supports the following signature algorithms for JWT generation and verification:
Please ensure all dependencies are available on the CircuitPython filesystem.
This is easily achieved by downloading
the Adafruit library and driver bundle.
Installing from PyPI
On supported GNU/Linux systems like the Raspberry Pi, you can install the driver locally from
PyPI. To install for current user:
pip3 install adafruit-circuitpython-jwt
To install system-wide (this may be required in some cases):
sudo pip3 install adafruit-circuitpython-jwt
To install in a virtual environment in your current project:
fromosimportgetenvimportadafruit_jwt# Import Private RSA key from a settings.toml fileprivate_key=getenv["private_key"]
# Create JWT Claimsclaims= {"iss": "joe",
"exp": 1300819380,
"name": "John Doe",
"admin": True}
# Generate JWT, sign with RSA private key and RS-256encoded_jwt=adafruit_jwt.JWT.generate(
claims, private_key, algo="RS256")
print("Encoded JWT: ", encoded_jwt)
Validating a generated JWT, encoded_jwt.
importadafruit_jwtdecoded_jwt=adafruit_jwt.JWT.validate(encoded_jwt)
# The decoded JWT's JOSE header and claims set are returned as a tupleprint('JOSE Header: {}\nJWT Claims: {}'.format(decoded_jwt[0], decoded_jwt[1]))
Documentation
API documentation for this library can be found on Read the Docs.
For information on building library documentation, please check out this guide.
Contributing
Contributions are welcome! Please read our Code of Conduct
before contributing to help this project stay welcoming.