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.12.0.tar.gz (60.4 kB view details)

Uploaded Source

Built Distribution

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

starlette_problem-0.12.0-py3-none-any.whl (10.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: starlette_problem-0.12.0.tar.gz
  • Upload date:
  • Size: 60.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.22

File hashes

Hashes for starlette_problem-0.12.0.tar.gz
Algorithm Hash digest
SHA256 befbaee708a9ff31c2a0a4a1214db06977f3248a6d6910f48e9674c3266325a6
MD5 dab7ee3fcadd121a23359be435f7f7a7
BLAKE2b-256 a2b4f3eea4e4f92bd5823b0d69d54cb121ceb25d92f5f9195cb8cebca2f52f5e

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for starlette_problem-0.12.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4ca8e9e1287b4e314760296c0c5382da0002d4b28ddbd456d57c6566e26603b1
MD5 fd9d2720325d0d1d8a8d77b23d3253f6
BLAKE2b-256 ac48d22aa8dbd86e94449294b39b5cb61772037b439cb8ccb4133126f4f3a919

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