soia-client 1.0.22__tar.gz → 1.0.24__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 (33) hide show
  1. {soia_client-1.0.22 → soia_client-1.0.24}/PKG-INFO +1 -1
  2. {soia_client-1.0.22 → soia_client-1.0.24}/pyproject.toml +1 -1
  3. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/service_client.py +86 -1
  4. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/structs.py +1 -1
  5. {soia_client-1.0.22 → soia_client-1.0.24}/soia_client.egg-info/PKG-INFO +1 -1
  6. {soia_client-1.0.22 → soia_client-1.0.24}/tests/test_module_initializer.py +1 -0
  7. {soia_client-1.0.22 → soia_client-1.0.24}/LICENSE +0 -0
  8. {soia_client-1.0.22 → soia_client-1.0.24}/README.md +0 -0
  9. {soia_client-1.0.22 → soia_client-1.0.24}/setup.cfg +0 -0
  10. {soia_client-1.0.22 → soia_client-1.0.24}/soia/__init__.py +0 -0
  11. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/__init__.py +0 -0
  12. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/arrays.py +0 -0
  13. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/enums.py +0 -0
  14. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/function_maker.py +0 -0
  15. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/keyed_items.py +0 -0
  16. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/method.py +0 -0
  17. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/never.py +0 -0
  18. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/optionals.py +0 -0
  19. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/primitives.py +0 -0
  20. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/repr.py +0 -0
  21. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/serializer.py +0 -0
  22. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/serializers.py +0 -0
  23. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/service.py +0 -0
  24. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/timestamp.py +0 -0
  25. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_impl/type_adapter.py +0 -0
  26. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_module_initializer.py +0 -0
  27. {soia_client-1.0.22 → soia_client-1.0.24}/soia/_spec.py +0 -0
  28. {soia_client-1.0.22 → soia_client-1.0.24}/soia/reflection.py +0 -0
  29. {soia_client-1.0.22 → soia_client-1.0.24}/soia_client.egg-info/SOURCES.txt +0 -0
  30. {soia_client-1.0.22 → soia_client-1.0.24}/soia_client.egg-info/dependency_links.txt +0 -0
  31. {soia_client-1.0.22 → soia_client-1.0.24}/soia_client.egg-info/top_level.txt +0 -0
  32. {soia_client-1.0.22 → soia_client-1.0.24}/tests/test_serializers.py +0 -0
  33. {soia_client-1.0.22 → soia_client-1.0.24}/tests/test_timestamp.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: soia-client
3
- Version: 1.0.22
3
+ Version: 1.0.24
4
4
  Author-email: Tyler Fibonacci <gepheum@gmail.com>
5
5
  License: MIT License
6
6
 
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
4
4
 
5
5
  [project]
6
6
  name = "soia-client"
7
- version = "1.0.22"
7
+ version = "1.0.24"
8
8
  description = ""
9
9
  readme = "README.md"
10
10
  authors = [{ name = "Tyler Fibonacci", email = "gepheum@gmail.com" }]
@@ -1,6 +1,6 @@
1
1
  import http.client
2
2
  import re
3
- from typing import Any, Final, Mapping
3
+ from typing import Any, Final, Mapping, Protocol
4
4
  from urllib.parse import urlparse
5
5
 
6
6
  from soia._impl.method import Method, Request, Response
@@ -77,3 +77,88 @@ class ServiceClient:
77
77
  if re.match(r"text/plain\b", content_type):
78
78
  message = f"{message}: {response_data}"
79
79
  raise RuntimeError(message)
80
+
81
+ async def invoke_remote_async(
82
+ self,
83
+ aiohttp_client_session: "_AiohttpClientSession",
84
+ method: Method[Request, Response],
85
+ request: Request,
86
+ headers: Mapping[str, str] = {},
87
+ *,
88
+ res_headers: list[tuple[str, str]] | None = None,
89
+ ) -> Response:
90
+ """
91
+ Asynchronously invokes the given method on the remote server through an RPC.
92
+
93
+ Usage:
94
+ import aiohttp
95
+
96
+ async with aiohttp.ClientSession() as session:
97
+ response = await service_client.invoke_remote_async(
98
+ session,
99
+ method,
100
+ request,
101
+ headers,
102
+ )
103
+
104
+ With timeout:
105
+ timeout = aiohttp.ClientTimeout(total=30)
106
+ async with aiohttp.ClientSession(timeout=timeout) as session:
107
+ response = await service_client.invoke_remote_async(
108
+ session,
109
+ method,
110
+ request,
111
+ headers,
112
+ )
113
+ """
114
+
115
+ request_json = method.request_serializer.to_json_code(request)
116
+ body = ":".join(
117
+ [
118
+ method.name,
119
+ str(method.number),
120
+ "",
121
+ request_json,
122
+ ]
123
+ )
124
+
125
+ request_headers = {
126
+ **headers,
127
+ "Content-Type": "text/plain; charset=utf-8",
128
+ "Content-Length": str(len(body)),
129
+ }
130
+
131
+ # Build the URL
132
+ url = f"{self._scheme}://{self._host}{self._path}"
133
+
134
+ async with aiohttp_client_session.post(
135
+ url,
136
+ data=body,
137
+ headers=request_headers,
138
+ ) as response:
139
+ if res_headers is not None:
140
+ res_headers.clear()
141
+ res_headers.extend(response.headers.items())
142
+
143
+ status_code = response.status
144
+ content_type = response.headers.get("Content-Type", "")
145
+ response_data = await response.text(encoding="utf-8", errors="ignore")
146
+
147
+ if status_code in range(200, 300):
148
+ return method.response_serializer.from_json_code(response_data)
149
+ else:
150
+ message = f"HTTP status {status_code}"
151
+ if re.match(r"text/plain\b", content_type):
152
+ message = f"{message}: {response_data}"
153
+ raise RuntimeError(message)
154
+
155
+
156
+ class _AiohttpClientSession(Protocol):
157
+ def post(
158
+ self,
159
+ url: str,
160
+ *,
161
+ data: str,
162
+ headers: Mapping[str, str],
163
+ ) -> Any:
164
+ ...
@@ -676,7 +676,7 @@ def _make_from_json_fn(
676
676
  name = field.field.name
677
677
  lvalue = f"ret.{field.field.attribute}"
678
678
  builder.append_ln(f' if "{name}" in json:')
679
- builder.append_ln(f" array_len = {field.field.number}")
679
+ builder.append_ln(f" array_len = {field.field.number + 1}")
680
680
  builder.append_ln(
681
681
  f" {lvalue} = ",
682
682
  field.type.from_json_expr(f'json["{name}"]'),
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: soia-client
3
- Version: 1.0.22
3
+ Version: 1.0.24
4
4
  Author-email: Tyler Fibonacci <gepheum@gmail.com>
5
5
  License: MIT License
6
6
 
@@ -518,6 +518,7 @@ class ModuleInitializerTestCase(unittest.TestCase):
518
518
  point = point_cls.SERIALIZER.from_json_code('{"x":1,"y":2}')
519
519
  self.assertEqual(point.x, 1.0)
520
520
  self.assertIsInstance(point.x, float)
521
+ self.assertEqual(point._array_len, 3)
521
522
 
522
523
  def test_point_with_unrecognized_and_removed_fields(self):
523
524
  point_cls = self.init_test_module()["Point"]
File without changes
File without changes
File without changes
File without changes