Skip to main content

Custom Exception Handling Middleware for Swarmauri Framework

Project description

Swarmauri Logo

PyPI - Downloads Hits PyPI - Python Version PyPI - License PyPI - swarmauri_middleware_exceptionhandling Discord

Swarmauri Middleware Exception Handling

Centralized exception and error handling for Swarmauri applications built on FastAPI.

Features

  • Wraps unhandled exceptions in a consistent JSON payload with the error type, message, and a UTC timestamp.
  • Logs request metadata (method, path, and headers) alongside the stack trace to simplify troubleshooting.
  • Registers through the Swarmauri component system and can be attached to any FastAPI application via app.middleware("http").

Installation

Pick the workflow that matches your project:

pip install swarmauri_middleware_exceptionhandling
poetry add swarmauri_middleware_exceptionhandling
uv pip install swarmauri_middleware_exceptionhandling
# or, inside a uv project
uv add swarmauri_middleware_exceptionhandling

Usage

Attach the middleware to convert uncaught exceptions into the structured error response returned by Swarmauri services.

from fastapi import FastAPI
from fastapi.testclient import TestClient

from swarmauri_middleware_exceptionhandling import ExceptionHandlingMiddleware

app = FastAPI()
app.middleware("http")(ExceptionHandlingMiddleware())


@app.get("/boom")
async def boom():
    raise RuntimeError("Boom!")


client = TestClient(app)
response = client.get("/boom")
assert response.status_code == 500
print(response.json())

The JSON payload produced by the middleware includes the error type, message, and a timestamp similar to the following:

{
  "error": {
    "type": "Unhandled Exception",
    "message": "Boom!",
    "timestamp": "2024-05-01T12:34:56.789012"
  }
}

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_exceptionhandling-0.11.0.dev1.tar.gz.

File metadata

  • Download URL: swarmauri_middleware_exceptionhandling-0.11.0.dev1.tar.gz
  • Upload date:
  • Size: 7.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.26 {"installer":{"name":"uv","version":"0.11.26","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_exceptionhandling-0.11.0.dev1.tar.gz
Algorithm Hash digest
SHA256 0176e09b9a0f198b5612fd5152ab50976ac79f2d7a1de544c2ab3947cd6b311a
MD5 c444c2fbc94667d9effd2fb55487e180
BLAKE2b-256 94b733a99b15e03ee6af070c5a38575d560e3e9f03ec525fa74bab7729c99eb0

See more details on using hashes here.

File details

Details for the file swarmauri_middleware_exceptionhandling-0.11.0.dev1-py3-none-any.whl.

File metadata

  • Download URL: swarmauri_middleware_exceptionhandling-0.11.0.dev1-py3-none-any.whl
  • Upload date:
  • Size: 8.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.26 {"installer":{"name":"uv","version":"0.11.26","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_exceptionhandling-0.11.0.dev1-py3-none-any.whl
Algorithm Hash digest
SHA256 97e14ccb409d31b54aec32e7c2a3adaec81169be0d4f15ba3b03d26bb707daf9
MD5 ab0875bbd1c8154f15ec86b223aba3b7
BLAKE2b-256 5824719b6ee84b55707062b6cf6e2e61c4d72aa2c19ead2e03b24843cf0c9ca4

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