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

Uploaded Source

Built Distribution

starlette_problem-0.10.1-py3-none-any.whl (9.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: starlette_problem-0.10.1.tar.gz
  • Upload date:
  • Size: 9.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.9.19 Linux/6.5.0-1025-azure

File hashes

Hashes for starlette_problem-0.10.1.tar.gz
Algorithm Hash digest
SHA256 dd034bdff8957f9e562117f4a553e874d21282a8ce56cda60f371d7e432a03e4
MD5 ad8ca0a8224294c5a7ad5993e7f7397d
BLAKE2b-256 7a13d97a386719a877de529b43a40b5f7c5b37af03519dc3fdb62852b3b4a577

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for starlette_problem-0.10.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9fdd23418ba953cd5a0c3046208bbbddb609adfc998f047b7bf90c8fc2a4e5e1
MD5 816fa4a441cb5e787bc616a3e6761a4c
BLAKE2b-256 6cf84dd2eda41481f045851540322527a6d1c5e1e3972086e03590d4590e5065

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