Skip to main content

Nitrokey Python SDK

Project description

Nitrokey Python SDK

The Nitrokey Python SDK can be used to use and configure Nitrokey devices.

Documentation

Features

The SDK supports these devices and features:

  • Nitrokey 3
    • device and bootloader management (nitrokey.nk3)
    • admin app (nitrokey.trussed.admin_app)
    • provisioner app (nitrokey.trussed.provisioner_app)
    • secrets app (nitrokey.nk3.secrets_app)
  • Nitrokey Passkey
    • device and bootloader management (nitrokey.nkpk)
    • admin app (nitrokey.trussed.admin_app)
    • provisioner app (nitrokey.trussed.provisioner_app)

Installation

The Nitrokey Python SDK is released to the Python Package Index (PyPI) and can be installed with pip:

$ pip install nitrokey

The releases are also available as signed tags in the GitHub repository Nitrokey/nitrokey-sdk-py.

Getting Started

import nitrokey.trussed

print("Connected Nitrokey devices:")
for device in nitrokey.trussed.list():
    print(f"- {device.name} at {device.path}")

Compatibility

The Nitrokey Python SDK currently requires Python 3.10 or later. Support for old Python versions may be dropped in minor releases.

Related Projects

  • pynitrokey: A command line interface for the Nitrokey FIDO2, Nitrokey Start, Nitrokey 3 and NetHSM
  • nitrokey-app2: A graphical application to manage and use Nitrokey 3 devices
  • nethsm-sdk-py: A client-side Python SDK for NetHSM

Development

The following software is required for the development of the SDK:

  • Python 3.10 or newer
  • poetry
  • GNU Make
  • git

After checking out the source code from GitHub, you can install the SDK and its dev dependencies into a new virtual environment managed by poetry using make install:

$ git clone https://github.com/Nitrokey/nitrokey-sdk-py.git
$ cd nitrokey-sdk-py
$ make install

We use multiple checks and linters for this project. Use make check to run all required checks. Some problems can automatically be fixed by running make fix.

The SDK also includes minimal tests to ensure that it is installed and loaded correctly. Use make test to run these tests.

Dependency Management

We use poetry for dependency management. poetry maintains a lockfile with pinned dependency versions that is used for development environments and in CI. This lockfile includes the hash of the pyproject.toml file, so it needs to be updated if pyproject.toml is changed. These make targets can be used to invoke poetry for the most common tasks:

  • make install installs the SDK and its dependencies as specified in the lockfile (must be up-to-date)
  • make lock updates the lockfile without changing pinned dependency versions
  • make update bumps all dependencies, installs them and updates the lockfile

For more information, see poetry’s documentation on Managing depencies and Commands.

Publishing Releases

Releases are published using Github Actions. To create a new release:

  1. Update the version field in pyproject.toml manually or using poetry version.
  2. Update the changelog for the release.
  3. Commit these changes, create a PR and merge into main.
  4. Trigger the full.yaml workflow for the release branch to run the full compatibility tests.
  5. Create a signed tag with the version number and a v prefix, for example v0.2.4, and push it to this repository.
  6. Create a new release for this tag and copy the relevant parts from the changelog to the release description.
  7. Wait for the deployment action to run and approve the deployment to PyPI.
  8. Update the NITROKEY_SDK_PY_VERSION and NITROKEY_SDK_PY_CHECKSUM variables in the Makefile of the nitrokey-documentation repository to update the documentation on docs.nitrokey.com.

All commits to main are automatically deployed to TestPyPI. It is also possible to publish release candidates (pre-releases) with a suffix like -rc.1.

License

This software is fully open source.

All software, unless otherwise noted, is dual licensed under Apache 2.0 and MIT. You may use the software under the terms of either the Apache 2.0 license or MIT license.

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nitrokey-0.5.0rc2.tar.gz (117.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nitrokey-0.5.0rc2-py3-none-any.whl (167.5 kB view details)

Uploaded Python 3

File details

Details for the file nitrokey-0.5.0rc2.tar.gz.

File metadata

  • Download URL: nitrokey-0.5.0rc2.tar.gz
  • Upload date:
  • Size: 117.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for nitrokey-0.5.0rc2.tar.gz
Algorithm Hash digest
SHA256 3cc79a7d19947b78a6bb676e1ba06e2174be2f846b67bdaf950c48a875e4221d
MD5 76c751b9a5ef3f4ec3c619952718a5eb
BLAKE2b-256 12ea57c3724aa226789825fcd80168b712f6220c875f783d8cc85cebb6aae0ec

See more details on using hashes here.

Provenance

The following attestation bundles were made for nitrokey-0.5.0rc2.tar.gz:

Publisher: cd-pypi.yaml on Nitrokey/nitrokey-sdk-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nitrokey-0.5.0rc2-py3-none-any.whl.

File metadata

  • Download URL: nitrokey-0.5.0rc2-py3-none-any.whl
  • Upload date:
  • Size: 167.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for nitrokey-0.5.0rc2-py3-none-any.whl
Algorithm Hash digest
SHA256 0b6df5ac57b46024b02d904636335c6aa3331c2796ed36ec7398bf56653b9267
MD5 8d74998d6eae032cfc9e770538fe0b9f
BLAKE2b-256 6856708ce6bb6ba491b2da8224cb240dfac52b3a2f5afd734a0ad4b5d0133db2

See more details on using hashes here.

Provenance

The following attestation bundles were made for nitrokey-0.5.0rc2-py3-none-any.whl:

Publisher: cd-pypi.yaml on Nitrokey/nitrokey-sdk-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page