RFC9457 compliant problem details for HCLI applications
Project description
hcli_problem_details
A Python library providing RFC 9457-compliant problem detail exceptions for HCLI applications and beyond.
This package delivers a complete set of HTTP problem detail exceptions adhering to RFC 9457 (Problem Details for HTTP APIs). Built as part of the HCLI ecosystem, it offers reusable exception classes for HTTP 4xx and 5xx status codes, simplifying standardized error handling in HCLI applications and other Python projects. Each exception can be transformed into an RFC 9457-compliant problem detail object for consistent API error responses.
Learn more about HCLI at hcli.io [1].
Help shape this library and the HCLI ecosystem by raising issues on GitHub!
[1] http://hcli.io
Installation
hcli_problem_details requires a supported version of Python and pip.
pip install hcli-problem-details
Usage
Import and raise exceptions in your Python application as needed. Each exception generates an RFC 9457-compliant problem detail representation.
from hcli_problem_details import NotFoundError, BadRequestError
# Raise a 404 Not Found error
raise NotFoundError(detail="Resource not found")
# Output: {"type": "about:blank", "title": "Not Found", "status": 404, "detail": "Resource not found"}
# Raise a 400 Bad Request error with custom extensions
raise BadRequestError(detail="Invalid input", extensions={"field": "username"})
# Output: {"type": "about:blank", "title": "Bad Request", "status": 400, "detail": "Invalid input", "field": "username"}
Integration with HCLI Core
HCLI Core utilizes this package to automatically recognize and relay its raised exceptions to HCLI clients (e.g., huckle) as problem details.
Available Errors
The following exception classes are available, each corresponding to an HTTP status code and RFC 9457 problem detail:
4xx Client Errors:
BadRequestError (400) - Bad Request
AuthenticationError (401) - Unauthorized
PaymentRequiredError (402) - Payment Required
AuthorizationError (403) - Forbidden
NotFoundError (404) - Not Found
MethodNotAllowedError (405) - Method Not Allowed
NotAcceptableError (406) - Not Acceptable
ProxyAuthenticationError (407) - Proxy Authentication Required
RequestTimeoutError (408) - Request Timeout
ConflictError (409) - Conflict
GoneError (410) - Gone
LengthRequiredError (411) - Length Required
PreconditionFailedError (412) - Precondition Failed
PayloadTooLargeError (413) - Payload Too Large
URITooLongError (414) - URI Too Long
UnsupportedMediaTypeError (415) - Unsupported Media Type
RangeNotSatisfiableError (416) - Range Not Satisfiable
ExpectationFailedError (417) - Expectation Failed
TeapotError (418) - I’m a teapot
MisdirectedRequestError (421) - Misdirected Request
UnprocessableEntityError (422) - Unprocessable Entity
LockedError (423) - Locked
FailedDependencyError (424) - Failed Dependency
TooEarlyError (425) - Too Early
UpgradeRequiredError (426) - Upgrade Required
PreconditionRequiredError (428) - Precondition Required
TooManyRequestsError (429) - Too Many Requests
RequestHeaderFieldsTooLargeError (431) - Request Header Fields Too Large
UnavailableForLegalReasonsError (451) - Unavailable For Legal Reasons
5xx Server Errors:
InternalServerError (500) - Internal Server Error
NotImplementedError (501) - Not Implemented
BadGatewayError (502) - Bad Gateway
ServiceUnavailableError (503) - Service Unavailable
GatewayTimeoutError (504) - Gateway Timeout
HTTPVersionNotSupportedError (505) - HTTP Version Not Supported
VariantAlsoNegotiatesError (506) - Variant Also Negotiates
InsufficientStorageError (507) - Insufficient Storage
LoopDetectedError (508) - Loop Detected
NotExtendedError (510) - Not Extended
NetworkAuthenticationRequiredError (511) - Network Authentication Required
All exceptions inherit from ProblemDetail and support optional detail, instance, and extensions parameters.
Versioning
This project follows semantic versioning (http://semver.org). Development releases may use “devx”, “prealphax”, “alphax”, “betax”, or “rcx” extensions (e.g., 0.1.0-prealpha1) on GitHub. Only full major.minor.patch releases are published to PyPI.
Supports
Full coverage of HTTP 4xx client errors and 5xx server errors as exception classes.
RFC 9457 problem detail structure with type, title, status, detail, instance, and extensible extensions.
Compatibility with HCLI Core and any Python project requiring standardized HTTP error handling.
To Do
Add automated tests for all exception classes.
Provide integration examples for common web frameworks (e.g., Flask, FastAPI, Falcon).
Document advanced usage of extensions for custom problem details.
Bugs
No known issues.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file hcli_problem_details-0.1.1.tar.gz.
File metadata
- Download URL: hcli_problem_details-0.1.1.tar.gz
- Upload date:
- Size: 6.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.11.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5a0922c41735e02c1915788823b0c5abf50b1d9cdd3e7b31e96c592fb9bed8c2
|
|
| MD5 |
7078524f60dff5bc6fab2c53d35fbb23
|
|
| BLAKE2b-256 |
4f5742fa3232b73bf45b0158e6e95fe1fa6fc1c7fca043707fba8bb85e7eab88
|
File details
Details for the file hcli_problem_details-0.1.1-py3-none-any.whl.
File metadata
- Download URL: hcli_problem_details-0.1.1-py3-none-any.whl
- Upload date:
- Size: 6.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.11.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6fb267b15428d520e3f55d61e0ad697cd79b47c5feb2516c0db1ac1e6442f5ec
|
|
| MD5 |
6cc0f88fd37608ceb21c662996015b17
|
|
| BLAKE2b-256 |
b3ad3856861696e819fbbed2caa954927c37808ee1f4ef2e088394a7e25b6f8b
|