
- Implemented user authentication with JWT tokens - Created comprehensive task management with CRUD operations - Added category system for task organization - Set up SQLite database with SQLAlchemy ORM - Configured Alembic for database migrations - Added API documentation with OpenAPI/Swagger - Implemented proper authorization and user scoping - Created health check and root endpoints - Updated README with complete documentation
36 lines
951 B
Python
36 lines
951 B
Python
from typing import Optional
|
|
from pydantic import BaseModel
|
|
from datetime import datetime
|
|
from app.models.task import TaskStatus, TaskPriority
|
|
|
|
class TaskBase(BaseModel):
|
|
title: str
|
|
description: Optional[str] = None
|
|
status: TaskStatus = TaskStatus.PENDING
|
|
priority: TaskPriority = TaskPriority.MEDIUM
|
|
due_date: Optional[datetime] = None
|
|
category_id: Optional[int] = None
|
|
|
|
class TaskCreate(TaskBase):
|
|
pass
|
|
|
|
class TaskUpdate(BaseModel):
|
|
title: Optional[str] = None
|
|
description: Optional[str] = None
|
|
status: Optional[TaskStatus] = None
|
|
priority: Optional[TaskPriority] = None
|
|
due_date: Optional[datetime] = None
|
|
category_id: Optional[int] = None
|
|
|
|
class TaskInDBBase(TaskBase):
|
|
id: int
|
|
owner_id: int
|
|
completed_at: Optional[datetime] = None
|
|
created_at: datetime
|
|
updated_at: Optional[datetime] = None
|
|
|
|
class Config:
|
|
from_attributes = True
|
|
|
|
class Task(TaskInDBBase):
|
|
pass |