No puede seleccionar más de 25 temas Los temas deben comenzar con una letra o número, pueden incluir guiones ('-') y pueden tener hasta 35 caracteres de largo.
 
 
 
 

74 líneas
2.2 KiB

  1. import json
  2. from typing import List, Dict, Any, Optional
  3. from fastapi.encoders import jsonable_encoder
  4. from schemas.reslevis import FloorItem
  5. from .config import FLOOR_JSON_PATH
  6. from .gateway import _LockedFile, _atomic_write, _norm_str, _index_by_id
  7. class FloorJsonRepository:
  8. def __init__(self, json_path: str = FLOOR_JSON_PATH):
  9. self.path = json_path
  10. def _read_all(self) -> List[Dict[str, Any]]:
  11. with _LockedFile(self.path, "r") as fp:
  12. try:
  13. fp.seek(0)
  14. data = fp.read().strip()
  15. return json.loads(data) if data else []
  16. except json.JSONDecodeError:
  17. return []
  18. def _write_all(self, rows: List[Dict[str, Any]]) -> None:
  19. payload = json.dumps(rows, ensure_ascii=False, indent=2)
  20. _atomic_write(self.path, payload)
  21. def list(self, search_string: Optional[str] = None) -> List[Dict[str, Any]]:
  22. rows = self._read_all()
  23. if search_string:
  24. s = search_string.lower()
  25. rows = [
  26. r
  27. for r in rows
  28. if any(
  29. isinstance(r.get(k), str) and s in (r.get(k) or "").lower()
  30. for k in ("name", "image")
  31. )
  32. ]
  33. return rows
  34. def add(self, item: FloorItem) -> None:
  35. rows = self._read_all()
  36. obj = jsonable_encoder(item)
  37. obj_id = _norm_str(obj.get("id"))
  38. if any(_norm_str(r.get("id")) == obj_id for r in rows):
  39. raise ValueError(f"Floor con id '{obj_id}' già presente")
  40. rows.append(obj)
  41. self._write_all(rows)
  42. def update(self, item: FloorItem) -> None:
  43. rows = self._read_all()
  44. obj = jsonable_encoder(item)
  45. obj_id = _norm_str(obj.get("id"))
  46. idx = _index_by_id(rows, obj_id)
  47. if idx is None:
  48. raise ValueError(f"Floor con id '{obj_id}' non trovato")
  49. rows[idx] = obj
  50. self._write_all(rows)
  51. def remove(self, floor_id: str) -> None:
  52. rows = self._read_all()
  53. idx = _index_by_id(rows, floor_id)
  54. if idx is None:
  55. raise ValueError(f"Floor con id '{floor_id}' non trovato")
  56. del rows[idx]
  57. self._write_all(rows)