Compare commits
2 Commits
723f59d35e
...
a9997b1207
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
a9997b1207 | ||
|
|
9e5cde8e28 |
@@ -1,22 +1,19 @@
|
||||
from typing import Annotated
|
||||
|
||||
from fastapi import APIRouter, Depends
|
||||
from sqlalchemy import select
|
||||
|
||||
from src.api.dependacies.db_dep import sessionDep
|
||||
from src.api.dependacies.user_dep import ActiveUser
|
||||
from src.models.tasks import TasksORM
|
||||
from src.schemas.tasks import TaskADDRequest
|
||||
from src.services.tasks import TaskService
|
||||
from src.services.users import UserService
|
||||
|
||||
router = APIRouter(prefix="/tasks", tags=["Tasks"])
|
||||
|
||||
|
||||
@router.get("/")
|
||||
async def get_tasks(session: sessionDep, user: ActiveUser):
|
||||
query = select(TasksORM.id, TasksORM.description).where(TasksORM.user_id == user.id)
|
||||
tasks = await session.session.execute(query)
|
||||
result = tasks.scalars().all()
|
||||
result = await UserService(session).get_user_with_tasks(user.id)
|
||||
return result
|
||||
|
||||
|
||||
|
||||
@@ -1,6 +1,8 @@
|
||||
from sqlalchemy import update
|
||||
from sqlalchemy import select, update
|
||||
from sqlalchemy.orm import selectinload
|
||||
|
||||
from src.models import UsersORM
|
||||
from src.models.tasks import TasksORM
|
||||
from src.repository.base import BaseRepo
|
||||
|
||||
|
||||
@@ -17,3 +19,17 @@ class UsersRepo(BaseRepo):
|
||||
result = await self.session.execute(stmt)
|
||||
model = result.scalar_one()
|
||||
return model
|
||||
|
||||
async def get_one_with_load(self, user_id: int) -> UsersORM | None:
|
||||
quary = (
|
||||
select(self.model)
|
||||
.where(self.model.id == user_id)
|
||||
.options(
|
||||
selectinload(self.model.tasks).load_only(
|
||||
TasksORM.id, TasksORM.title, TasksORM.due_date
|
||||
)
|
||||
)
|
||||
)
|
||||
result = await self.session.execute(quary)
|
||||
obj = result.scalar_one_or_none()
|
||||
return obj
|
||||
|
||||
@@ -7,6 +7,6 @@ class Token(BaseModel):
|
||||
|
||||
|
||||
class TokenData(BaseModel):
|
||||
id: int | None = None
|
||||
sub: str | None = None
|
||||
id: int
|
||||
sub: str
|
||||
is_active: bool
|
||||
|
||||
@@ -38,3 +38,8 @@ class UserService(BaseService):
|
||||
)
|
||||
await self.session.commit()
|
||||
return User.model_validate(user)
|
||||
|
||||
async def get_user_with_tasks(self, user_id: int):
|
||||
user = await self.session.user.get_one_with_load(user_id)
|
||||
if user is None:
|
||||
raise HTTPException(status_code=404, detail="User not found.")
|
||||
|
||||
Reference in New Issue
Block a user