wslink 2.3.1__tar.gz → 2.3.3__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.
Files changed (32) hide show
  1. {wslink-2.3.1 → wslink-2.3.3}/PKG-INFO +1 -1
  2. {wslink-2.3.1 → wslink-2.3.3}/setup.cfg +1 -1
  3. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/backends/aiohttp/__init__.py +15 -0
  4. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/emitter.py +30 -19
  5. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/websocket.py +3 -1
  6. {wslink-2.3.1 → wslink-2.3.3}/src/wslink.egg-info/PKG-INFO +1 -1
  7. {wslink-2.3.1 → wslink-2.3.3}/MANIFEST.in +0 -0
  8. {wslink-2.3.1 → wslink-2.3.3}/README.rst +0 -0
  9. {wslink-2.3.1 → wslink-2.3.3}/setup.py +0 -0
  10. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/LICENSE +0 -0
  11. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/__init__.py +0 -0
  12. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/backends/__init__.py +0 -0
  13. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/backends/aiohttp/launcher.py +0 -0
  14. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/backends/aiohttp/relay.py +0 -0
  15. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/backends/generic/__init__.py +0 -0
  16. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/backends/generic/core.py +0 -0
  17. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/backends/jupyter/__init__.py +0 -0
  18. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/backends/jupyter/core.py +0 -0
  19. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/backends/tornado/__init__.py +0 -0
  20. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/backends/tornado/core.py +0 -0
  21. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/chunking.py +0 -0
  22. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/launcher.py +0 -0
  23. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/protocol.py +0 -0
  24. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/publish.py +0 -0
  25. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/relay.py +0 -0
  26. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/server.py +0 -0
  27. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/ssl_context.py +0 -0
  28. {wslink-2.3.1 → wslink-2.3.3}/src/wslink/uri.py +0 -0
  29. {wslink-2.3.1 → wslink-2.3.3}/src/wslink.egg-info/SOURCES.txt +0 -0
  30. {wslink-2.3.1 → wslink-2.3.3}/src/wslink.egg-info/dependency_links.txt +0 -0
  31. {wslink-2.3.1 → wslink-2.3.3}/src/wslink.egg-info/requires.txt +0 -0
  32. {wslink-2.3.1 → wslink-2.3.3}/src/wslink.egg-info/top_level.txt +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: wslink
3
- Version: 2.3.1
3
+ Version: 2.3.3
4
4
  Summary: Python/JavaScript library for communicating over WebSocket
5
5
  Home-page: https://github.com/kitware/wslink
6
6
  Author: Kitware, Inc.
@@ -1,5 +1,5 @@
1
1
  [metadata]
2
- version = 2.3.1
2
+ version = 2.3.3
3
3
 
4
4
  [egg_info]
5
5
  tag_build =
@@ -27,6 +27,19 @@ STATE_KEY = aiohttp_web.AppKey("state", str)
27
27
 
28
28
  logger = logging.getLogger(__name__)
29
29
 
30
+ def reload_settings():
31
+ global MSG_OVERHEAD, MAX_MSG_SIZE, HEART_BEAT, HTTP_HEADERS
32
+
33
+ MSG_OVERHEAD = int(os.environ.get("WSLINK_MSG_OVERHEAD", 4096))
34
+ MAX_MSG_SIZE = int(os.environ.get("WSLINK_MAX_MSG_SIZE", 4194304))
35
+ HEART_BEAT = int(os.environ.get("WSLINK_HEART_BEAT", 30)) # 30 seconds
36
+ HTTP_HEADERS = os.environ.get("WSLINK_HTTP_HEADERS")
37
+
38
+ # Allow to skip heart beat
39
+ if HEART_BEAT < 1:
40
+ HEART_BEAT = None
41
+
42
+
30
43
  # -----------------------------------------------------------------------------
31
44
  # HTTP helpers
32
45
  # -----------------------------------------------------------------------------
@@ -57,6 +70,7 @@ async def http_headers(request: aiohttp_web.Request, handler):
57
70
  # -----------------------------------------------------------------------------
58
71
  class WebAppServer(AbstractWebApp):
59
72
  def __init__(self, server_config):
73
+ reload_settings()
60
74
  AbstractWebApp.__init__(self, server_config)
