JWKS-based JWT verification middleware for Swarmauri
Project description
Swarmauri Middleware JWKS Verifier
A middleware component providing JWT verification using a cached JWKS with TTL and LRU eviction.
Features
- Parses RSA, EC, Ed25519, and HMAC keys from JWKS documents (RFC 7517).
- Thread-safe cache with configurable TTL refresh and LRU eviction limits.
- Optional constructor guards for allowed algorithms and issuer values.
- Manual cache controls for forced refreshes, invalidation, and overrides.
Installation
Install the package with your preferred Python packaging tool:
pip install swarmauri_middleware_jwksverifier
poetry add swarmauri_middleware_jwksverifier
uv pip install swarmauri_middleware_jwksverifier
Quickstart
CachedJWKSVerifier expects a callable that returns a JWKS document. The fetch
callback is invoked whenever the cache expires (default ttl_s=300 seconds) or
when a forced refresh is requested.
The verifier exposes a verify helper that performs signature validation and
standard PyJWT checks. Pass the algorithms you are willing to accept by
supplying the algorithms_whitelist parameter on every verification call. If
you do not provide an explicit issuer, the first value from
allowed_issuers (if configured during construction) is used.
import base64
import jwt
from swarmauri_middleware_jwksverifier import CachedJWKSVerifier
SECRET = b"super-secret-signing-key"
def fetch_jwks() -> dict[str, object]:
return {
"keys": [
{
"kty": "oct",
"kid": "demo",
"k": base64.urlsafe_b64encode(SECRET).rstrip(b"=").decode("ascii"),
"alg": "HS256",
}
]
}
verifier = CachedJWKSVerifier(fetch=fetch_jwks, ttl_s=60)
token = jwt.encode(
{"sub": "user-123", "aud": "example-service"},
SECRET,
algorithm="HS256",
headers={"kid": "demo"},
)
claims = verifier.verify(
token,
algorithms_whitelist=["HS256"],
audience="example-service",
)
print(claims["sub"])
Cache management helpers
refresh(force: bool = False)— trigger a JWKS refresh immediately whenforceis true or the cache has expired.invalidate(kid: Optional[str] = None)— drop either a specific key or the entire cache, including overrides.inject_override_key(kid, key_obj)/inject_override_jwk(kid, jwk)— add temporary key material that bypasses JWKS fetching when resolving bykid.key_resolver()— obtain a callable suitable for advanced PyJWT usage when integrating with other verification flows.
Entry Point
The middleware registers under the swarmauri.middlewares entry point as
CachedJWKSVerifier.
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_middleware_jwksverifier-0.3.0.dev33.tar.gz.
File metadata
- Download URL: swarmauri_middleware_jwksverifier-0.3.0.dev33.tar.gz
- Upload date:
- Size: 9.0 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 |
f9c5d47f494882725f7e49bd9549ab927f65e1b05bf3826c8b4a2df7b5b932d0
|
|
| MD5 |
af27b71ac6fc229052e450bb89286ce1
|
|
| BLAKE2b-256 |
db31af1766499d1736d782d44fc2c1b2e83d8ec7bee9b5e194b1a00962343e57
|
File details
Details for the file swarmauri_middleware_jwksverifier-0.3.0.dev33-py3-none-any.whl.
File metadata
- Download URL: swarmauri_middleware_jwksverifier-0.3.0.dev33-py3-none-any.whl
- Upload date:
- Size: 9.9 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 |
547a015996128f73c89e610fc18e60ac9c97d1f9ffea01cb52d8ec134f019280
|
|
| MD5 |
ade47e3fe97e7362636ebb028dfb1b35
|
|
| BLAKE2b-256 |
f44600e44ed6aec4d76bfe774e1c234e6cee1d50b1dc1dc6f273d80ea67966f9
|