add patch endpoint and service update_task
This commit is contained in:
@@ -1,11 +1,11 @@
|
||||
from typing import Annotated
|
||||
|
||||
from fastapi import APIRouter, Depends
|
||||
from fastapi import APIRouter, Body, Depends
|
||||
|
||||
from src.api.dependacies.db_dep import sessionDep
|
||||
from src.api.dependacies.task_dep import TaskFilterDep
|
||||
from src.api.dependacies.user_dep import ActiveUser, TaskOwnerDep
|
||||
from src.schemas.tasks import TaskADDRequest
|
||||
from src.schemas.tasks import TaskADDRequest, TaskPATCHRequest
|
||||
from src.services.tasks import TaskService
|
||||
from src.services.users import UserService
|
||||
|
||||
@@ -13,14 +13,9 @@ router = APIRouter(prefix="/tasks", tags=["Tasks"])
|
||||
|
||||
|
||||
@router.get("/")
|
||||
async def get_tasks(
|
||||
session: sessionDep,
|
||||
user: ActiveUser,
|
||||
filter: TaskFilterDep
|
||||
):
|
||||
async def get_tasks(session: sessionDep, user: ActiveUser, filter: TaskFilterDep):
|
||||
result = await UserService(session).get_user_with_tasks(
|
||||
user_id=user.id,
|
||||
**filter.model_dump(exclude_unset=True)
|
||||
user_id=user.id, **filter.model_dump(exclude_unset=True)
|
||||
)
|
||||
return result
|
||||
|
||||
@@ -43,6 +38,17 @@ async def post_task(
|
||||
return result
|
||||
|
||||
|
||||
@router.patch("/{id}")
|
||||
async def patch_task(
|
||||
session: sessionDep,
|
||||
id: int,
|
||||
_: TaskOwnerDep,
|
||||
task_data: TaskPATCHRequest = Body(),
|
||||
):
|
||||
task = await TaskService(session).update_task(id, task_data)
|
||||
return task
|
||||
|
||||
|
||||
@router.delete("/{id}")
|
||||
async def delete_task(
|
||||
session: sessionDep,
|
||||
|
||||
@@ -50,7 +50,11 @@ class UsersRepo(BaseRepo):
|
||||
selectinload(
|
||||
self.model.tasks.and_(TasksORM.id.in_(tasks_subquery))
|
||||
).load_only(
|
||||
TasksORM.id, TasksORM.title, TasksORM.due_date, TasksORM.priority, TasksORM.status
|
||||
TasksORM.id,
|
||||
TasksORM.title,
|
||||
TasksORM.due_date,
|
||||
TasksORM.priority,
|
||||
TasksORM.status,
|
||||
)
|
||||
)
|
||||
)
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
from fastapi import HTTPException
|
||||
|
||||
from src.models.tasks import TasksORM
|
||||
from src.schemas.tasks import Task, TaskADDRequest
|
||||
from src.schemas.tasks import Task, TaskADDRequest, TaskPATCHRequest
|
||||
from src.services.base import BaseService
|
||||
|
||||
|
||||
@@ -27,3 +27,8 @@ class TaskService(BaseService):
|
||||
async def delete_task(self, task_id: int):
|
||||
await self.session.task.delete_one(id=task_id)
|
||||
await self.session.commit()
|
||||
|
||||
async def update_task(self, task_id: int, task_data: TaskPATCHRequest, exclude_unset: bool = True):
|
||||
task = await self.session.task.update_one(id=task_id, data=task_data.model_dump(exclude_unset=exclude_unset))
|
||||
await self.session.commit()
|
||||
return Task.model_validate(task)
|
||||
|
||||
@@ -49,7 +49,6 @@ class UserService(BaseService):
|
||||
offset: int | None,
|
||||
date_to: date | None,
|
||||
date_from: date | None,
|
||||
|
||||
):
|
||||
user = await self.session.user.get_one_with_load(
|
||||
user_id=user_id,
|
||||
|
||||
Reference in New Issue
Block a user