-
Notifications
You must be signed in to change notification settings - Fork 0
/
source.py
99 lines (82 loc) · 3.56 KB
/
source.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
from typing import Any
from auth_lib.fastapi import UnionAuth
from fastapi import APIRouter, Depends, Request
from fastapi_sqlalchemy import db
from pydantic.type_adapter import TypeAdapter
from userdata_api.exceptions import AlreadyExists
from userdata_api.models.db import Source
from userdata_api.schemas.response_model import StatusResponseModel
from userdata_api.schemas.source import SourceGet, SourcePatch, SourcePost
source = APIRouter(prefix="/source", tags=["Source"])
@source.post("", response_model=SourceGet)
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:
"""
Создать источник данных
Scopes: `["userdata.source.create"]`
\f
:param request: https://fastapi.tiangolo.com/advanced/using-request-directly/
:param source_inp: Моделька для создания
:param _: Аутентификация
:return: SourceGet - созданный источник
"""
source = Source.query(session=db.session).filter(Source.name == source_inp.name).all()
if source:
raise AlreadyExists(Source, source_inp.name)
return SourceGet.model_validate(Source.create(session=db.session, **source_inp.dict()))
@source.get("/{id}", response_model=SourceGet)
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])
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)
async def patch_source(
request: Request,
id: int,
source_inp: SourcePatch,
_: dict[str, Any] = Depends(UnionAuth(scopes=["userdata.source.update"], allow_none=False, auto_error=True)),
) -> SourceGet:
"""
Обновить источник данных
Scopes: `["userdata.source.update"]`
\f
:param request: https://fastapi.tiangolo.com/advanced/using-request-directly/
:param id: Айди обновляемого источника
:param source_inp: Моделька для обновления
:param _: Аутентификация
:return: SourceGet - обновленный источник данных
"""
return SourceGet.model_validate(Source.update(id, session=db.session, **source_inp.dict(exclude_unset=True)))
@source.delete("/{id}", response_model=StatusResponseModel)
async def delete_source(
request: Request,
id: int,
_: dict[str, Any] = Depends(UnionAuth(scopes=["userdata.source.delete"], allow_none=False, auto_error=True)),
) -> StatusResponseModel:
"""
Удалить источник данных
Scopes: `["userdata.source.delete"]`
\f
:param request: https://fastapi.tiangolo.com/advanced/using-request-directly/
:param id: Айди удаляемого источника
:param _: Аутентфиикация
:return: None
"""
Source.delete(id, session=db.session)
return StatusResponseModel(status="Success", message="Source deleted", ru="Источник удален")