pypetkitapi 1.12.5__py3-none-any.whl → 1.12.6__py3-none-any.whl
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.
- pypetkitapi/__init__.py +1 -1
- pypetkitapi/const.py +4 -2
- pypetkitapi/media.py +12 -7
- {pypetkitapi-1.12.5.dist-info → pypetkitapi-1.12.6.dist-info}/METADATA +1 -1
- {pypetkitapi-1.12.5.dist-info → pypetkitapi-1.12.6.dist-info}/RECORD +7 -7
- {pypetkitapi-1.12.5.dist-info → pypetkitapi-1.12.6.dist-info}/LICENSE +0 -0
- {pypetkitapi-1.12.5.dist-info → pypetkitapi-1.12.6.dist-info}/WHEEL +0 -0
pypetkitapi/__init__.py
CHANGED
pypetkitapi/const.py
CHANGED
@@ -28,7 +28,9 @@ T3 = "t3"
|
|
28
28
|
T4 = "t4"
|
29
29
|
T5 = "t5"
|
30
30
|
T6 = "t6"
|
31
|
+
W4 = "w4"
|
31
32
|
W5 = "w5"
|
33
|
+
CTW2 = "ctw2"
|
32
34
|
CTW3 = "ctw3"
|
33
35
|
K2 = "k2"
|
34
36
|
K3 = "k3"
|
@@ -42,7 +44,7 @@ LITTER_NO_CAMERA = [T3, T4]
|
|
42
44
|
FEEDER_WITH_CAMERA = [D4H, D4SH]
|
43
45
|
DEVICES_FEEDER = [FEEDER, FEEDER_MINI, D3, D4, D4S, D4H, D4SH]
|
44
46
|
# Water Fountain
|
45
|
-
DEVICES_WATER_FOUNTAIN = [W5, CTW3]
|
47
|
+
DEVICES_WATER_FOUNTAIN = [W4, W5, CTW2, CTW3]
|
46
48
|
# Purifier
|
47
49
|
DEVICES_PURIFIER = [K2]
|
48
50
|
# All devices
|
@@ -76,7 +78,7 @@ class Header(StrEnum):
|
|
76
78
|
ACCEPT = "*/*"
|
77
79
|
ACCEPT_LANG = "en-US;q=1, it-US;q=0.9"
|
78
80
|
ENCODING = "gzip, deflate"
|
79
|
-
API_VERSION = "
|
81
|
+
API_VERSION = "12.0.2"
|
80
82
|
CONTENT_TYPE = "application/x-www-form-urlencoded"
|
81
83
|
AGENT = "okhttp/3.12.11"
|
82
84
|
CLIENT = f"{Client.PLATFORM_TYPE}({Client.OS_VERSION};{Client.MODEL_NAME})"
|
pypetkitapi/media.py
CHANGED
@@ -24,6 +24,7 @@ from pypetkitapi.const import (
|
|
24
24
|
FEEDER_WITH_CAMERA,
|
25
25
|
LITTER_WITH_CAMERA,
|
26
26
|
MediaType,
|
27
|
+
PetkitEndpoint,
|
27
28
|
RecordTypeLST,
|
28
29
|
)
|
29
30
|
from pypetkitapi.litter_container import LitterRecord
|
@@ -353,7 +354,7 @@ class MediaManager:
|
|
353
354
|
user_id=user_id,
|
354
355
|
image=item.preview,
|
355
356
|
video=await self.construct_video_url(
|
356
|
-
device_type, item
|
357
|
+
device_type, item, user_id, cp_sub
|
357
358
|
),
|
358
359
|
filepath=filepath,
|
359
360
|
aes_key=item.aes_key,
|
@@ -407,7 +408,7 @@ class MediaManager:
|
|
407
408
|
user_id=user_id,
|
408
409
|
image=record.preview,
|
409
410
|
video=await self.construct_video_url(
|
410
|
-
device_type, record
|
411
|
+
device_type, record, user_id, cp_sub
|
411
412
|
),
|
412
413
|
filepath=filepath,
|
413
414
|
aes_key=record.aes_key,
|
@@ -442,22 +443,26 @@ class MediaManager:
|
|
442
443
|
@staticmethod
|
443
444
|
async def construct_video_url(
|
444
445
|
device_type: str | None,
|
445
|
-
|
446
|
+
event_data: LitterRecord | RecordsItems,
|
446
447
|
user_id: int,
|
447
448
|
cp_sub: bool | None,
|
448
449
|
) -> str | None:
|
449
450
|
"""Construct the video URL.
|
450
451
|
:param device_type: Device type
|
451
|
-
:param
|
452
|
+
:param event_data: LitterRecord | RecordsItems
|
452
453
|
:param user_id: User ID
|
453
454
|
:param cp_sub: Cpsub value
|
454
455
|
:return: Constructed video URL
|
455
456
|
"""
|
456
|
-
if not
|
457
|
+
if not hasattr(event_data, "media_api") or not user_id or not cp_sub:
|
457
458
|
return None
|
458
|
-
params = parse_qs(urlparse(
|
459
|
+
params = parse_qs(str(urlparse(event_data.media_api).query))
|
459
460
|
param_dict = {k: v[0] for k, v in params.items()}
|
460
|
-
|
461
|
+
url = f"/{device_type}/{PetkitEndpoint.CLOUD_VIDEO}?startTime={param_dict.get('startTime')}&deviceId={param_dict.get('deviceId')}&userId={user_id}&mark={param_dict.get('mark')}"
|
462
|
+
if hasattr(event_data, "eat_end_time"):
|
463
|
+
# Special case for Eat video (need to add endTime)
|
464
|
+
url += f"&endTime={event_data.eat_end_time}"
|
465
|
+
return url
|
461
466
|
|
462
467
|
@staticmethod
|
463
468
|
async def _get_timestamp(item) -> int | None:
|
@@ -1,19 +1,19 @@
|
|
1
|
-
pypetkitapi/__init__.py,sha256=
|
1
|
+
pypetkitapi/__init__.py,sha256=9aYDp2exciCKqaGEwL9K23dY3sH05gih03womG0NnII,2107
|
2
2
|
pypetkitapi/bluetooth.py,sha256=1zEZIrKNTttrZpqBiQ-6V37Uphft5_T8CH9OBfYjwxE,9915
|
3
3
|
pypetkitapi/client.py,sha256=62QzLypzCa6nEfR-Ihams6uQuYyKpu6yrFfnjfFu1Cc,30057
|
4
4
|
pypetkitapi/command.py,sha256=k04iC0ONiFx7pkr-LJI7qT3RprQ3ojT0jP6KWQk8eTQ,7514
|
5
|
-
pypetkitapi/const.py,sha256=
|
5
|
+
pypetkitapi/const.py,sha256=tDCbvDbJHKZEy6L5Api59O1NE3mi9X61YTYTBv_6E9E,4767
|
6
6
|
pypetkitapi/containers.py,sha256=QshQ3PaN858jy0nSjeIZyyLijK_AfpzrIZeq2SDoqXQ,4816
|
7
7
|
pypetkitapi/exceptions.py,sha256=4BXUyYXLfZjNxdnOGJPjyE9ASIl7JmQphjws87jvHtE,1631
|
8
8
|
pypetkitapi/feeder_container.py,sha256=PhidWd5WpsZqtdKZy60PzE67YXgQfApjm8CqvMCHK3U,14743
|
9
9
|
pypetkitapi/litter_container.py,sha256=VIQZyZwmsxgMsV80Bc1lnYMqJyTZSaiqwE4Y_CNTD9Q,19338
|
10
|
-
pypetkitapi/media.py,sha256=
|
10
|
+
pypetkitapi/media.py,sha256=LNY3khU5eZN4i1MGHxJaPHcf3LA1fFaPVkn-wdn0YLI,27168
|
11
11
|
pypetkitapi/purifier_container.py,sha256=ssyIxhNben5XJ4KlQTXTrtULg2ji6DqHqjzOq08d1-I,2491
|
12
12
|
pypetkitapi/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
13
13
|
pypetkitapi/schedule_container.py,sha256=ycIHeQHkVILDp7ZBjaVdGI_9rhHrgqeKBfvQAX3JMGE,2071
|
14
14
|
pypetkitapi/utils.py,sha256=z7325kcJQUburnF28HSXrJMvY_gY9007K73Zwxp-4DQ,743
|
15
15
|
pypetkitapi/water_fountain_container.py,sha256=5J0b-fDZYcFLNX2El7fifv8H6JMhBCt-ttxSow1ozRQ,6787
|
16
|
-
pypetkitapi-1.12.
|
17
|
-
pypetkitapi-1.12.
|
18
|
-
pypetkitapi-1.12.
|
19
|
-
pypetkitapi-1.12.
|
16
|
+
pypetkitapi-1.12.6.dist-info/LICENSE,sha256=u5jNkZEn6YMrtN4Kr5rU3TcBJ5-eAt0qMx4JDsbsnzM,1074
|
17
|
+
pypetkitapi-1.12.6.dist-info/METADATA,sha256=QaAgcHSi7rs1mRuz_LKb7zFPD3QHlqhnwd680OBC0bs,6946
|
18
|
+
pypetkitapi-1.12.6.dist-info/WHEEL,sha256=XbeZDeTWKc1w7CSIyre5aMDU_-PohRwTQceYnisIYYY,88
|
19
|
+
pypetkitapi-1.12.6.dist-info/RECORD,,
|
File without changes
|
File without changes
|