61
75
  if HTTP_HEADERS:
62
76
  self.set_app(aiohttp_web.Application(middlewares=[http_headers]))
@@ -167,6 +181,7 @@ class WebAppServer(AbstractWebApp):
167
181
 
168
182
  class ReverseWebAppServer(AbstractWebApp):
169
183
  def __init__(self, server_config):
184
+ reload_settings()
170
185
  super().__init__(server_config)
171
186
  self._url = server_config.get("reverse_url")
172
187
  self._server_protocol = server_config.get("ws_protocol")
@@ -3,34 +3,26 @@ import functools
3
3
 
4
4
 
5
5
  class EventEmitter:
6
- def __init__(self):
6
+ def __init__(self, allowed_events=None):
7
7
  self._listeners = {}
8
8
 
9
+ if allowed_events is None:
10
+ allowed_events = []
11
+
12
+ self._allowed_events = set(allowed_events)
13
+
14
+ for event in self._allowed_events:
15
+ setattr(self, event, functools.partial(self.emit, event))
16
+
9
17
  def clear(self):
10
18
  self._listeners = {}
11
19
 
12
20
  def __call__(self, event, *args, **kwargs):
13
21
  self.emit(event, *args, **kwargs)
14
22
 
15
- def __getattr__(self, name):
16
- return functools.partial(self.emit, name)
17
-
18
- def exception(self, *args, **kwargs):
19
- self.emit("exception", *args, **kwargs)
20
-
21
- def error(self, *args, **kwargs):
22
- self.emit("error", *args, **kwargs)
23
-
24
- def critical(self, *args, **kwargs):
25
- self.emit("critical", *args, **kwargs)
26
-
27
- def info(self, *args, **kwargs):
28
- self.emit("info", *args, **kwargs)
29
-
30
- def debug(self, *args, **kwargs):
31
- self.emit("debug", *args, **kwargs)
32
-
33
23
  def emit(self, event, *args, **kwargs):
24
+ self._validate_event(event)
25
+
34
26
  listeners = self._listeners.get(event)
35
27
  if listeners is None:
36
28
  return
@@ -47,6 +39,8 @@ class EventEmitter:
47
39
  listener(*args, **kwargs)
48
40
 
49
41
  def add_event_listener(self, event, listener):
42
+ self._validate_event(event)
43
+
50
44
  listeners = self._listeners.get(event)
51
45
  if listeners is None:
52
46
  listeners = set()
@@ -55,6 +49,8 @@ class EventEmitter:
55
49
  listeners.add(listener)
56
50
 
57
51
  def remove_event_listener(self, event, listener):
52
+ self._validate_event(event)
53
+
58
54
  listeners = self._listeners.get(event)
59
55
  if listeners is None:
60
56
  return
@@ -66,8 +62,23 @@ class EventEmitter:
66
62
  return self.listeners_count(event) > 0
67
63
 
68
64
  def listeners_count(self, event):
65
+ self._validate_event(event)
66
+
69
67
  listeners = self._listeners.get(event)
70
68
  if listeners is None:
71
69
  return 0
72
70
 
73
71
  return len(listeners)
72
+
73
+ @property
74
+ def allowed_events(self):
75
+ return self._allowed_events
76
+
77
+ def _validate_event(self, event):
78
+ if len(self.allowed_events) == 0:
79
+ return
80
+
81
+ if event not in self.allowed_events:
82
+ raise ValueError(
83
+ f"'{event}' is not a known event of this EventEmitter: {self.allowed_events}"
84
+ )
@@ -126,7 +126,9 @@ class ServerProtocol(object):
126
126
 
127
127
  def __init__(self):
128
128
  self.network_monitor = NetworkMonitor()
129
- self.log_emitter = EventEmitter()
129
+ self.log_emitter = EventEmitter(
130
+ allowed_events=["exception", "error", "critical", "info", "debug"]
131
+ )
130
132
  self.linkProtocols = []
131
133
  self.secret = None
132
134
  self.initialize()
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: wslink
3
- Version: 2.3.1
3
+ Version: 2.3.3
4
4
  Summary: Python/JavaScript library for communicating over WebSocket
5
5
  Home-page: https://github.com/kitware/wslink
6
6
  Author: Kitware, Inc.
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes