Skip to main content

JWKS-based JWT verification middleware for Swarmauri

Project description

Swarmauri Logo

PyPI - Downloads Hits PyPI - Python Version PyPI - License PyPI - swarmauri_middleware_jwksverifier


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 when force is 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 by kid.
  • 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


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

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

File details

Details for the file swarmauri_middleware_jwksverifier-0.3.0.dev43.tar.gz.

File metadata

  • Download URL: swarmauri_middleware_jwksverifier-0.3.0.dev43.tar.gz
  • Upload date:
  • Size: 9.0 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

Hashes for swarmauri_middleware_jwksverifier-0.3.0.dev43.tar.gz
Algorithm Hash digest
SHA256 b333d0cd1d8b8b93a3badbf512ee21652765be8641163b137dc2050b617edddf
MD5 7d2a5adf164b8e1f2115f3eab7bdff20
BLAKE2b-256 0de8d1c4b233aa555a4f611ff88bd1529459f2dff18c4aea735f62e87d57f82e

See more details on using hashes here.

File details

Details for the file swarmauri_middleware_jwksverifier-0.3.0.dev43-py3-none-any.whl.

File metadata

  • Download URL: swarmauri_middleware_jwksverifier-0.3.0.dev43-py3-none-any.whl
  • Upload date:
  • Size: 9.9 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

Hashes for swarmauri_middleware_jwksverifier-0.3.0.dev43-py3-none-any.whl
Algorithm Hash digest
SHA256 8b1f15e5dc4190e47349b8bcfdcf4a4373733ace876b3421ef0eedeb29c3d319
MD5 83c6b6df54a95bdc914320e8045ea89f
BLAKE2b-256 3a9e2da6b4dbc5d44698494ba6e3863ffb792b42bef5cfa2cc6ce19d127945c3

See more details on using hashes here.

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