Skip to main content

JWT validation middleware for Swarmauri applications.

Project description

Swarmauri Logo

PyPI - Downloads Hits PyPI - Python Version PyPI - License PyPI - swarmauri_middleware_jwt


Swarmauri Middleware JWT

JWTMiddleware validates JSON Web Tokens (JWT) issued to FastAPI-based Swarmauri services. The middleware expects a Bearer token in the Authorization header, decodes it with the configured secret and algorithm, and stores the decoded payload on request.state.jwt_payload. Requests with missing or invalid tokens receive an HTTP 401 response.

Installation

pip

pip install swarmauri_middleware_jwt

Poetry

poetry add swarmauri_middleware_jwt

uv

# Install uv (see https://docs.astral.sh/uv/) if it is not already available
curl -LsSf https://astral.sh/uv/install.sh | sh

# Use uv to add the middleware to your environment
uv pip install swarmauri_middleware_jwt

Example

The example below attaches JWTMiddleware to a FastAPI application, issues a token using PyJWT, and performs a request that reads the decoded payload from request.state.

from fastapi import FastAPI, Request
from starlette.testclient import TestClient
import jwt

from swarmauri_middleware_jwt import JWTMiddleware


SECRET_KEY = "change-me"

app = FastAPI()

# Register the middleware with the FastAPI app
jwt_middleware = JWTMiddleware(secret_key=SECRET_KEY)
app.middleware("http")(jwt_middleware.dispatch)


@app.get("/protected")
async def protected_route(request: Request):
    return {"subject": request.state.jwt_payload["sub"]}


def run_example() -> dict:
    token = jwt.encode({"sub": "demo-user"}, SECRET_KEY, algorithm="HS256")
    client = TestClient(app)
    response = client.get(
        "/protected", headers={"Authorization": f"Bearer {token}"}
    )
    response.raise_for_status()
    return response.json()


if __name__ == "__main__":
    print(run_example())

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

swarmauri_middleware_jwt-0.8.0.dev38.tar.gz (7.4 kB view details)

Uploaded Source

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_jwt-0.8.0.dev38.tar.gz.

File metadata

  • Download URL: swarmauri_middleware_jwt-0.8.0.dev38.tar.gz
  • Upload date:
  • Size: 7.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","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_jwt-0.8.0.dev38.tar.gz
Algorithm Hash digest
SHA256 9b7c7d6a6d6406690580f58e9037064e8a745a115238b6b288675c2e41caa80a
MD5 56355f9062d3bf550064e82b1a8bc23e
BLAKE2b-256 fec91875e1503acaabcdc6b98dead60ccdafa2303aa002bfb0d00e3e8bb9385b

See more details on using hashes here.

File details

Details for the file swarmauri_middleware_jwt-0.8.0.dev38-py3-none-any.whl.

File metadata

  • Download URL: swarmauri_middleware_jwt-0.8.0.dev38-py3-none-any.whl
  • Upload date:
  • Size: 8.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","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_jwt-0.8.0.dev38-py3-none-any.whl
Algorithm Hash digest
SHA256 8bef4cbe6248608d3b673d5d30e1ff4ab0563a2875701076d8d740e06cb333bc
MD5 6a2996b7accd86ddea41dea9ab3eef73
BLAKE2b-256 b1e12206e13203e2c0b1df91e6b1cc5c42325c74d96397818072b316c2a704ad

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