78 lines
3.5 KiB
Python
78 lines
3.5 KiB
Python
# /opt/docker/dev/service_finder/backend/app/schemas/asset_event.py
|
|
from pydantic import BaseModel, ConfigDict, Field, validator
|
|
from typing import Optional, Dict, Any, List
|
|
from uuid import UUID
|
|
from datetime import datetime
|
|
from enum import Enum
|
|
|
|
class AssetEventTypeEnum(str, Enum):
|
|
"""Digitális Szervizkönyv eseménytípusok."""
|
|
SERVICE = "SERVICE" # Szerviz
|
|
REPAIR = "REPAIR" # Javítás
|
|
ACCIDENT = "ACCIDENT" # Baleset
|
|
INSPECTION = "INSPECTION" # Műszaki vizsga
|
|
TIRE_CHANGE = "TIRE_CHANGE" # Gumi csere
|
|
MAINTENANCE = "MAINTENANCE" # Karbantartás
|
|
UPGRADE = "UPGRADE" # Fejlesztés
|
|
RECALL = "RECALL" # Visszahívás
|
|
OTHER = "OTHER" # Egyéb
|
|
|
|
class AssetEventCreate(BaseModel):
|
|
"""Digitális Szervizkönyv esemény létrehozásához szükséges adatok."""
|
|
event_type: AssetEventTypeEnum = Field(..., description="Esemény típusa")
|
|
odometer_reading: Optional[int] = Field(None, ge=0, description="Km óra állás az eseménykor")
|
|
description: str = Field(..., min_length=1, max_length=1000, description="Esemény leírása")
|
|
event_date: Optional[datetime] = Field(None, description="Esemény dátuma (alapértelmezett: most)")
|
|
cost_id: Optional[UUID] = Field(None, description="Kapcsolódó költség rekord ID (opcionális)")
|
|
|
|
# RBAC ellenőrzés: csak a tulajdonos vagy operátor szervezet adhat hozzá eseményt
|
|
# Ezt a service rétegben validáljuk, nem a sémában
|
|
|
|
model_config = ConfigDict(from_attributes=True)
|
|
|
|
class AssetEventResponse(BaseModel):
|
|
"""Digitális Szervizkönyv esemény teljes válaszmodellje."""
|
|
id: UUID
|
|
asset_id: UUID
|
|
user_id: Optional[int] = None
|
|
organization_id: Optional[int] = None
|
|
|
|
event_type: str
|
|
odometer_reading: Optional[int] = None
|
|
description: Optional[str] = None
|
|
cost_id: Optional[UUID] = None
|
|
|
|
event_date: datetime
|
|
created_at: datetime
|
|
updated_at: Optional[datetime] = None
|
|
|
|
# Kapcsolódó entitások (opcionális, csak ha eager loadoltuk)
|
|
user_name: Optional[str] = Field(None, description="Felhasználó neve")
|
|
organization_name: Optional[str] = Field(None, description="Szervezet neve")
|
|
|
|
model_config = ConfigDict(from_attributes=True)
|
|
|
|
class AssetEventUpdate(BaseModel):
|
|
"""Digitális Szervizkönyv esemény frissítéséhez szükséges adatok."""
|
|
event_type: Optional[AssetEventTypeEnum] = Field(None, description="Esemény típusa")
|
|
odometer_reading: Optional[int] = Field(None, ge=0, description="Km óra állás az eseménykor")
|
|
description: Optional[str] = Field(None, min_length=1, max_length=1000, description="Esemény leírása")
|
|
event_date: Optional[datetime] = Field(None, description="Esemény dátuma")
|
|
cost_id: Optional[UUID] = Field(None, description="Kapcsolódó költség rekord ID")
|
|
|
|
@validator('description')
|
|
def validate_description(cls, v):
|
|
if v is not None and len(v.strip()) == 0:
|
|
raise ValueError('Description cannot be empty or whitespace only')
|
|
return v
|
|
|
|
model_config = ConfigDict(from_attributes=True)
|
|
|
|
class AssetEventListResponse(BaseModel):
|
|
"""Digitális Szervizkönyv események listázásának válasza."""
|
|
items: List[AssetEventResponse] = Field(default_factory=list)
|
|
total: int = Field(0, description="Összes esemény száma")
|
|
page: int = Field(1, description="Aktuális oldal")
|
|
page_size: int = Field(20, description="Oldalméret")
|
|
|
|
model_config = ConfigDict(from_attributes=True) |