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

Uploaded Source

Built Distribution

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

Uploaded Python 3

File details

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

File metadata

  • Download URL: starlette_problem-0.10.8.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.8.tar.gz
Algorithm Hash digest
SHA256 d0512add8845957c0983696e5b8808c0bcba42fa53a9ee7a2446439464d51357
MD5 764a2d665f65cc3a5bd10bfd5067dac7
BLAKE2b-256 59f2b54f3e4361eeaf0d8e7035b64a7adbe5f0b025c9bd5cdb9d30367f2f0d4b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for starlette_problem-0.10.8-py3-none-any.whl
Algorithm Hash digest
SHA256 2a791ceb139e39b443c3c7b35ccf30dae368675a3a5bd25f922f1fe17e538247
MD5 4f316f1fcaff3d3373e4cabd4f5b5ce7
BLAKE2b-256 50859d8ee4db4593527d87ae268c147c6552a7a9e5cdc6f85366caf73bd5e008

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