feat(backend): champs identified_* sur Media pour stocker l'identification

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-02-22 12:20:32 +01:00
parent 560fa63a45
commit 883299272f
2 changed files with 99 additions and 0 deletions

View File

@@ -0,0 +1,28 @@
from datetime import datetime, timezone
from typing import Optional
from sqlmodel import Field, SQLModel
class Media(SQLModel, table=True):
id: Optional[int] = Field(default=None, primary_key=True)
entity_type: str # jardin|plante|outil|plantation
entity_id: int
url: str
thumbnail_url: Optional[str] = None
titre: Optional[str] = None
# Identification automatique
identified_species: Optional[str] = None
identified_common: Optional[str] = None
identified_confidence: Optional[float] = None
identified_source: Optional[str] = None # "plantnet" | "yolo" | "cache"
created_at: datetime = Field(default_factory=lambda: datetime.now(timezone.utc))
class Attachment(SQLModel, table=True):
id: Optional[int] = Field(default=None, primary_key=True)
entity_type: str
entity_id: int
type: str # pdf|url|note
titre: Optional[str] = None
contenu: Optional[str] = None
created_at: datetime = Field(default_factory=lambda: datetime.now(timezone.utc))