|
1 | | -from .enum import StatusEnum |
2 | | -from .base import BaseModel |
3 | | -from typing import Optional |
| 1 | +from datetime import datetime |
4 | 2 | from uuid import UUID, uuid4 |
| 3 | + |
5 | 4 | from sqlalchemy import DateTime |
6 | | -from datetime import datetime |
7 | | -from sqlmodel import SQLModel, Field |
| 5 | +from sqlmodel import Field, SQLModel |
| 6 | + |
| 7 | +from .base import BaseModel |
| 8 | +from .enum import StatusEnum |
8 | 9 |
|
9 | 10 |
|
10 | 11 | class JobsBase(SQLModel): |
11 | 12 | """Shared fields between table and API models""" |
12 | 13 |
|
13 | | - route_group_id: Optional[UUID] = Field(foreign_key="route_groups.id") |
| 14 | + route_group_id: UUID | None = Field(foreign_key="route_groups.id") |
14 | 15 | status: StatusEnum = Field(default=StatusEnum.PENDING) |
15 | 16 | progress: str = Field(default=None) |
16 | 17 |
|
17 | 18 |
|
18 | 19 | class Jobs(JobsBase, BaseModel, table=True): |
| 20 | + """Jobs model for demonstration purposes""" |
| 21 | + |
19 | 22 | __tablename__ = "jobs" |
20 | 23 |
|
21 | 24 | id: UUID = Field(default=uuid4, primary_key=True) |
22 | | - started_at: Optional[datetime] = Field( |
| 25 | + started_at: datetime | None = Field( |
23 | 26 | default_factory=datetime.utcnow, |
24 | 27 | sa_type=DateTime(timezone=True), |
25 | 28 | description="Timestamp when the record was created", |
26 | 29 | ) |
27 | | - finished_at: Optional[datetime] = Field( |
| 30 | + updated_at: datetime | None = Field( |
| 31 | + default=None, |
| 32 | + sa_type=DateTime(timezone=True), |
| 33 | + description="Timestamp when the record was updated", |
| 34 | + ) |
| 35 | + finished_at: datetime | None = Field( |
28 | 36 | default=None, |
29 | 37 | sa_type=DateTime(timezone=True), |
30 | 38 | description="Timestamp when the record is finished", |
31 | 39 | ) |
32 | 40 |
|
33 | 41 |
|
34 | 42 | class JobsCreate(JobsBase): |
| 43 | + """Jobs creation request""" |
| 44 | + |
35 | 45 | pass |
36 | 46 |
|
37 | 47 |
|
38 | 48 | class JobsRead(JobsBase): |
| 49 | + """Jobs response model""" |
| 50 | + |
39 | 51 | id: UUID |
40 | | - started_at: Optional[datetime] = None |
41 | | - finished_at: Optional[datetime] = None |
| 52 | + started_at: datetime | None = None |
| 53 | + finished_at: datetime | None = None |
42 | 54 | created_at: datetime |
43 | 55 | updated_at: datetime |
44 | 56 |
|
45 | 57 |
|
46 | 58 | class JobsUpdate(SQLModel): |
47 | | - status: Optional[StatusEnum] = None |
48 | | - progress: Optional[str] = None |
49 | | - route_group_id: Optional[UUID] = None |
50 | | - started_at: Optional[datetime] = None |
51 | | - finished_at: Optional[datetime] = None |
| 59 | + """Jobs update request - all optional""" |
| 60 | + |
| 61 | + status: StatusEnum | None = None |
| 62 | + progress: str | None = None |
| 63 | + route_group_id: UUID | None = None |
| 64 | + started_at: datetime | None = None |
| 65 | + finished_at: datetime | None = None |
0 commit comments