mirror of
https://github.com/fastapi/fastapi.git
synced 2026-06-09 16:15:03 -04:00
* ✨ Re-export main features used from Starlette to simplify developer's code * ♻️ Refactor Starlette exports * ♻️ Refactor tutorial examples to use re-exported utils from Starlette * 📝 Add examples for all middlewares * 📝 Add new docs for middlewares * 📝 Add examples for custom responses * 📝 Extend docs for custom responses * 📝 Update docs and add notes explaining re-exports from Starlette everywhere * 🍱 Update screenshot for HTTP status * 🔧 Update MkDocs config with new content * ♻️ Refactor tests to use re-exported utils from Starlette * ✨ Re-export WebSocketDisconnect from Starlette for tests * ✅ Add extra tests for extra re-exported middleware * ✅ Add tests for re-exported responses from Starlette * ✨ Add docs about mounting WSGI apps * ➕ Add Flask as a dependency to test WSGIMiddleware * ✅ Test WSGIMiddleware example
31 lines
662 B
Python
31 lines
662 B
Python
from fastapi import FastAPI
|
|
from fastapi.responses import FileResponse
|
|
from pydantic import BaseModel
|
|
|
|
|
|
class Item(BaseModel):
|
|
id: str
|
|
value: str
|
|
|
|
|
|
responses = {
|
|
404: {"description": "Item not found"},
|
|
302: {"description": "The item was moved"},
|
|
403: {"description": "Not enough privileges"},
|
|
}
|
|
|
|
|
|
app = FastAPI()
|
|
|
|
|
|
@app.get(
|
|
"/items/{item_id}",
|
|
response_model=Item,
|
|
responses={**responses, 200: {"content": {"image/png": {}}}},
|
|
)
|
|
async def read_item(item_id: str, img: bool = None):
|
|
if img:
|
|
return FileResponse("image.png", media_type="image/png")
|
|
else:
|
|
return {"id": "foo", "value": "there goes my hero"}
|