Вы можете задать следующие поля, которые используются в спецификации OpenAPI и в UI автоматической документации API:
Параметр
Тип
Описание
title
str
Заголовок API.
description
str
Краткое описание API. Может быть использован Markdown.
version
string
Версия API. Версия вашего собственного приложения, а не OpenAPI. К примеру 2.5.0.
terms_of_service
str
Ссылка к условиям пользования API. Если указано, то это должен быть URL-адрес.
contact
dict
Контактная информация для открытого API. Может содержать несколько полей. поля contact
Параметр
Тип
Описание
name
str
Идентификационное имя контактного лица/организации.
url
str
URL указывающий на контактную информацию. ДОЛЖЕН быть в формате URL.
email
str
Email адрес контактного лица/организации. ДОЛЖЕН быть в формате email адреса.
license_info
dict
Информация о лицензии открытого API. Может содержать несколько полей. поля license_info
Параметр
Тип
Описание
name
str
ОБЯЗАТЕЛЬНО (если установлен параметр license_info). Название лицензии, используемой для API
url
str
URL, указывающий на лицензию, используемую для API. ДОЛЖЕН быть в формате URL.
Вы можете задать их следующим образом:
fromfastapiimportFastAPIdescription="""ChimichangApp API helps you do awesome stuff. 🚀## ItemsYou can **read items**.## UsersYou will be able to:* **Create users** (_not implemented_).* **Read users** (_not implemented_)."""app=FastAPI(title="ChimichangApp",description=description,summary="Deadpool's favorite app. Nuff said.",version="0.0.1",terms_of_service="http://example.com/terms/",contact={"name":"Deadpoolio the Amazing","url":"http://x-force.example.com/contact/","email":"dp@x-force.example.com",},license_info={"name":"Apache 2.0","url":"https://www.apache.org/licenses/LICENSE-2.0.html",},)@app.get("/items/")asyncdefread_items():return[{"name":"Katana"}]
Подсказка
Вы можете использовать Markdown в поле description, и оно будет отображено в выводе.
С этой конфигурацией автоматическая документация API будут выглядеть так:
Вы также можете добавить дополнительные метаданные для различных тегов, используемых для группировки ваших операций пути с помощью параметра openapi_tags.
Он принимает список, содержащий один словарь для каждого тега.
Каждый словарь может содержать в себе:
name (обязательно): str-значение с тем же именем тега, которое вы используете в параметре tags в ваших операциях пути и APIRouterах.
description: str-значение с кратким описанием для тега. Может содержать Markdown и будет отображаться в UI документации.
externalDocs: dict-значение описывающее внешнюю документацию. Включает в себя:
description: str-значение с кратким описанием для внешней документации.
url (обязательно): str-значение с URL-адресом для внешней документации.
Давайте попробуем сделать это на примере с тегами для users и items.
Создайте метаданные для ваших тегов и передайте их в параметре openapi_tags:
fromfastapiimportFastAPItags_metadata=[{"name":"users","description":"Operations with users. The **login** logic is also here.",},{"name":"items","description":"Manage items. So _fancy_ they have their own docs.","externalDocs":{"description":"Items external docs","url":"https://fastapi.tiangolo.com/",},},]app=FastAPI(openapi_tags=tags_metadata)@app.get("/users/",tags=["users"])asyncdefget_users():return[{"name":"Harry"},{"name":"Ron"}]@app.get("/items/",tags=["items"])asyncdefget_items():return[{"name":"wand"},{"name":"flying broom"}]
Помните, что вы можете использовать Markdown внутри описания, к примеру "login" будет отображен жирным шрифтом (login) и "fancy" будет отображаться курсивом (fancy).
Подсказка
Вам необязательно добавлять метаданные для всех используемых тегов
Используйте параметр tags с вашими операциями пути (и APIRouterами), чтобы присвоить им различные теги:
fromfastapiimportFastAPItags_metadata=[{"name":"users","description":"Operations with users. The **login** logic is also here.",},{"name":"items","description":"Manage items. So _fancy_ they have their own docs.","externalDocs":{"description":"Items external docs","url":"https://fastapi.tiangolo.com/",},},]app=FastAPI(openapi_tags=tags_metadata)@app.get("/users/",tags=["users"])asyncdefget_users():return[{"name":"Harry"},{"name":"Ron"}]@app.get("/items/",tags=["items"])asyncdefget_items():return[{"name":"wand"},{"name":"flying broom"}]
Порядок расположения словарей метаданных для каждого тега определяет также порядок, отображаемый в документах UI
К примеру, несмотря на то, что users будут идти после items в алфавитном порядке, они отображаются раньше, потому что мы добавляем свои метаданные в качестве первого словаря в списке.
Если вы хотите отключить схему OpenAPI полностью, вы можете задать openapi_url=None, это также отключит пользовательские интерфейсы документации, которые его использует.