omserv 0.0.0.dev23__py3-none-any.whl → 0.0.0.dev25__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.
omserv/__about__.py CHANGED
@@ -26,3 +26,16 @@ class Setuptools(SetuptoolsBase):
26
26
  'include': [Project.name, f'{Project.name}.*'],
27
27
  'exclude': [*SetuptoolsBase.find_packages['exclude']],
28
28
  }
29
+
30
+ package_data = {
31
+ **SetuptoolsBase.package_data,
32
+
33
+ '*': [
34
+ *SetuptoolsBase.package_data['*'],
35
+
36
+ '*.ico',
37
+ '*.j2',
38
+
39
+ '*.patch',
40
+ ],
41
+ }
omserv/_manifests.json ADDED
@@ -0,0 +1 @@
1
+ []
File without changes
omserv/nginx/build.py ADDED
@@ -0,0 +1,122 @@
1
+ import multiprocessing
2
+ import os.path
3
+ import shutil
4
+ import subprocess
5
+ import sys
6
+ import tempfile
7
+ import urllib.request
8
+
9
+ from omlish import check
10
+ from omlish import lang
11
+
12
+
13
+ NGINX_VERSION = '1.27.0'
14
+ NGINX_SRC_URL = f'https://nginx.org/download/nginx-{NGINX_VERSION}.tar.gz'
15
+
16
+ NGINX_VTS_VERSION = '0.2.2'
17
+ NGINX_VTS_SRC_URL = f'https://github.com/vozlt/nginx-module-vts/archive/refs/tags/v{NGINX_VTS_VERSION}.tar.gz'
18
+
19
+
20
+ def build_nginx() -> None:
21
+ build_dir = tempfile.mkdtemp('-omlish-nginx-build')
22
+ print(f'{build_dir=}')
23
+
24
+ #
25
+
26
+ nginx_src_file = urllib.request.urlretrieve(NGINX_SRC_URL)[0] # noqa
27
+ print(f'{nginx_src_file=}')
28
+
29
+ nginx_vts_src_file = urllib.request.urlretrieve(NGINX_VTS_SRC_URL)[0] # noqa
30
+ print(f'{nginx_vts_src_file=}')
31
+
32
+ subprocess.check_call(['tar', 'xvzf', nginx_src_file, '-C', build_dir])
33
+ nginx_dir = os.path.join(build_dir, f'nginx-{NGINX_VERSION}')
34
+
35
+ subprocess.check_call(['tar', 'xvzf', nginx_vts_src_file, '-C', build_dir])
36
+ nginx_vts_dir = os.path.join(build_dir, f'nginx-module-vts-{NGINX_VTS_VERSION}')
37
+
38
+ #
39
+
40
+ patch_prefix = f'nginx-{NGINX_VERSION}_'
41
+ for r in lang.get_relative_resources('patches', globals=globals()).values():
42
+ if r.is_file and r.name.startswith(patch_prefix) and r.name.endswith('.patch'):
43
+ print(r.name)
44
+
45
+ patch_src = r.read_bytes()
46
+ subprocess.run(
47
+ ['git', 'apply'],
48
+ cwd=nginx_dir,
49
+ input=patch_src,
50
+ check=True,
51
+ )
52
+
53
+ #
54
+
55
+ cflags = [
56
+ '-g',
57
+ '-O2',
58
+ '-fstack-protector',
59
+ ]
60
+ ldflags = []
61
+
62
+ if sys.platform == 'darwin':
63
+ openssl_prefix = subprocess.check_output(['brew', '--prefix', 'openssl']).decode().strip()
64
+ pcre_prefix = subprocess.check_output(['brew', '--prefix', 'pcre']).decode().strip()
65
+ cflags.extend([
66
+ f'-I{openssl_prefix}/include',
67
+ f'-I{pcre_prefix}/include',
68
+ ])
69
+ ldflags.extend([
70
+ f'-L{openssl_prefix}/lib',
71
+ f'-L{pcre_prefix}/lib',
72
+ ])
73
+
74
+ subprocess.check_call([
75
+ check.not_none(shutil.which('sh')),
76
+
77
+ 'configure',
78
+
79
+ f'--with-cc-opt={" ".join(cflags)}',
80
+ f'--with-ld-opt={" ".join(ldflags)}',
81
+
82
+ '--with-compat',
83
+ '--with-threads',
84
+ '--with-debug',
85
+ '--with-ipv6',
86
+ '--with-pcre',
87
+ '--with-pcre-jit',
88
+
89
+ '--with-http_auth_request_module',
90
+ '--with-http_gunzip_module',
91
+ '--with-http_gzip_static_module',
92
+ '--with-http_ssl_module',
93
+ '--with-http_stub_status_module',
94
+ '--with-http_v2_module',
95
+
96
+ '--with-stream',
97
+ '--with-stream_ssl_module',
98
+ '--with-stream_ssl_preread_module',
99
+
100
+ f'--add-module={nginx_vts_dir}',
101
+ ], cwd=nginx_dir)
102
+
103
+ #
104
+
105
+ make_jobs = max(multiprocessing.cpu_count() // 2, 1)
106
+ subprocess.check_call([
107
+ 'make',
108
+ f'-j{make_jobs}',
109
+ ], cwd=nginx_dir)
110
+
111
+ #
112
+
113
+ exe_file = os.path.join(nginx_dir, 'objs', 'nginx')
114
+ print(exe_file)
115
+
116
+
117
+ def _main() -> None:
118
+ build_nginx()
119
+
120
+
121
+ if __name__ == '__main__':
122
+ _main()
@@ -0,0 +1,86 @@
1
+ """
2
+ TODO:
3
+ - omnibus/jmespath
4
+
5
+ https://nginx.org/en/docs/dev/development_guide.html
6
+ https://nginx.org/en/docs/dev/development_guide.html#config_directives
7
+ https://nginx.org/en/docs/example.html
8
+
9
+ https://github.com/yandex/gixy
10
+ """
11
+ import dataclasses as dc
12
+ import typing as ta
13
+
14
+ from omlish import check
15
+ from omlish import lang
16
+ from omlish.text.indent import IndentWriter
17
+
18
+
19
+ @dc.dataclass()
20
+ class Items(lang.Final):
21
+ lst: list['Item']
22
+
23
+ @classmethod
24
+ def of(cls, obj: ta.Any) -> 'Items':
25
+ if isinstance(obj, Items):
26
+ return obj
27
+ return cls([Item.of(e) for e in check.isinstance(obj, list)])
28
+
29
+
30
+ @dc.dataclass()
31
+ class Item(lang.Final):
32
+ name: str
33
+ args: list[str] | None = None
34
+ block: Items | None = None
35
+
36
+ @classmethod
37
+ def of(cls, obj: ta.Any) -> 'Item':
38
+ if isinstance(obj, Item):
39
+ return obj
40
+ args = check.isinstance(obj, tuple)
41
+ name, args = check.isinstance(args[0], str), args[1:]
42
+ if args and not isinstance(args[-1], str):
43
+ block, args = Items.of(args[-1]), args[:-1]
44
+ else:
45
+ block = None
46
+ return Item(name, [check.isinstance(e, str) for e in args], block=block)
47
+
48
+
49
+ def render(wr: IndentWriter, obj: ta.Any) -> None:
50
+ if isinstance(obj, Item):
51
+ wr.write(obj.name)
52
+ for e in obj.args or ():
53
+ wr.write(' ')
54
+ wr.write(e)
55
+ if obj.block:
56
+ wr.write(' {\n')
57
+ with wr.indent():
58
+ render(wr, obj.block)
59
+ wr.write('}\n')
60
+ else:
61
+ wr.write(';\n')
62
+
63
+ elif isinstance(obj, Items):
64
+ for e2 in obj.lst:
65
+ render(wr, e2)
66
+
67
+ else:
68
+ raise TypeError(obj)
69
+
70
+
71
+ def _main() -> None:
72
+ conf = Items.of([
73
+ ('user', 'www', 'www'),
74
+ ('worker_processes', '2'),
75
+ ('events', [
76
+ ('worker_connections', '2000'),
77
+ ]),
78
+ ])
79
+
80
+ wr = IndentWriter()
81
+ render(wr, conf)
82
+ print(wr.getvalue())
83
+
84
+
85
+ if __name__ == '__main__':
86
+ _main()
File without changes
@@ -0,0 +1,109 @@
1
+ diff --git a/src/event/ngx_event.c b/src/event/ngx_event.c
2
+ index ef525d9..46ca5ee 100644
3
+ --- a/src/event/ngx_event.c
4
+ +++ b/src/event/ngx_event.c
5
+ @@ -75,6 +75,13 @@ ngx_atomic_t *ngx_stat_writing = &ngx_stat_writing0;
6
+ static ngx_atomic_t ngx_stat_waiting0;
7
+ ngx_atomic_t *ngx_stat_waiting = &ngx_stat_waiting0;
8
+
9
+ +static ngx_atomic_t ngx_stat_2xx0;
10
+ +ngx_atomic_t *ngx_stat_2xx = &ngx_stat_2xx0;
11
+ +static ngx_atomic_t ngx_stat_4xx0;
12
+ +ngx_atomic_t *ngx_stat_4xx = &ngx_stat_4xx0;
13
+ +static ngx_atomic_t ngx_stat_5xx0;
14
+ +ngx_atomic_t *ngx_stat_5xx = &ngx_stat_5xx0;
15
+ +
16
+ #endif
17
+
18
+
19
+ @@ -563,7 +570,10 @@ ngx_event_module_init(ngx_cycle_t *cycle)
20
+ + cl /* ngx_stat_active */
21
+ + cl /* ngx_stat_reading */
22
+ + cl /* ngx_stat_writing */
23
+ - + cl; /* ngx_stat_waiting */
24
+ + + cl /* ngx_stat_waiting */
25
+ + + cl /* ngx_stat_2xx */
26
+ + + cl /* ngx_stat_4xx */
27
+ + + cl; /* ngx_stat_5xx */
28
+
29
+ #endif
30
+
31
+ @@ -610,6 +620,9 @@ ngx_event_module_init(ngx_cycle_t *cycle)
32
+ ngx_stat_reading = (ngx_atomic_t *) (shared + 7 * cl);
33
+ ngx_stat_writing = (ngx_atomic_t *) (shared + 8 * cl);
34
+ ngx_stat_waiting = (ngx_atomic_t *) (shared + 9 * cl);
35
+ + ngx_stat_2xx = (ngx_atomic_t *) (shared + 10 * cl);
36
+ + ngx_stat_4xx = (ngx_atomic_t *) (shared + 11 * cl);
37
+ + ngx_stat_5xx = (ngx_atomic_t *) (shared + 12 * cl);
38
+
39
+ #endif
40
+
41
+ diff --git a/src/event/ngx_event.h b/src/event/ngx_event.h
42
+ index deac04e..48b7622 100644
43
+ --- a/src/event/ngx_event.h
44
+ +++ b/src/event/ngx_event.h
45
+ @@ -475,6 +475,10 @@ extern ngx_atomic_t *ngx_stat_reading;
46
+ extern ngx_atomic_t *ngx_stat_writing;
47
+ extern ngx_atomic_t *ngx_stat_waiting;
48
+
49
+ +extern ngx_atomic_t *ngx_stat_2xx;
50
+ +extern ngx_atomic_t *ngx_stat_4xx;
51
+ +extern ngx_atomic_t *ngx_stat_5xx;
52
+ +
53
+ #endif
54
+
55
+
56
+ diff --git a/src/http/modules/ngx_http_stub_status_module.c b/src/http/modules/ngx_http_stub_status_module.c
57
+ index db68b76..631427d 100644
58
+ --- a/src/http/modules/ngx_http_stub_status_module.c
59
+ +++ b/src/http/modules/ngx_http_stub_status_module.c
60
+ @@ -87,7 +87,7 @@ ngx_http_stub_status_handler(ngx_http_request_t *r)
61
+ ngx_int_t rc;
62
+ ngx_buf_t *b;
63
+ ngx_chain_t out;
64
+ - ngx_atomic_int_t ap, hn, ac, rq, rd, wr, wa;
65
+ + ngx_atomic_int_t ap, hn, ac, rq, rd, wr, wa, st2xx, st4xx, st5xx;
66
+
67
+ if (!(r->method & (NGX_HTTP_GET|NGX_HTTP_HEAD))) {
68
+ return NGX_HTTP_NOT_ALLOWED;
69
+ @@ -124,12 +124,16 @@ ngx_http_stub_status_handler(ngx_http_request_t *r)
70
+ wr = *ngx_stat_writing;
71
+ wa = *ngx_stat_waiting;
72
+
73
+ + st2xx = *ngx_stat_2xx;
74
+ + st4xx = *ngx_stat_4xx;
75
+ + st5xx = *ngx_stat_5xx;
76
+ +
77
+ b->last = ngx_sprintf(b->last, "Active connections: %uA \n", ac);
78
+
79
+ - b->last = ngx_cpymem(b->last, "server accepts handled requests\n",
80
+ - sizeof("server accepts handled requests\n") - 1);
81
+ + b->last = ngx_cpymem(b->last, "server accepts handled requests 2xx 4xx 5xx\n",
82
+ + sizeof("server accepts handled requests 2xx 4xx 5xx\n") - 1);
83
+
84
+ - b->last = ngx_sprintf(b->last, " %uA %uA %uA \n", ap, hn, rq);
85
+ + b->last = ngx_sprintf(b->last, " %uA %uA %uA %uA %uA %uA \n", ap, hn, rq, st2xx, st4xx, st5xx);
86
+
87
+ b->last = ngx_sprintf(b->last, "Reading: %uA Writing: %uA Waiting: %uA \n",
88
+ rd, wr, wa);
89
+ diff --git a/src/http/ngx_http_request.c b/src/http/ngx_http_request.c
90
+ index 3cca57c..46ff1fe 100644
91
+ --- a/src/http/ngx_http_request.c
92
+ +++ b/src/http/ngx_http_request.c
93
+ @@ -3797,6 +3797,16 @@ ngx_http_log_request(ngx_http_request_t *r)
94
+ ngx_http_handler_pt *log_handler;
95
+ ngx_http_core_main_conf_t *cmcf;
96
+
97
+ +#if (NGX_STAT_STUB)
98
+ + if (r->headers_out.status >= 200 && r->headers_out.status < 300) {
99
+ + (void) ngx_atomic_fetch_add(ngx_stat_2xx, 1);
100
+ + } else if (r->headers_out.status >= 400 && r->headers_out.status < 500) {
101
+ + (void) ngx_atomic_fetch_add(ngx_stat_4xx, 1);
102
+ + } else if (r->headers_out.status >= 500 && r->headers_out.status < 600) {
103
+ + (void) ngx_atomic_fetch_add(ngx_stat_5xx, 1);
104
+ + }
105
+ +#endif
106
+ +
107
+ cmcf = ngx_http_get_module_main_conf(r, ngx_http_core_module);
108
+
109
+ log_handler = cmcf->phases[NGX_HTTP_LOG_PHASE].handlers.elts;
@@ -0,0 +1,73 @@
1
+ import dataclasses as dc
2
+ import re
3
+ import textwrap
4
+ import typing as ta
5
+
6
+
7
+ @dc.dataclass(frozen=True, kw_only=True)
8
+ class StubStatus:
9
+ active: int
10
+
11
+ # std: accepts handled requests
12
+ # ext: 2xx 4xx 5xx
13
+ counts: ta.Mapping[str, int]
14
+
15
+ reading: int
16
+ writing: int
17
+ waiting: int
18
+
19
+
20
+ _ACTIVE_PAT = re.compile(r'^Active connections: (?P<active>\d+)')
21
+ _RWW_PAT = re.compile(r'^Reading: (?P<reading>\d+) Writing: (?P<writing>\d+) Waiting: (?P<waiting>\d+)')
22
+
23
+
24
+ def parse_stub_status(s: str) -> StubStatus:
25
+ # Active connections: 1
26
+ # server accepts handled requests 2xx 4xx 5xx
27
+ # 20 20 20 18 1 0
28
+ # Reading: 0 Writing: 1 Waiting: 0
29
+
30
+ lines = [l for l in s.splitlines() for l in [l.strip()] if l]
31
+ if len(lines) < 4:
32
+ raise Exception('Not enough lines')
33
+
34
+ if (active_m := _ACTIVE_PAT.match(lines[0])) is None:
35
+ raise Exception('Failed to match active line')
36
+ active = int(active_m.groupdict()['active'])
37
+
38
+ if (rww_m := _RWW_PAT.match(lines[3])) is None:
39
+ raise Exception('Failed to match rww line')
40
+ reading = int(rww_m.groupdict()['reading'])
41
+ writing = int(rww_m.groupdict()['writing'])
42
+ waiting = int(rww_m.groupdict()['waiting'])
43
+
44
+ ct_lbl = lines[1].split()[1:]
45
+ ct_val = lines[2].split()
46
+ if len(ct_lbl) != len(ct_val):
47
+ raise Exception('Counts label/value mismatch')
48
+ counts = {l: int(v) for l, v in zip(ct_lbl, ct_val)}
49
+
50
+ return StubStatus(
51
+ active=active,
52
+
53
+ counts=counts,
54
+
55
+ reading=reading,
56
+ writing=writing,
57
+ waiting=waiting,
58
+ )
59
+
60
+
61
+ def _main() -> None:
62
+ s = textwrap.dedent("""
63
+ Active connections: 1
64
+ server accepts handled requests 2xx 4xx 5xx
65
+ 20 20 20 18 1 0
66
+ Reading: 0 Writing: 1 Waiting: 0
67
+ """)
68
+ ss = parse_stub_status(s)
69
+ print(ss)
70
+
71
+
72
+ if __name__ == '__main__':
73
+ _main()
omserv/server/LICENSE ADDED
@@ -0,0 +1,14 @@
1
+ Copyright P G Jones 2018.
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
4
+ documentation files (the "Software"), to deal in the Software without restriction, including without limitation the
5
+ rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit
6
+ persons to whom the Software is furnished to do so, subject to the following conditions:
7
+
8
+ The above copyright notice and this permission notice shall be included in all copies or substantial portions of the
9
+ Software.
10
+
11
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
12
+ WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
13
+ COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
14
+ OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Binary file
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: omserv
3
- Version: 0.0.0.dev23
3
+ Version: 0.0.0.dev25
4
4
  Summary: omserv
5
5
  Author: wrmsr
6
6
  License: BSD-3-Clause
@@ -12,7 +12,7 @@ Classifier: Operating System :: OS Independent
12
12
  Classifier: Operating System :: POSIX
13
13
  Requires-Python: ~=3.12
14
14
  License-File: LICENSE
15
- Requires-Dist: omlish ==0.0.0.dev23
15
+ Requires-Dist: omlish ==0.0.0.dev25
16
16
  Provides-Extra: all
17
17
  Requires-Dist: h11 ~=0.14 ; extra == 'all'
18
18
  Requires-Dist: h2 ~=4.1 ; extra == 'all'
@@ -1,5 +1,6 @@
1
- omserv/__about__.py,sha256=IwJ97UdJUqmuXGftkoUyB4PLm1kL_q7bZozQLMSrceI,631
1
+ omserv/__about__.py,sha256=l9yTdHqbdd7L6tobi6BTiEO9huwg_6ndnmVNnQxL8f8,838
2
2
  omserv/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
3
+ omserv/_manifests.json,sha256=N1F-Xz3GaBn2H1p7uKzhkhKCQV8QVR0t76XD6wmFtXA,3
3
4
  omserv/dbs.py,sha256=RLXwNmENmM9MLsjFqDho_R8ibMjOKAxWUn4zhzTlP9Y,756
4
5
  omserv/secrets.py,sha256=ja0VsCB01MHxYwn5OHjFeXV9cRah9AQl-0uJzZELpic,256
5
6
  omserv/apps/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -9,10 +10,17 @@ omserv/apps/markers.py,sha256=aj39pNZYlTSjUQT02wOftzrkTq1TTMIfE0aMoV_XxVk,882
9
10
  omserv/apps/routes.py,sha256=shcN8qCSF2YoKal7nk-lemCAK3RX8MuHgNHhq_CTnh0,3762
10
11
  omserv/apps/sessions.py,sha256=glruQSbOSbCYLPp6nDRNSHCyp5hj4oiOPhh3R0F9BTM,1537
11
12
  omserv/apps/templates.py,sha256=PBRZHIF9UbnFnq-4EC6RmPeRkeH8lCBbpJkSdseHs6A,2125
13
+ omserv/nginx/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
14
+ omserv/nginx/build.py,sha256=mCvX7f1LGguLNPVQEwxlWO6OQpad43JbLu96gbIlNy4,3141
15
+ omserv/nginx/configs.py,sha256=4oQDcKJKIatRG621qiZCYTayJI3-vv63TtRCiUxEVWI,2008
16
+ omserv/nginx/stubstatus.py,sha256=_VnXZdXxSA7jIelYSwJLf9mOnt_UOvpWghAPWtlWSLw,1857
17
+ omserv/nginx/patches/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
18
+ omserv/nginx/patches/nginx-1.27.0_http_status.patch,sha256=bEDSczpBLcdjcBp_X1m73oxvt8KPeons7v_sUxqBSXM,4335
12
19
  omserv/node/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
13
20
  omserv/node/models.py,sha256=XsfAI-LjlRkRfK0_ofh-gai5IUq_g357UfThK9dZ0UM,1258
14
21
  omserv/node/registry.py,sha256=0hodmyQn3POOZJBG8zTr9ojR80-ZNmIwJpQbchJg8EM,3459
15
22
  omserv/node/sql.py,sha256=vy7RP50JiH3jQHMVa7Hxk0pFJK3QcbGeTvyNppB1W4I,2826
23
+ omserv/server/LICENSE,sha256=VKPNmbyrS9wcwcx20hBlVtLP01brb2dByHrWHeNLPag,1050
16
24
  omserv/server/__init__.py,sha256=K8l4nfv9c_5o8dph-SyadW_19CdTC2FGlikyHMU5lAU,375
17
25
  omserv/server/config.py,sha256=oGWL1kuk45bJ6sVr8n3ow5Q-1nz9EqByjoykU2iOHIY,1189
18
26
  omserv/server/debug.py,sha256=N7RI0Jj-ttmys3DJD0RREmGG5XZpTCp6y9Yu0x98Agg,299
@@ -33,12 +41,13 @@ omserv/server/protocols/h2.py,sha256=pClkPlaX0WnQ1dKee7Fvr4csSH2bBqItTcsKVuk1p1Q
33
41
  omserv/server/protocols/protocols.py,sha256=1ky8PGYIIR8wco6fcw-41RmHW-Kz_cNcZZoOqi7btNk,2790
34
42
  omserv/server/protocols/types.py,sha256=OXt5U3LsBToDxT7ipfFGiIHJU0WVvlfT6QQacF-_Plc,440
35
43
  omserv/server/resources/__init__.py,sha256=KppZbvZBKX1TdyaQZYY92oEKpdB3nuUXxharAgrbAIA,193
44
+ omserv/server/resources/favicon.ico,sha256=48hwhc03Fp6Rbj0fEQEB95woJMhCDsM2nMZJfeKAU0g,38078
36
45
  omserv/server/streams/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
37
46
  omserv/server/streams/httpstream.py,sha256=0DeiAPLGbEGNa0fHTs8lUpi_CFZs4M5_QB-TiS8mobQ,8015
38
47
  omserv/server/streams/utils.py,sha256=aMOrqWIg_Hht5W4kLg3y7oR5AEkVvMrZhyjzo6U5owE,1527
39
48
  omserv/server/streams/wsstream.py,sha256=3Vyzox7dCE1tDSXjb6xBubWo41ZF9d38Hrsrlj6h1J8,15482
40
- omserv-0.0.0.dev23.dist-info/LICENSE,sha256=B_hVtavaA8zCYDW99DYdcpDLKz1n3BBRjZrcbv8uG8c,1451
41
- omserv-0.0.0.dev23.dist-info/METADATA,sha256=8ZvRY6x8Ub3JXRB9KM9EBkA5QQbLrn0C2pBn-njd3JE,881
42
- omserv-0.0.0.dev23.dist-info/WHEEL,sha256=cVxcB9AmuTcXqmwrtPhNK88dr7IR_b6qagTj0UvIEbY,91
43
- omserv-0.0.0.dev23.dist-info/top_level.txt,sha256=HXehpnxeKscKNULzKNzZ27oNawBrsh1PaNAirbX-XNA,7
44
- omserv-0.0.0.dev23.dist-info/RECORD,,
49
+ omserv-0.0.0.dev25.dist-info/LICENSE,sha256=B_hVtavaA8zCYDW99DYdcpDLKz1n3BBRjZrcbv8uG8c,1451
50
+ omserv-0.0.0.dev25.dist-info/METADATA,sha256=65c61CuYjTA6ag094L-GdCJXShj0YcJNfbUWRK4B18Y,881
51
+ omserv-0.0.0.dev25.dist-info/WHEEL,sha256=cVxcB9AmuTcXqmwrtPhNK88dr7IR_b6qagTj0UvIEbY,91
52
+ omserv-0.0.0.dev25.dist-info/top_level.txt,sha256=HXehpnxeKscKNULzKNzZ27oNawBrsh1PaNAirbX-XNA,7
53
+ omserv-0.0.0.dev25.dist-info/RECORD,,