Skip to main content

FastAPI support for RFC9457 problems.

Project description

FastAPI Problems

uv ruff image image image style tests codecov

fastapi_problem is a set of exceptions and handlers for use in fastapi applications to support easy error management and responses.

Each exception easily marshals to JSON based on the RFC9457 spec for use in api errors.

Check the docs for more details.

Custom Errors

Subclassing the convenience classes provide a simple way to consistently raise the same error with detail/extras changing based on the raised context.

from fastapi_problem.error import NotFoundProblem


class UserNotFoundError(NotFoundProblem):
    title = "User not found."

raise UserNotFoundError(detail="detail")
{
    "type": "user-not-found",
    "title": "User not found",
    "detail": "detail",
    "status": 404,
}

Usage

import fastapi
from fastapi_problem.handler import add_exception_handler


app = fastapi.FastAPI()
add_exception_handler(app)

@app.get("/user")
async def get_user():
    raise UserNotFoundError("No user found.")
$ curl localhost:8000/user
{

    "type": "user-not-found",
    "title": "User not found",
    "detail": "No user found.",
    "status": 404,
}

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

fastapi_problem-0.9.6.tar.gz (66.8 kB view details)

Uploaded Source

Built Distribution

fastapi_problem-0.9.6-py3-none-any.whl (8.6 kB view details)

Uploaded Python 3

File details

Details for the file fastapi_problem-0.9.6.tar.gz.

File metadata

  • Download URL: fastapi_problem-0.9.6.tar.gz
  • Upload date:
  • Size: 66.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.20

File hashes

Hashes for fastapi_problem-0.9.6.tar.gz
Algorithm Hash digest
SHA256 7420698050f0d8ec1d2440d0e199081e4912fdd641f1b32f6c3aac3629484496
MD5 2d2b2132531a2fb4686f87470f011837
BLAKE2b-256 8ea71de8bd2fcb5c129fe3b6569699373f2eb9ca1fe3425f3b85a2dc245b11ca

See more details on using hashes here.

File details

Details for the file fastapi_problem-0.9.6-py3-none-any.whl.

File metadata

File hashes

Hashes for fastapi_problem-0.9.6-py3-none-any.whl
Algorithm Hash digest
SHA256 94c14a9f2aba41d87d85317da988c9597e97aa4209beb92d189cca5130d3a0d6
MD5 2c08b7d02221f62764b02004cd5f7e22
BLAKE2b-256 5319d360b62ee92dcb9e6bf53fc18ab1775d3f243ff11969ee0af3299de864d5

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page