Mirrored key provider for Swarmauri
Project description
Swarmauri Mirrored Key Provider
An asynchronous failover key provider that keeps a primary provider as the system of record while best-effort mirroring material to a secondary provider for redundancy.
Features
- Write operations (
create,import,rotate,destroy) execute on the primary provider first and then mirror to the secondary provider when possible. mirror_modegoverns what is replicated:public_only(default) mirrors only public material,fullattempts to replicate private material when export policy allows, andnonedisables replication while retaining read failover.- Read operations (
get_key,get_public_jwk,jwks,list_versions,random_bytes,hkdf) favor the primary provider and fail over to the secondary provider whenfail_open_readsis enabled. - JWKS responses merge keys from both providers, preferring primary entries when
the same
kidappears in both sets. - Maintains an in-memory mapping of mirrored key identifiers to coordinate destroy operations and failover reads—persist or rebuild this mapping if you need cross-process continuity.
- Optional extras add canonical JSON (
jsoncanon) and CBOR (cbor) support for consumers that require deterministic encodings.
Installation
Install the package with your preferred Python packaging tool:
pip install swarmauri_keyproviders_mirrored
poetry add swarmauri_keyproviders_mirrored
uv pip install swarmauri_keyproviders_mirrored
Enable extras for canonicalization when needed:
pip install swarmauri_keyproviders_mirrored[jsoncanon]
pip install swarmauri_keyproviders_mirrored[cbor]
Usage
The provider mirrors newly created keys to the secondary provider and fails open on reads when the primary becomes unavailable.
import asyncio
from swarmauri_keyproviders_mirrored import MirroredKeyProvider
from swarmauri_keyprovider_local import LocalKeyProvider
from swarmauri_core.key_providers.types import KeySpec, KeyAlg, KeyClass, ExportPolicy
from swarmauri_core.crypto.types import KeyUse
async def main() -> None:
primary = LocalKeyProvider()
secondary = LocalKeyProvider()
provider = MirroredKeyProvider(
primary,
secondary,
mirror_mode="public_only",
fail_open_reads=True,
)
spec = KeySpec(
klass=KeyClass.asymmetric,
alg=KeyAlg.ED25519,
uses=(KeyUse.SIGN, KeyUse.VERIFY),
export_policy=ExportPolicy.SECRET_WHEN_ALLOWED,
)
created = await provider.create_key(spec)
jwk = await provider.get_public_jwk(created.kid, created.version)
await primary.destroy_key(created.kid, created.version)
mirrored = await provider.get_public_jwk(created.kid, created.version)
assert mirrored["x"] == jwk["x"]
print(f"Failover retrieved Ed25519 key from secondary provider: {mirrored['kid']}")
if __name__ == "__main__":
asyncio.run(main())
In the example above the primary key is destroyed after mirroring, forcing
MirroredKeyProvider to serve the public key from the secondary provider.
Although mirrored keys may have different kid values, the public material
remains identical and ready for verification.
Mirror Modes
public_only(default) — Mirrors public key material and JWKS entries when available.full— Attempts to mirror private material when export policy permits, falling back to public-only replication otherwise.none— Disables replication while still permitting read failover to the secondary provider.
Failover Semantics
The fail_open_reads flag controls whether read operations fall back to the
secondary provider when the primary raises an exception. Disable it to surface
primary errors immediately.
Entry Point
The provider registers under the swarmauri.key_providers entry point as
MirroredKeyProvider.
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_keyproviders_mirrored-0.2.0.dev33.tar.gz.
File metadata
- Download URL: swarmauri_keyproviders_mirrored-0.2.0.dev33.tar.gz
- Upload date:
- Size: 9.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","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 |
244ed3e4e586a06f7c099f82f84362a6489029a6a11e49b07da31ab075d25123
|
|
| MD5 |
952172e3b60a4e12ffe277c585ee273e
|
|
| BLAKE2b-256 |
d43a59fd0f8cf4eecee18caddce9a4c6594f2d0707e593b4a8204b29042cd053
|
File details
Details for the file swarmauri_keyproviders_mirrored-0.2.0.dev33-py3-none-any.whl.
File metadata
- Download URL: swarmauri_keyproviders_mirrored-0.2.0.dev33-py3-none-any.whl
- Upload date:
- Size: 11.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","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 |
ac473e91a912d0e3a608bdb9147c7b17cacd976d714c2d549fbe067dda7a39cb
|
|
| MD5 |
6322435e736db03e20a3ee9f48b818e7
|
|
| BLAKE2b-256 |
294e1c7cb571ddb919c836f297b5390a51617340e62d3f4a27126e0c81bebc27
|