avant 50
This commit is contained in:
@@ -115,6 +115,19 @@ def create_cell(id: int, cell: GardenCell, session: Session = Depends(get_sessio
|
||||
return cell
|
||||
|
||||
|
||||
@router.put("/gardens/{id}/cells/{cell_id}", response_model=GardenCell)
|
||||
def update_cell(id: int, cell_id: int, data: GardenCell, session: Session = Depends(get_session)):
|
||||
c = session.get(GardenCell, cell_id)
|
||||
if not c or c.garden_id != id:
|
||||
raise HTTPException(status_code=404, detail="Case introuvable")
|
||||
for k, v in data.model_dump(exclude_unset=True, exclude={"id", "garden_id"}).items():
|
||||
setattr(c, k, v)
|
||||
session.add(c)
|
||||
session.commit()
|
||||
session.refresh(c)
|
||||
return c
|
||||
|
||||
|
||||
@router.get("/gardens/{id}/measurements", response_model=List[Measurement])
|
||||
def list_measurements(id: int, session: Session = Depends(get_session)):
|
||||
return session.exec(select(Measurement).where(Measurement.garden_id == id)).all()
|
||||
|
||||
@@ -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