Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

9 сделать читаемую доку в сваггере в юзердате #22

Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
40 changes: 27 additions & 13 deletions userdata_api/routes/category.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,13 @@
category = APIRouter(prefix="/category", tags=["Category"])


@category.post("", response_model=CategoryGet)
@category.post(
"",
response_model=CategoryGet,
description='Создать категорию пользовательских данных. Получить категорию можно будет со скоупами,'
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
' имена которых в category_inp.scopes.\n\n' # Используем символ перевода строки
'Ручка обновит документацию',
)
async def create_category(
request: Request,
category_inp: CategoryPost,
Expand All @@ -23,6 +29,7 @@ async def create_category(
"""
Создать категорию пользовательских данных. Получить категорию можно будет со скоупами, имена которых в category_inp.scopes
Ручка обновит документацию
\f
:param request: https://fastapi.tiangolo.com/advanced/using-request-directly/
:param category_inp: Принимаемая моделька
:param _: Аутентификация
Expand All @@ -34,10 +41,11 @@ async def create_category(
return CategoryGet.model_validate(category)


@category.get("/{id}", response_model=CategoryGet)
@category.get("/{id}", response_model=CategoryGet, description='Получить категорию')
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
async def get_category(id: int) -> CategoryGet:
"""
Получить категорию
\f
:param id: Айди категории
:param _: Аутентфикация
:return: Категорию со списком скоупов, которые нужны для получения пользовательских данных этой категории
Expand All @@ -46,29 +54,33 @@ async def get_category(id: int) -> CategoryGet:
return CategoryGet.model_validate(category)


@category.get("", response_model=list[CategoryGet], response_model_exclude_none=True)
@category.get(
"", response_model=list[CategoryGet], response_model_exclude_none=True, description='Получить все категории'
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
)
async def get_categories(query: list[Literal["param"]] = Query(default=[])) -> list[CategoryGet]:
result = []
for category in Category.query(session=db.session).all():
to_append = category.dict()
if "param" in query:
to_append["params"] = []
for param in category.params:
to_append["params"].append(param.dict())
result.append(to_append)
"""
Получить все категории
\f
:param query: Лист query параметров.
Если ничего не указано то вернет просто список категорий
Параметр 'param' - если указан, то в каждой категории будет список ее параметров
:param _: Аутентифиуация
:return: Список категорий. В каждой ноде списка - информация о скоупах, которые нужны для получения пользовательских данных этой категории
"""
result = []
for category in Category.query(session=db.session).all():
to_append = category.dict()
if "param" in query:
to_append["params"] = []
for param in category.params:
to_append["params"].append(param.dict())
result.append(to_append)

type_adapter = TypeAdapter(list[CategoryGet])
return type_adapter.validate_python(result)


@category.patch("/{id}", response_model=CategoryGet)
@category.patch("/{id}", response_model=CategoryGet, description='Обновить категорию')
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
async def patch_category(
request: Request,
id: int,
Expand All @@ -77,6 +89,7 @@ async def patch_category(
) -> CategoryGet:
"""
Обновить категорию
\f
:param request: https://fastapi.tiangolo.com/advanced/using-request-directly/
:param id: Айди обновляемой категории
:param category_inp: Моделька обновления
Expand All @@ -87,14 +100,15 @@ async def patch_category(
return CategoryGet.model_validate(Category.update(id, session=db.session, **category_inp.dict(exclude_unset=True)))


@category.delete("/{id}", response_model=StatusResponseModel)
@category.delete("/{id}", response_model=StatusResponseModel, description='Удалить категорию')
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
async def delete_category(
request: Request,
id: int,
_: dict[str, str] = Depends(UnionAuth(scopes=["userdata.category.delete"], allow_none=False, auto_error=True)),
) -> StatusResponseModel:
"""
Удалить категорию
\f
:param request: https://fastapi.tiangolo.com/advanced/using-request-directly/
:param id: Айди удаляемой категории
:param _: Аутентификация
Expand Down
21 changes: 16 additions & 5 deletions userdata_api/routes/param.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,13 @@
param = APIRouter(prefix="/category/{category_id}/param", tags=["Param"])


@param.post("", response_model=ParamGet)
@param.post(
"",
response_model=ParamGet,
description='Создать поле внутри категории. '
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
'Ответ на пользовательские данные будет такой {..., category: {...,param: '
', ...}}',
)
async def create_param(
request: Request,
category_id: int,
Expand All @@ -23,6 +29,7 @@ async def create_param(
) -> ParamGet:
"""
Создать поле внутри категории. Ответ на пользовательские данные будет такой {..., category: {...,param: '', ...}}
\f
:param request: https://fastapi.tiangolo.com/advanced/using-request-directly/
:param category_id: Айди котегории в которой создавать параметр
:param param_inp: Модель для создания
Expand All @@ -35,10 +42,11 @@ async def create_param(
return ParamGet.model_validate(Param.create(session=db.session, **param_inp.dict(), category_id=category_id))


@param.get("/{id}", response_model=ParamGet)
@param.get("/{id}", response_model=ParamGet, description='Получить параметр по айди')
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
async def get_param(id: int, category_id: int) -> ParamGet:
"""
Получить параметр по айди
\f
:param id: Айди параметра
:param category_id: айди категории в которой этот параметр находиится
:return: ParamGet - полученный параметр
Expand All @@ -49,18 +57,19 @@ async def get_param(id: int, category_id: int) -> ParamGet:
return ParamGet.model_validate(res)


@param.get("", response_model=list[ParamGet])
@param.get("", response_model=list[ParamGet], description='Получить все параметры категории')
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
async def get_params(category_id: int) -> list[ParamGet]:
"""
Получить все параметры категории
\f
:param category_id: Айди категории
:return: list[ParamGet] - список полученных параметров
"""
type_adapter = TypeAdapter(list[ParamGet])
return type_adapter.validate_python(Param.query(session=db.session).filter(Param.category_id == category_id).all())


@param.patch("/{id}", response_model=ParamGet)
@param.patch("/{id}", response_model=ParamGet, description='Обновить параметр внутри категории')
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
async def patch_param(
request: Request,
id: int,
Expand All @@ -70,6 +79,7 @@ async def patch_param(
) -> ParamGet:
"""
Обновить параметр внутри категории
\f
:param request: https://fastapi.tiangolo.com/advanced/using-request-directly/
:param id: Айди обновляемого параметра
:param category_id: Адйи категории в которой находится параметр
Expand All @@ -86,7 +96,7 @@ async def patch_param(
return ParamGet.model_validate(Param.update(id, session=db.session, **param_inp.dict(exclude_unset=True)))


@param.delete("/{id}", response_model=StatusResponseModel)
@param.delete("/{id}", response_model=StatusResponseModel, description='Удалить параметр внутри категории')
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
async def delete_param(
request: Request,
id: int,
Expand All @@ -95,6 +105,7 @@ async def delete_param(
) -> StatusResponseModel:
"""
Удалить параметр внутри категории
\f
:param request: https://fastapi.tiangolo.com/advanced/using-request-directly/
:param id: Айди удаляемого параметра
:param category_id: Айди категории в которой находится удлаляемый параметр
Expand Down
15 changes: 10 additions & 5 deletions userdata_api/routes/source.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,15 @@
source = APIRouter(prefix="/source", tags=["Source"])


@source.post("", response_model=SourceGet)
@source.post("", response_model=SourceGet, description="Создать источник данных")
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
async def create_source(
request: Request,
source_inp: SourcePost,
_: dict[str, Any] = Depends(UnionAuth(scopes=["userdata.source.create"], allow_none=False, auto_error=True)),
) -> SourceGet:
"""
Создать источник данных
\f
:param request: https://fastapi.tiangolo.com/advanced/using-request-directly/
:param source_inp: Моделька для создания
:param _: Аутентификация
Expand All @@ -33,27 +34,29 @@ async def create_source(
return SourceGet.model_validate(Source.create(session=db.session, **source_inp.dict()))


@source.get("/{id}", response_model=SourceGet)
@source.get("/{id}", response_model=SourceGet, description="Получить источник данных")
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
async def get_source(id: int) -> SourceGet:
"""
Получить источник данных
\f
:param id: Айди источника
:return: SourceGet - полученный источник
"""
return SourceGet.model_validate(Source.get(id, session=db.session))


@source.get("", response_model=list[SourceGet])
@source.get("", response_model=list[SourceGet], description='Получить все источники данных')
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
async def get_sources() -> list[SourceGet]:
"""
Получить все источники данных
\f
:return: list[SourceGet] - список источников данных
"""
type_adapter = TypeAdapter(list[SourceGet])
return type_adapter.validate_python(Source.query(session=db.session).all())


@source.patch("/{id}", response_model=SourceGet)
@source.patch("/{id}", response_model=SourceGet, description='Обновить источник данных')
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
async def patch_source(
request: Request,
id: int,
Expand All @@ -62,6 +65,7 @@ async def patch_source(
) -> SourceGet:
"""
Обновить источник данных
\f
:param request: https://fastapi.tiangolo.com/advanced/using-request-directly/
:param id: Айди обновляемого источника
:param source_inp: Моделька для обновления
Expand All @@ -71,14 +75,15 @@ async def patch_source(
return SourceGet.model_validate(Source.update(id, session=db.session, **source_inp.dict(exclude_unset=True)))


@source.delete("/{id}", response_model=StatusResponseModel)
@source.delete("/{id}", response_model=StatusResponseModel, description='Удалить источник данных')
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
async def delete_source(
request: Request,
id: int,
_: dict[str, Any] = Depends(UnionAuth(scopes=["userdata.source.delete"], allow_none=False, auto_error=True)),
) -> StatusResponseModel:
"""
Удалить источник данных
\f
:param request: https://fastapi.tiangolo.com/advanced/using-request-directly/
:param id: Айди удаляемого источника
:param _: Аутентфиикация
Expand Down
8 changes: 4 additions & 4 deletions userdata_api/routes/user.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,12 +12,13 @@
user = APIRouter(prefix="/user", tags=["User"])


@user.get("/{id}", response_model=UserInfoGet)
@user.get("/{id}", response_model=UserInfoGet, description='Получить информацию о пользователе')
Temmmmmo marked this conversation as resolved.
Show resolved Hide resolved
async def get_user_info(
id: int, user: dict[str, Any] = Depends(UnionAuth(scopes=[], allow_none=False, auto_error=True))
) -> UserInfoGet:
"""
Получить информацию о польщователе
Получить информацию о пользователе
\f
:param id: Айди овнера информации(пользователя)
:param user: Аутентфикация
:return: Словарь, ключи - категории на которые хватило прав(овнеру не нужны права, он получает всё).
Expand Down Expand Up @@ -54,8 +55,7 @@ async def update_user(
Для обновления своей информации(источник `user`) не нужны скоупы на обновление соответствующих категорий
Для обновления чужой информации от имени админа(источник `admin`)
нужны скоупы на обновление всех указанных в теле запроса категорий пользовательских данных данных


\f
:param request: Запрос из fastapi
:param user_id: Айди объекта обновленя
:param _: Модель запроса
Expand Down