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.
30 lines
717 B
30 lines
717 B
from typing import Set, Union
|
|
|
|
from fastapi import FastAPI
|
|
from pydantic import BaseModel
|
|
|
|
app = FastAPI()
|
|
|
|
|
|
class Item(BaseModel):
|
|
name: str
|
|
description: Union[str, None] = None
|
|
price: float
|
|
tax: Union[float, None] = None
|
|
tags: Set[str] = set()
|
|
|
|
|
|
@app.post("/items/", response_model=Item, summary="Create an item")
|
|
async def create_item(item: Item):
|
|
"""
|
|
Create an item with all the information:
|
|
|
|
- **name**: each item must have a name
|
|
- **description**: a long description
|
|
- **price**: required
|
|
- **tax**: if the item doesn't have tax, you can omit this
|
|
- **tags**: a set of unique tag strings for this item
|
|
\f
|
|
:param item: User input.
|
|
"""
|
|
return item
|
|
|