avant 50
This commit is contained in:
@@ -15,7 +15,11 @@ def list_plantings(session: Session = Depends(get_session)):
|
||||
|
||||
@router.post("/plantings", response_model=Planting, status_code=status.HTTP_201_CREATED)
|
||||
def create_planting(data: PlantingCreate, session: Session = Depends(get_session)):
|
||||
p = Planting(**data.model_dump())
|
||||
d = data.model_dump()
|
||||
# Rétro-compatibilité : cell_id = première zone sélectionnée
|
||||
if d.get("cell_ids") and not d.get("cell_id"):
|
||||
d["cell_id"] = d["cell_ids"][0]
|
||||
p = Planting(**d)
|
||||
session.add(p)
|
||||
session.commit()
|
||||
session.refresh(p)
|
||||
@@ -35,7 +39,12 @@ def update_planting(id: int, data: PlantingCreate, session: Session = Depends(ge
|
||||
p = session.get(Planting, id)
|
||||
if not p:
|
||||
raise HTTPException(status_code=404, detail="Plantation introuvable")
|
||||
for k, v in data.model_dump(exclude_unset=True).items():
|
||||
d = data.model_dump(exclude_unset=True)
|
||||
# Rétro-compatibilité : cell_id = première zone sélectionnée
|
||||
if "cell_ids" in d:
|
||||
ids = d["cell_ids"] or []
|
||||
d["cell_id"] = ids[0] if ids else None
|
||||
for k, v in d.items():
|
||||
setattr(p, k, v)
|
||||
p.updated_at = datetime.now(timezone.utc)
|
||||
session.add(p)
|
||||
|
||||
Reference in New Issue
Block a user