Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.
 
 
 
 

84 строки
2.5 KiB

  1. import json
  2. from typing import List, Dict, Any, Optional
  3. from fastapi.encoders import jsonable_encoder
  4. from schemas.reslevis import AlarmItem
  5. from .config import ALARM_JSON_PATH
  6. from .gateway import _LockedFile, _atomic_write, _norm_str, _index_by_id
  7. class AlarmJsonRepository:
  8. def __init__(self, json_path: str = ALARM_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 (
  31. "id",
  32. "status",
  33. "type",
  34. "gatewayName",
  35. "trackerName",
  36. "subjectName",
  37. "operatorName",
  38. "zoneName",
  39. "buildingName",
  40. )
  41. )
  42. ]
  43. return rows
  44. def add(self, item: AlarmItem) -> None:
  45. rows = self._read_all()
  46. obj = jsonable_encoder(item)
  47. obj_id = _norm_str(obj.get("id"))
  48. if any(_norm_str(r.get("id")) == obj_id for r in rows):
  49. raise ValueError(f"Alarm con id '{obj_id}' già presente")
  50. rows.append(obj)
  51. self._write_all(rows)
  52. def update(self, item: AlarmItem) -> None:
  53. rows = self._read_all()
  54. obj = jsonable_encoder(item)
  55. obj_id = _norm_str(obj.get("id"))
  56. idx = _index_by_id(rows, obj_id)
  57. if idx is None:
  58. raise ValueError(f"Alarm con id '{obj_id}' non trovato")
  59. rows[idx] = obj
  60. self._write_all(rows)
  61. def remove(self, alarm_id: str) -> None:
  62. rows = self._read_all()
  63. idx = _index_by_id(rows, alarm_id)
  64. if idx is None:
  65. raise ValueError(f"Alarm con id '{alarm_id}' non trovato")
  66. del rows[idx]
  67. self._write_all(rows)