SSH-based key provider for Swarmauri
Project description
Swarmauri SSH Key Provider
An asynchronous KeyProviderBase implementation that keeps SSH key material in
memory and bridges it to Swarmauri's signing abstractions.
Features
- Generate new Ed25519, RSA-PSS (SHA-256), or ECDSA P-256 key pairs on demand.
- Import existing private keys (PEM) or public keys (OpenSSH) while respecting
each key's
ExportPolicy. - Rotate keys, enumerate versions, and optionally destroy specific versions or entire key identifiers.
- Export public keys as RFC 7517-compliant JWKs/JWKS with OpenSSH fingerprints
embedded in the
tagsmetadata. - Produce random bytes and derive keying material using the HKDF construction (RFC 5869).
Installation
Choose the tool that matches your workflow:
# pip
pip install swarmauri_keyprovider_ssh
# Poetry
poetry add swarmauri_keyprovider_ssh
# uv
uv add swarmauri_keyprovider_ssh
Usage
The provider exposes an asynchronous interface for creating and managing SSH-based signing keys. The snippet below creates a new Ed25519 key and exports its public component as a JSON Web Key (JWK):
import asyncio
from swarmauri_keyprovider_ssh import SshKeyProvider
from swarmauri_core.key_providers.types import (
KeySpec,
KeyAlg,
KeyClass,
ExportPolicy,
KeyUse,
)
async def main() -> None:
provider = SshKeyProvider()
spec = KeySpec(
klass=KeyClass.asymmetric,
alg=KeyAlg.ED25519,
uses=(KeyUse.SIGN, KeyUse.VERIFY),
export_policy=ExportPolicy.PUBLIC_ONLY,
)
ref = await provider.create_key(spec)
jwk = await provider.get_public_jwk(ref.kid)
print(jwk)
asyncio.run(main())
Keys can also be rotated, and the provider will track key versions:
ref = await provider.create_key(spec)
await provider.rotate_key(ref.kid)
assert await provider.list_versions(ref.kid) == (1, 2)
Use destroy_key() to remove an entire key identifier or just a single
version, and jwks(prefix_kids=...) when you need to emit a filtered JWKS for
downstream consumers.
Existing keys can be imported from PEM or OpenSSH data and exposed via JWKS:
from pathlib import Path
pem = Path("id_ed25519").read_bytes()
ref = await provider.import_key(spec, pem)
jwks = await provider.jwks()
Want to help?
If you want to contribute to swarmauri-sdk, read up on our guidelines for contributing that will help you get started.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file swarmauri_keyprovider_ssh-0.3.0.dev46.tar.gz.
File metadata
- Download URL: swarmauri_keyprovider_ssh-0.3.0.dev46.tar.gz
- Upload date:
- Size: 9.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.12 {"installer":{"name":"uv","version":"0.10.12","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ad1521ae6f7582cca3dfd563a089ebdf1627d970c8d22be233698c76b163a8ef
|
|
| MD5 |
33a2134ffdb58275df5c09b283f845c8
|
|
| BLAKE2b-256 |
cd53dbac93793ea95656769f1a2518cd623defac7f0dc2c6237e15792d57146f
|
File details
Details for the file swarmauri_keyprovider_ssh-0.3.0.dev46-py3-none-any.whl.
File metadata
- Download URL: swarmauri_keyprovider_ssh-0.3.0.dev46-py3-none-any.whl
- Upload date:
- Size: 10.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.12 {"installer":{"name":"uv","version":"0.10.12","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4e0063b8890696e8064d76a31a0f2fdde875e5be5d478fc83aa8e0430a550aeb
|
|
| MD5 |
bcef444102cea51e5b2402e3788e0dd9
|
|
| BLAKE2b-256 |
284f0d9619b2f662651bd2850eda6599320ccdf56300592f207a7b70e9a06dab
|