mrok 0.4.3__py3-none-any.whl → 0.4.4__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.
mrok/proxy/app.py CHANGED
@@ -59,6 +59,6 @@ class ProxyApp(ForwardAppBase):
59
59
  headers: dict[str, str],
60
60
  ) -> tuple[StreamReader, StreamWriter] | tuple[None, None]:
61
61
  target_name = self.get_target_name(headers)
62
- sock = self._ziti_socket_cache.get_or_create(target_name)
62
+ sock = await self._ziti_socket_cache.get_or_create(target_name)
63
63
  reader, writer = await asyncio.open_connection(sock=sock)
64
64
  return reader, writer
mrok/proxy/ziti.py CHANGED
@@ -1,5 +1,6 @@
1
1
  import asyncio
2
2
  import contextlib
3
+ import logging
3
4
  from asyncio import Task
4
5
  from pathlib import Path
5
6
 
@@ -8,6 +9,8 @@ from aiocache import Cache
8
9
  from openziti.context import ZitiContext
9
10
  from openziti.zitisock import ZitiSocket
10
11
 
12
+ logger = logging.getLogger("mrok.proxy")
13
+
11
14
 
12
15
  class ZitiSocketCache:
13
16
  def __init__(
@@ -42,22 +45,24 @@ class ZitiSocketCache:
42
45
  sock = await self._cache.get(key)
43
46
 
44
47
  if sock:
45
- await self._cache.set(key, sock, ttl_seconds=self._ttl_seconds)
48
+ await self._cache.expire(key, self._ttl_seconds)
46
49
  self._active_sockets[key] = sock
50
+ logger.debug(f"Ziti socket found for service {key}")
47
51
  return sock
48
52
 
49
53
  sock = await self._create_socket(key)
50
- await self._cache.set(key, sock, ttl_seconds=self._ttl_seconds)
54
+ await self._cache.set(key, sock, self._ttl_seconds)
51
55
  self._active_sockets[key] = sock
56
+ logger.info(f"New Ziti socket created for service {key}")
52
57
  return sock
53
58
 
54
- async def invalidate(self, key: str):
55
- sock = await self._cache.get(key)
56
- if sock:
57
- await self._close_socket(sock)
59
+ # async def invalidate(self, key: str):
60
+ # sock = await self._cache.get(key)
61
+ # if sock:
62
+ # await self._close_socket(sock)
58
63
 
59
- await self._cache.delete(key)
60
- self._active_sockets.pop(key, None)
64
+ # await self._cache.delete(key)
65
+ # self._active_sockets.pop(key, None)
61
66
 
62
67
  async def start(self):
63
68
  self._cleanup_task = asyncio.create_task(self._periodic_cleanup())
@@ -65,9 +70,6 @@ class ZitiSocketCache:
65
70
  self._get_ziti_ctx()
66
71
 
67
72
  async def stop(self):
68
- """
69
- Cleanup: stop background task + close all sockets.
70
- """
71
73
  self._cleanup_task.cancel()
72
74
  with contextlib.suppress(Exception):
73
75
  await self._cleanup_task
@@ -92,12 +94,9 @@ class ZitiSocketCache:
92
94
  return
93
95
 
94
96
  async def _cleanup_once(self):
95
- keys_now = set(await self._cache.keys())
96
- known_keys = set(self._active_sockets.keys())
97
-
98
- expired = known_keys - keys_now
99
-
97
+ expired = {key for key in self._active_sockets.keys() if not self._cache.exists(key)}
100
98
  for key in expired:
99
+ logger.debug(f"Cleaning up expired socket connection {key}")
101
100
  sock = self._active_sockets.pop(key, None)
102
101
  if sock:
103
102
  await self._close_socket(sock)
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: mrok
3
- Version: 0.4.3
3
+ Version: 0.4.4
4
4
  Summary: MPT Extensions OpenZiti Orchestrator
5
5
  Author: SoftwareOne AG
6
6
  License: Apache License
@@ -71,9 +71,9 @@ mrok/http/server.py,sha256=Mj7C85fc-DXp-WTBWaOd7ag808oliLmFBH5bf-G2FHg,370
71
71
  mrok/http/types.py,sha256=XpNrvbfpANKvmjOBYtLF1FmDHoJF3z_MIMQHXoJlvmE,1302
72
72
  mrok/http/utils.py,sha256=sOixYu3R9-nNoMFYdifrreYvcFRIHYVtb6AAmtVzaLE,2125
73
73
  mrok/proxy/__init__.py,sha256=vWXyImroqM1Eq8e_oFPBup8VJ3reyp8SVjFTbLzRkI8,51
74
- mrok/proxy/app.py,sha256=-xmHKSSqQhNdwISRXQCUVLI1n6HWs3d46cgKQ6_NC3A,2157
74
+ mrok/proxy/app.py,sha256=yulfBdTdxesVxF1h2lli_5zjd5wP-jTx17FRdbkaV7A,2163
75
75
  mrok/proxy/main.py,sha256=ZXpticE6J4FABaslDB_8J5qklPsf3e7xIFSZmcPAAjQ,1588
76
- mrok/proxy/ziti.py,sha256=Ce02EimVJNffyluFr1nhOMXh6kZ0kY2nt6Shg58wkBw,3206
76
+ mrok/proxy/ziti.py,sha256=rKgIXpOvtBeVopZkQlNUZa3Fdci9jgiog_i6egb17ps,3318
77
77
  mrok/ziti/__init__.py,sha256=20OWMiexRhOovZOX19zlX87-V78QyWnEnSZfyAftUdE,263
78
78
  mrok/ziti/api.py,sha256=KvGiT9d4oSgC3JbFWLDQyuHcLX2HuZJoJ8nHmWtCDkY,16154
79
79
  mrok/ziti/bootstrap.py,sha256=QIDhlkIxPW2QRuumFq2D1WDbD003P5f3z24pAUsyeBI,2696
@@ -82,8 +82,8 @@ mrok/ziti/errors.py,sha256=yYCbVDwktnR0AYduqtynIjo73K3HOhIrwA_vQimvEd4,368
82
82
  mrok/ziti/identities.py,sha256=1BcwfqAJHMBhc3vRaf0aLaIkoHskj5Xe2Lsq2lO9Vs8,6735
83
83
  mrok/ziti/pki.py,sha256=o2tySqHC8-7bvFuI2Tqxg9vX6H6ZSxWxfP_9x29e19M,1954
84
84
  mrok/ziti/services.py,sha256=zR1PEBYwXVou20iJK4euh0ZZFAo9UB8PZk8f6SDmiUE,3194
85
- mrok-0.4.3.dist-info/METADATA,sha256=rfG5MT0fAz27oU7Jzr8RFD3LLA9Syci51df1gHFSgLI,15836
86
- mrok-0.4.3.dist-info/WHEEL,sha256=WLgqFyCfm_KASv4WHyYy0P3pM_m7J5L9k2skdKLirC8,87
87
- mrok-0.4.3.dist-info/entry_points.txt,sha256=tloXwvU1uJicBJR2h-8HoVclPgwJWDwuREMHN8Zq-nU,38
88
- mrok-0.4.3.dist-info/licenses/LICENSE.txt,sha256=6PaICaoA3yNsZKLv5G6OKqSfLSoX7MakYqTDgJoTCBs,11346
89
- mrok-0.4.3.dist-info/RECORD,,
85
+ mrok-0.4.4.dist-info/METADATA,sha256=nzjalRGet1yhkJf1L4t022A-NTDG-xQ9a5cWZfbDkdg,15836
86
+ mrok-0.4.4.dist-info/WHEEL,sha256=WLgqFyCfm_KASv4WHyYy0P3pM_m7J5L9k2skdKLirC8,87
87
+ mrok-0.4.4.dist-info/entry_points.txt,sha256=tloXwvU1uJicBJR2h-8HoVclPgwJWDwuREMHN8Zq-nU,38
88
+ mrok-0.4.4.dist-info/licenses/LICENSE.txt,sha256=6PaICaoA3yNsZKLv5G6OKqSfLSoX7MakYqTDgJoTCBs,11346
89
+ mrok-0.4.4.dist-info/RECORD,,
File without changes