Skip to main content

FastAPI Custom Responses

Project description

FastAPI Custom Responses

Provides normalized response objects and error handling for FastAPI applications. All errors — validation, HTTP, and unhandled exceptions — are returned in a consistent { "success": false, "error": "..." } format with human-readable messages.

Installation

pip install fastapi-custom-responses

Quick Start

from http import HTTPStatus
from fastapi_custom_responses import EXCEPTION_HANDLERS, ErrorResponse, ErrorResponseModel, Response, SuccessResponse
from fastapi import APIRouter, FastAPI, Request

router = APIRouter()

app = FastAPI(
    title="API",
    description="My API",
    version="1.0.0",
    exception_handlers=EXCEPTION_HANDLERS,
)

class Data(Response):
    example: str

@router.get(
    "/",
    response_model=Response[Data],
    responses={
        400: {"model": ErrorResponseModel, "description": "Bad request"},
        500: {"model": ErrorResponseModel, "description": "Internal server error"},
    },
)
async def index(_: Request) -> Response[Data]:
    """Index route."""

    return Response(
        success=True,
        data=Data(example="hello"),
    )

@router.get("/return-error")
async def error_route(_: Request) -> Response:
    """Error route."""

    raise ErrorResponse(error="Your request is invalid.", status_code=HTTPStatus.BAD_REQUEST)

Note: When using OpenAPI generators, use SuccessResponse instead of Response if your endpoint has no data to return.

Error Normalization

Passing EXCEPTION_HANDLERS to your FastAPI app registers handlers that normalize all errors into a consistent JSON shape:

{
  "success": false,
  "error": "Human-readable error message"
}

Handled Exception Types

Exception Status Code Behavior
ErrorResponse Custom (default 400) Uses the provided error message directly
RequestValidationError 400 Pydantic validation errors are converted to human-readable messages (see below)
HTTPException From exception Uses the exception detail as the error message
ValueError 400 Uses str(exc) as the error message
Exception (catch-all) 500 Returns a generic "An unexpected error occurred" message

Raising Errors

Raise ErrorResponse with a message and status code:

from http import HTTPStatus
from fastapi_custom_responses import ErrorResponse

raise ErrorResponse(error="Resource not found", status_code=HTTPStatus.NOT_FOUND)

You can also create one from a status code alone, which maps to a default message:

raise ErrorResponse.from_status_code(HTTPStatus.FORBIDDEN)
# → { "success": false, "error": "You don't have permission to perform this action" }

Default messages for common status codes:

Status Code Default Message
401 "Authentication required"
403 "You don't have permission to perform this action"
404 "Resource not found"
400 "Invalid request"
500 "An unexpected error occurred"

Validation Error Normalization

When a request fails Pydantic validation, FastAPI normally returns a verbose JSON array of raw Pydantic errors. With EXCEPTION_HANDLERS, these are automatically converted into concise, human-readable messages.

Before (default FastAPI):

{
  "detail": [
    {
      "type": "missing",
      "loc": ["body", "email"],
      "msg": "Field required",
      "input": {}
    }
  ]
}

After (with EXCEPTION_HANDLERS):

{
  "success": false,
  "error": "Field 'email' is required"
}

When multiple fields fail validation, messages are joined with periods:

{
  "success": false,
  "error": "Field 'email' is required. Field 'age' must be a valid integer"
}

Supported Pydantic error types and their human-readable formats:

Error Type Example Message
missing Field 'name' is required
string_type Field 'name' must be a string
int_type / int_parsing Field 'age' must be a valid integer
float_type / float_parsing Field 'price' must be a valid number
bool_type / bool_parsing Field 'active' must be a boolean
enum Field 'status' must be one of: active, inactive
uuid_type / uuid_parsing Field 'id' must be a valid UUID
string_too_short Field 'name' must be at least 3 characters
string_too_long Field 'name' must be at most 50 characters
too_short / too_long Field 'items' must have at least 1 item
greater_than / less_than Field 'age' must be greater than 0
greater_than_equal / less_than_equal Field 'age' must be at least 18
value_error Field 'email': invalid email format
json_invalid Invalid JSON in request body

Any unrecognized error types fall back to the Pydantic error message prefixed with the field name.

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

fastapi_custom_responses-0.1.0.tar.gz (5.8 kB view details)

Uploaded Source

Built Distribution

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

fastapi_custom_responses-0.1.0-py3-none-any.whl (7.7 kB view details)

Uploaded Python 3

File details

Details for the file fastapi_custom_responses-0.1.0.tar.gz.

File metadata

File hashes

Hashes for fastapi_custom_responses-0.1.0.tar.gz
Algorithm Hash digest
SHA256 ba6194a69e7dba35c159cffe72f070fb83e65ad26d4a3c4416890e95b6d7d1ab
MD5 feb683df10d6fb1bbe214c65340250e4
BLAKE2b-256 ccf070cce31fc2cda1b53e6f4157ee49ac1acfbd34ed0ad65774f03744470e6b

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_custom_responses-0.1.0.tar.gz:

Publisher: publish-to-pypi.yml on julien777z/fastapi-custom-responses

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file fastapi_custom_responses-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for fastapi_custom_responses-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 78422256551f0be8413bc5980797ad1f99ed6a7037783c9f9f81d9345f92317b
MD5 174cd2a05802b2ac125d0f0aeb7c52ee
BLAKE2b-256 2ec58abca1b7301afe6978091e4a8c657c1615621650a2750344285a94b4c6bd

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_custom_responses-0.1.0-py3-none-any.whl:

Publisher: publish-to-pypi.yml on julien777z/fastapi-custom-responses

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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