uiprotect 7.6.1__tar.gz → 7.8.0__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of uiprotect might be problematic. Click here for more details.

Files changed (38) hide show
  1. {uiprotect-7.6.1 → uiprotect-7.8.0}/PKG-INFO +1 -1
  2. {uiprotect-7.6.1 → uiprotect-7.8.0}/pyproject.toml +1 -1
  3. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/cli/lights.py +9 -0
  4. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/data/devices.py +42 -0
  5. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/data/nvr.py +5 -0
  6. {uiprotect-7.6.1 → uiprotect-7.8.0}/LICENSE +0 -0
  7. {uiprotect-7.6.1 → uiprotect-7.8.0}/README.md +0 -0
  8. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/__init__.py +0 -0
  9. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/__main__.py +0 -0
  10. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/_compat.py +0 -0
  11. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/api.py +0 -0
  12. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/cli/__init__.py +0 -0
  13. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/cli/aiports.py +0 -0
  14. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/cli/backup.py +0 -0
  15. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/cli/base.py +0 -0
  16. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/cli/cameras.py +0 -0
  17. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/cli/chimes.py +0 -0
  18. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/cli/doorlocks.py +0 -0
  19. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/cli/events.py +0 -0
  20. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/cli/liveviews.py +0 -0
  21. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/cli/nvr.py +0 -0
  22. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/cli/sensors.py +0 -0
  23. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/cli/viewers.py +0 -0
  24. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/data/__init__.py +0 -0
  25. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/data/base.py +0 -0
  26. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/data/bootstrap.py +0 -0
  27. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/data/convert.py +0 -0
  28. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/data/types.py +0 -0
  29. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/data/user.py +0 -0
  30. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/data/websocket.py +0 -0
  31. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/exceptions.py +0 -0
  32. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/py.typed +0 -0
  33. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/release_cache.json +0 -0
  34. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/stream.py +0 -0
  35. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/test_util/__init__.py +0 -0
  36. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/test_util/anonymize.py +0 -0
  37. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/utils.py +0 -0
  38. {uiprotect-7.6.1 → uiprotect-7.8.0}/src/uiprotect/websocket.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: uiprotect
3
- Version: 7.6.1
3
+ Version: 7.8.0
4
4
  Summary: Python API for Unifi Protect (Unofficial)
5
5
  License: MIT
6
6
  Author: UI Protect Maintainers
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "uiprotect"
3
- version = "7.6.1"
3
+ version = "7.8.0"
4
4
  license = "MIT"
5
5
  description = "Python API for Unifi Protect (Unofficial)"
6
6
  authors = [{ name = "UI Protect Maintainers", email = "ui@koston.org" }]
@@ -117,3 +117,12 @@ def set_duration(
117
117
  obj: Light = ctx.obj.device
118
118
 
119
119
  base.run(ctx, obj.set_duration(timedelta(seconds=duration)))
120
+
121
+
122
+ @app.command()
123
+ def set_flood_light(ctx: typer.Context, enabled: bool) -> None:
124
+ """Sets flood light (force on) for light device."""
125
+ base.require_device_id(ctx)
126
+ obj: Light = ctx.obj.device
127
+
128
+ base.run(ctx, obj.set_flood_light(enabled))
@@ -160,6 +160,14 @@ class Light(ProtectMotionDeviceModel):
160
160
  self.camera_id = camera.id
161
161
  await self.save_device(data_before_changes, force_emit=True)
162
162
 
163
+ async def set_flood_light(self, enabled: bool) -> None:
164
+ """Sets the flood light (force on) for the light"""
165
+
166
+ def callback() -> None:
167
+ self.light_on_settings.is_led_force_on = enabled
168
+
169
+ await self.queue_update(callback)
170
+
163
171
  async def set_status_light(self, enabled: bool) -> None:
164
172
  """Sets the status indicator light for the light"""
165
173
 
@@ -1442,6 +1450,40 @@ class Camera(ProtectMotionDeviceModel):
1442
1450
  """Toggles vehicle smart detection. Requires camera to have smart detection"""
1443
1451
  return await self._set_object_detect(SmartDetectObjectType.VEHICLE, enabled)
1444
1452
 
1453
+ # endregion
1454
+ # region Face
1455
+
1456
+ @property
1457
+ def can_detect_face(self) -> bool:
1458
+ return SmartDetectObjectType.FACE in self.feature_flags.smart_detect_types
1459
+
1460
+ @property
1461
+ def is_face_detection_on(self) -> bool:
1462
+ """Is Face Detection available and enabled?"""
1463
+ return self._is_smart_enabled(SmartDetectObjectType.FACE)
1464
+
1465
+ @property
1466
+ def last_face_detect_event(self) -> Event | None:
1467
+ """Get the last face smart detection event."""
1468
+ return self.get_last_smart_detect_event(SmartDetectObjectType.FACE)
1469
+
1470
+ @property
1471
+ def last_face_detect(self) -> datetime | None:
1472
+ """Get the last face smart detection event."""
1473
+ return self.last_smart_detects.get(SmartDetectObjectType.FACE)
1474
+
1475
+ @property
1476
+ def is_face_currently_detected(self) -> bool:
1477
+ """Is face currently being detected"""
1478
+ return self._is_smart_detected(SmartDetectObjectType.FACE)
1479
+
1480
+ async def set_face_detection(self, enabled: bool) -> None:
1481
+ """Toggles face smart detection. Requires camera to have smart detection"""
1482
+ return await self._set_object_detect(
1483
+ SmartDetectObjectType.FACE,
1484
+ enabled,
1485
+ )
1486
+
1445
1487
  # endregion
1446
1488
  # region License Plate
1447
1489
 
@@ -1361,6 +1361,11 @@ class NVR(ProtectDeviceModel):
1361
1361
  """
1362
1362
  return self._is_smart_enabled(SmartDetectObjectType.VEHICLE)
1363
1363
 
1364
+ @property
1365
+ def is_global_face_detection_on(self) -> bool:
1366
+ """Is Face Detection available and enabled?"""
1367
+ return self._is_smart_enabled(SmartDetectObjectType.FACE)
1368
+
1364
1369
  @property
1365
1370
  def is_global_license_plate_detection_on(self) -> bool:
1366
1371
  """
File without changes
File without changes