Skip to main content

Starlette support for RFC9457 problems.

Project description

Starlette Problems

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

Uploaded Source

Built Distribution

starlette_problem-0.10.6-py3-none-any.whl (10.2 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for starlette_problem-0.10.6.tar.gz
Algorithm Hash digest
SHA256 f31dea6bba516afc4a55a8de1db214dffe37b15999528700c7f2e775fb861eec
MD5 1d88970acb98d83439b6843ed45a46c2
BLAKE2b-256 62c81d213bf1c8321fd086ef5cd569b9f0e2f202b7b247b6237f521a2e86bdf2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for starlette_problem-0.10.6-py3-none-any.whl
Algorithm Hash digest
SHA256 1763370f015e0e745cb8dc276b1a0361ca45b9fc564eb6b535f043898fe8ac69
MD5 f5f615f6109986ba9c97b91750e75e31
BLAKE2b-256 ffd2ec8b553fe29799a071a0c03ecfaabb807f871c1d1f35921821a41874cdce

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