mirror of
https://github.com/fastapi/fastapi.git
synced 2026-01-17 18:39:04 -05:00
* 🌐 Refactor file structure to support internationalization * ✅ Update tests changed after i18n * 🔀 Merge Typer style from master * 🔧 Update MkConfig with Typer-styles * 🎨 Format mkdocs.yml with cannonical form * 🎨 Format mkdocs.yml * 🔧 Update MkDocs config * ➕ Add docs translation scripts dependencies * ✨ Add Typer scripts to handle translations * ✨ Add missing translation snippet to include * ✨ Update contributing docs, add docs for translations * 🙈 Add docs_build to gitignore * 🔧 Update scripts with new locations and docs scripts * 👷 Update docs deploy action with translations * 📝 Add note about languages not supported in the theme * ✨ Add first translation, for Spanish
34 lines
708 B
Python
34 lines
708 B
Python
from typing import Set
|
|
|
|
from fastapi import FastAPI
|
|
from pydantic import BaseModel
|
|
|
|
app = FastAPI()
|
|
|
|
|
|
class Item(BaseModel):
|
|
name: str
|
|
description: str = None
|
|
price: float
|
|
tax: float = None
|
|
tags: Set[str] = []
|
|
|
|
|
|
@app.post(
|
|
"/items/",
|
|
response_model=Item,
|
|
summary="Create an item",
|
|
response_description="The created 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
|
|
"""
|
|
return item
|