Skip to main content

Starlette support for RFC9457 problems.

Project description

Starlette Problems

uv ruff image image image style tests codecov

starlette_problem is a set of exceptions and handlers for use in starlette 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 starlette_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 starlette.applications
from starlette_problem.handler import add_exception_handler


app = starlette.applications.Starlette()
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

starlette_problem-0.10.7.tar.gz (59.8 kB view details)

Uploaded Source

Built Distribution

starlette_problem-0.10.7-py3-none-any.whl (10.7 kB view details)

Uploaded Python 3

File details

Details for the file starlette_problem-0.10.7.tar.gz.

File metadata

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

File hashes

Hashes for starlette_problem-0.10.7.tar.gz
Algorithm Hash digest
SHA256 a2559aa37da1c79c4bce055684ce0931070d01f25af91bdb000a4602c5634e07
MD5 c261637a1b67a8a51bb843284a13a27f
BLAKE2b-256 d6f0da4bbd232c6ffbb78f6b631bfe533be8e0c1a2432b43172c9a5b90c71e38

See more details on using hashes here.

File details

Details for the file starlette_problem-0.10.7-py3-none-any.whl.

File metadata

File hashes

Hashes for starlette_problem-0.10.7-py3-none-any.whl
Algorithm Hash digest
SHA256 a26a6f9052ba9f078400c6d121c401304de5c5f849ade8725be4a8552eb9bd83
MD5 a12b4cb75d1ddc6303e79cf8871f3c01
BLAKE2b-256 d8358625718ade243084527b3d86b08ec310eec2a091cace2eb460815ec8129e

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