panther 4.1.1__py3-none-any.whl → 4.1.2__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.
- panther/__init__.py +1 -1
- panther/_utils.py +1 -1
- panther/base_websocket.py +5 -2
- panther/cli/monitor_command.py +1 -1
- panther/cli/run_command.py +3 -1
- panther/db/connections.py +7 -1
- panther/db/models.py +1 -1
- panther/logging.py +2 -2
- {panther-4.1.1.dist-info → panther-4.1.2.dist-info}/METADATA +1 -1
- {panther-4.1.1.dist-info → panther-4.1.2.dist-info}/RECORD +14 -14
- {panther-4.1.1.dist-info → panther-4.1.2.dist-info}/LICENSE +0 -0
- {panther-4.1.1.dist-info → panther-4.1.2.dist-info}/WHEEL +0 -0
- {panther-4.1.1.dist-info → panther-4.1.2.dist-info}/entry_points.txt +0 -0
- {panther-4.1.1.dist-info → panther-4.1.2.dist-info}/top_level.txt +0 -0
panther/__init__.py
CHANGED
panther/_utils.py
CHANGED
@@ -82,7 +82,7 @@ def clean_traceback_message(exception: Exception) -> str:
|
|
82
82
|
tb = TracebackException(type(exception), exception, exception.__traceback__)
|
83
83
|
stack = tb.stack.copy()
|
84
84
|
for t in stack:
|
85
|
-
if t.filename.find('site-packages/panther') != -1:
|
85
|
+
if t.filename.find('site-packages/panther') != -1 or t.filename.find('site-packages\\panther') != -1:
|
86
86
|
tb.stack.remove(t)
|
87
87
|
_traceback = list(tb.format(chain=False))
|
88
88
|
return exception if len(_traceback) == 1 else f'{exception}\n' + ''.join(_traceback)
|
panther/base_websocket.py
CHANGED
@@ -52,8 +52,11 @@ class WebsocketConnections(Singleton):
|
|
52
52
|
queue = self.pubsub.subscribe()
|
53
53
|
logger.info("Subscribed to 'websocket_connections' queue")
|
54
54
|
while True:
|
55
|
-
|
56
|
-
|
55
|
+
try:
|
56
|
+
received_message = queue.get()
|
57
|
+
await self._handle_received_message(received_message=received_message)
|
58
|
+
except InterruptedError:
|
59
|
+
break
|
57
60
|
else:
|
58
61
|
# We have a redis connection, so use it for pubsub
|
59
62
|
self.pubsub = self.pubsub_connection.pubsub()
|
panther/cli/monitor_command.py
CHANGED
@@ -57,7 +57,7 @@ class Monitoring:
|
|
57
57
|
|
58
58
|
# Check log file
|
59
59
|
if not self.monitoring_log_file.exists():
|
60
|
-
return f'`{self.monitoring_log_file}` file not found. (Make sure `MONITORING` is `True` in `configs`'
|
60
|
+
return f'`{self.monitoring_log_file}` file not found. (Make sure `MONITORING` is `True` in `configs` and you have at least one record)'
|
61
61
|
|
62
62
|
# Initialize Deque
|
63
63
|
self.update_rows()
|
panther/cli/run_command.py
CHANGED
@@ -1,3 +1,4 @@
|
|
1
|
+
import contextlib
|
1
2
|
import os
|
2
3
|
|
3
4
|
import uvicorn
|
@@ -75,6 +76,7 @@ def run(args: list[str]) -> None:
|
|
75
76
|
command.update(_handle_commands(args))
|
76
77
|
command.update(args)
|
77
78
|
try:
|
78
|
-
|
79
|
+
with contextlib.suppress(KeyboardInterrupt):
|
80
|
+
uvicorn.run('main:app', **command)
|
79
81
|
except TypeError as e:
|
80
82
|
cli_error(e)
|
panther/db/connections.py
CHANGED
@@ -122,7 +122,13 @@ class RedisConnection(Singleton, _Redis):
|
|
122
122
|
def sync_ping(self):
|
123
123
|
from redis import Redis
|
124
124
|
|
125
|
-
Redis(host=self.host, port=self.port, **self.kwargs).ping()
|
125
|
+
Redis(host=self.host, port=self.port, socket_timeout=3, **self.kwargs).ping()
|
126
|
+
|
127
|
+
async def execute_command(self, *args, **options):
|
128
|
+
if self.is_connected:
|
129
|
+
return await super().execute_command(*args, **options)
|
130
|
+
msg = '`REDIS` is not found in `configs`'
|
131
|
+
raise ValueError(msg)
|
126
132
|
|
127
133
|
def create_connection_for_websocket(self) -> _Redis:
|
128
134
|
if not hasattr(self, 'websocket_connection'):
|
panther/db/models.py
CHANGED
@@ -58,7 +58,7 @@ class BaseUser(Model):
|
|
58
58
|
|
59
59
|
async def login(self) -> dict:
|
60
60
|
"""Return dict of access and refresh token"""
|
61
|
-
return config.AUTHENTICATION.login(self.id)
|
61
|
+
return config.AUTHENTICATION.login(str(self.id))
|
62
62
|
|
63
63
|
async def logout(self) -> dict:
|
64
64
|
return await config.AUTHENTICATION.logout(self._auth_token)
|
panther/logging.py
CHANGED
@@ -1,18 +1,18 @@
|
|
1
|
-
panther/__init__.py,sha256=
|
1
|
+
panther/__init__.py,sha256=jygFzW2zuio44KfIpTdDG3C8iAGBD_vxBn8GVGODSDk,110
|
2
2
|
panther/_load_configs.py,sha256=AVkoixkUFkBQiTmrLrwCmg0eiPW2U_Uw2EGNEGQRfnI,9281
|
3
|
-
panther/_utils.py,sha256=
|
3
|
+
panther/_utils.py,sha256=j0rwIxTf0rtcZAAD-1nGE-_bWpvinyKtnwt3uO0hMmY,4330
|
4
4
|
panther/app.py,sha256=vb4j8CKidFHD5HIfK1t96fr8URMYxkroW8dQH9SVj14,7385
|
5
5
|
panther/authentications.py,sha256=gf7BVyQ8vXKhiumJAtD0aAK7uIHWx_snbOKYAKrYuVw,5677
|
6
6
|
panther/background_tasks.py,sha256=HBYubDIiO_673cl_5fqCUP9zzimzRgRkDSkag9Msnbs,7656
|
7
7
|
panther/base_request.py,sha256=Fwwpm-9bjAZdpzSdakmSas5BD3gh1nrc6iGcBxwa_94,4001
|
8
|
-
panther/base_websocket.py,sha256=
|
8
|
+
panther/base_websocket.py,sha256=iJUIbrfnh3ZLXlmKxTswMw158eNvtBFi8RZ-aBBmc8w,10643
|
9
9
|
panther/caching.py,sha256=ltuJYdjNiAaKIs3jpO5EBpL8Y6CF1vAIQqh8J_Np10g,4098
|
10
10
|
panther/configs.py,sha256=EaLApT6nYcguBoNXBG_8n6DU6HTNxsulI2943j8UAkE,3174
|
11
11
|
panther/events.py,sha256=bxDqrfiNNBlvD03vEk2LDK4xbMzTMFVcgAjx2ein7mI,1158
|
12
12
|
panther/exceptions.py,sha256=7rHdJIES2__kqOStIqbHl3Uxask2lzKgLQlkZvvDwFA,1591
|
13
13
|
panther/file_handler.py,sha256=XnomEigCUYOaXjkH4kD1kzpUbL2i9lLnR5kerruF6BA,846
|
14
14
|
panther/generics.py,sha256=SIK1Wqpfb_jKKt4xJPbYIhMY0QhtbhOXS68dIW4Y0bU,6671
|
15
|
-
panther/logging.py,sha256=
|
15
|
+
panther/logging.py,sha256=k__vzvSrPpr1IsA4OLrBt1JHuRUBXr7ekPlBW0-9rbM,2209
|
16
16
|
panther/main.py,sha256=UbIxwaojvY_vH9nYfBpkulRBqVEj4Lbl81Er4XW_KCY,9334
|
17
17
|
panther/monitoring.py,sha256=y1F3c8FJlnmooM-m1nSyOTa9eWq0v1nHnmw9zz-4Kls,1314
|
18
18
|
panther/pagination.py,sha256=ANJrEF0q1nVAfD33I4nZfUUxFcETzJb01gIhbZX3HEw,1639
|
@@ -29,14 +29,14 @@ panther/websocket.py,sha256=5WLw--Oa-6kGYbeRvO79hjbd0ARFcTTF40-hO_bdjmQ,1206
|
|
29
29
|
panther/cli/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
30
30
|
panther/cli/create_command.py,sha256=cVhz0VQOvEbpufFsevH9T1rYZ8T_Wsa89cpTiIVKTC0,10294
|
31
31
|
panther/cli/main.py,sha256=pCqnOTazgMhTvFHTugutIsiFXueU5kx2VmGngwAl54Q,1679
|
32
|
-
panther/cli/monitor_command.py,sha256=
|
33
|
-
panther/cli/run_command.py,sha256=
|
32
|
+
panther/cli/monitor_command.py,sha256=7N1-4W0Lu7yl5maehJowe04WH4nxZ1DumGDRATh82SQ,3139
|
33
|
+
panther/cli/run_command.py,sha256=yWcDoWC-c4ph4M5EDj0jvR9xSjh-apG5r6-NpDdArUo,2195
|
34
34
|
panther/cli/template.py,sha256=rsyKOQ0l2v3kdwmLiZxt5ecIhDzmFprCCv0uVAv7eQI,5319
|
35
35
|
panther/cli/utils.py,sha256=Jd4YQ9H6lapVktl7ZmiORt30WVmKI85xcwsY-fMRq3c,5289
|
36
36
|
panther/db/__init__.py,sha256=w9lEL0vRqb18Qx_iUJipUR_fi5GQ5uVX0DWycx14x08,50
|
37
|
-
panther/db/connections.py,sha256=
|
37
|
+
panther/db/connections.py,sha256=rps48Ic2r3SV2HD3df1OU7C4Pv8j98PVXU1O_FqF9Ak,4210
|
38
38
|
panther/db/cursor.py,sha256=jJ6bhz_Zljt3-AoeVdi563e2q3MSDJPP33WVbQk-goE,1287
|
39
|
-
panther/db/models.py,sha256=
|
39
|
+
panther/db/models.py,sha256=4g6Jm2TBTViC2ttpENzuRJyvPbvXYzEqHIZLiWekRUk,2575
|
40
40
|
panther/db/utils.py,sha256=Uxh7UebkBv4thMCfooYW1pkuorFgocsbnBZJi-hHtdY,1582
|
41
41
|
panther/db/queries/__init__.py,sha256=uF4gvBjLBJ-Yl3WLqoZEVNtHCVhFRKW3_Vi44pJxDNI,45
|
42
42
|
panther/db/queries/base_queries.py,sha256=8HhdlsSW-lgz3-IrZYfOtHNC3TBWbCNErDR4XE718AY,3764
|
@@ -49,9 +49,9 @@ panther/panel/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
49
49
|
panther/panel/apis.py,sha256=COsbwKZyTgyHvHYbpDfusifAH9ojMS3z1KhZCt9M-Ms,2428
|
50
50
|
panther/panel/urls.py,sha256=JiV-H4dWE-m_bfaTTVxzOxTvJmOWhyLOvcbM7xU3Bn4,240
|
51
51
|
panther/panel/utils.py,sha256=0Rv79oR5IEqalqwpRKQHMn1p5duVY5mxMqDKiA5mWx4,437
|
52
|
-
panther-4.1.
|
53
|
-
panther-4.1.
|
54
|
-
panther-4.1.
|
55
|
-
panther-4.1.
|
56
|
-
panther-4.1.
|
57
|
-
panther-4.1.
|
52
|
+
panther-4.1.2.dist-info/LICENSE,sha256=2aF1hL2aC0zRPjzUkSxJUzZbn2_uLoOkn7DHjzZni-I,1524
|
53
|
+
panther-4.1.2.dist-info/METADATA,sha256=c0gW17fnBtGxqL-u4mM6gVckd4r3nrZRsbEKeh7MAOY,6376
|
54
|
+
panther-4.1.2.dist-info/WHEEL,sha256=GJ7t_kWBFywbagK5eo9IoUwLW6oyOeTKmQ-9iHFVNxQ,92
|
55
|
+
panther-4.1.2.dist-info/entry_points.txt,sha256=6GPxYFGuzVfNB4YpHFJvYex6iWah5_tLnirAHwj2Qsg,51
|
56
|
+
panther-4.1.2.dist-info/top_level.txt,sha256=VbBs02JGXTIoHMzsX-eLOk2MCbBZzQbLhWiYpI7xI2g,8
|
57
|
+
panther-4.1.2.dist-info/RECORD,,
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|