Critical fixes: - [C1] _reactivate_recurring_todos now uses flush + with_for_update instead of mid-request commit; get_todos commits the full transaction - [C2] recurrence_rule validated via Literal["daily","weekly","monthly"] in Pydantic schemas (rejects invalid values with 422) Warnings fixed: - [W3] Clear due_time when due_date is set to null in update endpoint Suggestions applied: - [S2] Wrap filteredTodos in useMemo for consistent memoization - [S6] Add aria-labels to edit/delete icon buttons Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
50 lines
1.4 KiB
Python
50 lines
1.4 KiB
Python
from pydantic import BaseModel, ConfigDict
|
|
from datetime import datetime, date, time
|
|
from typing import Optional, Literal
|
|
|
|
TodoPriority = Literal["none", "low", "medium", "high"]
|
|
RecurrenceRule = Literal["daily", "weekly", "monthly"]
|
|
|
|
|
|
class TodoCreate(BaseModel):
|
|
title: str
|
|
description: Optional[str] = None
|
|
priority: TodoPriority = "medium"
|
|
due_date: Optional[date] = None
|
|
due_time: Optional[time] = None
|
|
category: Optional[str] = None
|
|
recurrence_rule: Optional[RecurrenceRule] = None
|
|
project_id: Optional[int] = None
|
|
|
|
|
|
class TodoUpdate(BaseModel):
|
|
title: Optional[str] = None
|
|
description: Optional[str] = None
|
|
priority: Optional[TodoPriority] = None
|
|
due_date: Optional[date] = None
|
|
due_time: Optional[time] = None
|
|
completed: Optional[bool] = None
|
|
category: Optional[str] = None
|
|
recurrence_rule: Optional[RecurrenceRule] = None
|
|
project_id: Optional[int] = None
|
|
|
|
|
|
class TodoResponse(BaseModel):
|
|
id: int
|
|
title: str
|
|
description: Optional[str]
|
|
priority: str
|
|
due_date: Optional[date]
|
|
due_time: Optional[time]
|
|
completed: bool
|
|
completed_at: Optional[datetime]
|
|
category: Optional[str]
|
|
recurrence_rule: Optional[str]
|
|
reset_at: Optional[datetime]
|
|
next_due_date: Optional[date]
|
|
project_id: Optional[int]
|
|
created_at: datetime
|
|
updated_at: datetime
|
|
|
|
model_config = ConfigDict(from_attributes=True)
|