pythonasyncioapiasyncfastapiframeworkjsonjson-schemaopenapiopenapi3pydanticpython-typespython3redocreststarletteswaggerswagger-uiuvicornweb
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
51 lines
1.3 KiB
51 lines
1.3 KiB
from typing import Optional
|
|
|
|
from fastapi import Body, FastAPI
|
|
from pydantic import BaseModel
|
|
|
|
app = FastAPI()
|
|
|
|
|
|
class Item(BaseModel):
|
|
name: str
|
|
description: Optional[str] = None
|
|
price: float
|
|
tax: Optional[float] = None
|
|
|
|
|
|
@app.put("/items/{item_id}")
|
|
async def update_item(
|
|
*,
|
|
item_id: int,
|
|
item: Item = Body(
|
|
examples={
|
|
"normal": {
|
|
"summary": "A normal example",
|
|
"description": "A **normal** item works correctly.",
|
|
"value": {
|
|
"name": "Foo",
|
|
"description": "A very nice Item",
|
|
"price": 35.4,
|
|
"tax": 3.2,
|
|
},
|
|
},
|
|
"converted": {
|
|
"summary": "An example with converted data",
|
|
"description": "FastAPI can convert price `strings` to actual `numbers` automatically",
|
|
"value": {
|
|
"name": "Bar",
|
|
"price": "35.4",
|
|
},
|
|
},
|
|
"invalid": {
|
|
"summary": "Invalid data is rejected with an error",
|
|
"value": {
|
|
"name": "Baz",
|
|
"price": "thirty five point four",
|
|
},
|
|
},
|
|
},
|
|
),
|
|
):
|
|
results = {"item_id": item_id, "item": item}
|
|
return results
|
|
|