parallel-web 0.1.0__py3-none-any.whl → 0.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.

Potentially problematic release.


This version of parallel-web might be problematic. Click here for more details.

parallel/__init__.py CHANGED
@@ -1,5 +1,7 @@
1
1
  # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
2
 
3
+ import typing as _t
4
+
3
5
  from . import types
4
6
  from ._types import NOT_GIVEN, Omit, NoneType, NotGiven, Transport, ProxiesTypes
5
7
  from ._utils import file_from_path
@@ -78,6 +80,9 @@ __all__ = [
78
80
  "DefaultAsyncHttpxClient",
79
81
  ]
80
82
 
83
+ if not _t.TYPE_CHECKING:
84
+ from ._utils._resources_proxy import resources as resources
85
+
81
86
  _setup_logging()
82
87
 
83
88
  # Update the __module__ attribute for exported symbols so that
parallel/_base_client.py CHANGED
@@ -960,6 +960,9 @@ class SyncAPIClient(BaseClient[httpx.Client, Stream[Any]]):
960
960
  if self.custom_auth is not None:
961
961
  kwargs["auth"] = self.custom_auth
962
962
 
963
+ if options.follow_redirects is not None:
964
+ kwargs["follow_redirects"] = options.follow_redirects
965
+
963
966
  log.debug("Sending HTTP Request: %s %s", request.method, request.url)
964
967
 
965
968
  response = None
@@ -1068,7 +1071,14 @@ class SyncAPIClient(BaseClient[httpx.Client, Stream[Any]]):
1068
1071
  ) -> ResponseT:
1069
1072
  origin = get_origin(cast_to) or cast_to
1070
1073
 
1071
- if inspect.isclass(origin) and issubclass(origin, BaseAPIResponse):
1074
+ if (
1075
+ inspect.isclass(origin)
1076
+ and issubclass(origin, BaseAPIResponse)
1077
+ # we only want to actually return the custom BaseAPIResponse class if we're
1078
+ # returning the raw response, or if we're not streaming SSE, as if we're streaming
1079
+ # SSE then `cast_to` doesn't actively reflect the type we need to parse into
1080
+ and (not stream or bool(response.request.headers.get(RAW_RESPONSE_HEADER)))
1081
+ ):
1072
1082
  if not issubclass(origin, APIResponse):
1073
1083
  raise TypeError(f"API Response types must subclass {APIResponse}; Received {origin}")
1074
1084
 
@@ -1460,6 +1470,9 @@ class AsyncAPIClient(BaseClient[httpx.AsyncClient, AsyncStream[Any]]):
1460
1470
  if self.custom_auth is not None:
1461
1471
  kwargs["auth"] = self.custom_auth
1462
1472
 
1473
+ if options.follow_redirects is not None:
1474
+ kwargs["follow_redirects"] = options.follow_redirects
1475
+
1463
1476
  log.debug("Sending HTTP Request: %s %s", request.method, request.url)
1464
1477
 
1465
1478
  response = None
@@ -1568,7 +1581,14 @@ class AsyncAPIClient(BaseClient[httpx.AsyncClient, AsyncStream[Any]]):
1568
1581
  ) -> ResponseT:
1569
1582
  origin = get_origin(cast_to) or cast_to
1570
1583
 
1571
- if inspect.isclass(origin) and issubclass(origin, BaseAPIResponse):
1584
+ if (
1585
+ inspect.isclass(origin)
1586
+ and issubclass(origin, BaseAPIResponse)
1587
+ # we only want to actually return the custom BaseAPIResponse class if we're
1588
+ # returning the raw response, or if we're not streaming SSE, as if we're streaming
1589
+ # SSE then `cast_to` doesn't actively reflect the type we need to parse into
1590
+ and (not stream or bool(response.request.headers.get(RAW_RESPONSE_HEADER)))
1591
+ ):
1572
1592
  if not issubclass(origin, AsyncAPIResponse):
1573
1593
  raise TypeError(f"API Response types must subclass {AsyncAPIResponse}; Received {origin}")
1574
1594
 
parallel/_models.py CHANGED
@@ -737,6 +737,7 @@ class FinalRequestOptionsInput(TypedDict, total=False):
737
737
  idempotency_key: str
738
738
  json_data: Body
739
739
  extra_json: AnyMapping
740
+ follow_redirects: bool
740
741
 
741
742
 
742
743
  @final
@@ -750,6 +751,7 @@ class FinalRequestOptions(pydantic.BaseModel):
750
751
  files: Union[HttpxRequestFiles, None] = None
751
752
  idempotency_key: Union[str, None] = None
752
753
  post_parser: Union[Callable[[Any], Any], NotGiven] = NotGiven()
754
+ follow_redirects: Union[bool, None] = None
753
755
 
754
756
  # It should be noted that we cannot use `json` here as that would override
755
757
  # a BaseModel method in an incompatible fashion.
parallel/_types.py CHANGED
@@ -100,6 +100,7 @@ class RequestOptions(TypedDict, total=False):
100
100
  params: Query
101
101
  extra_json: AnyMapping
102
102
  idempotency_key: str
103
+ follow_redirects: bool
103
104
 
104
105
 
105
106
  # Sentinel class used until PEP 0661 is accepted
@@ -215,3 +216,4 @@ class _GenericAlias(Protocol):
215
216
 
216
217
  class HttpxSendArgs(TypedDict, total=False):
217
218
  auth: httpx.Auth
219
+ follow_redirects: bool
parallel/_utils/_proxy.py CHANGED
@@ -46,7 +46,10 @@ class LazyProxy(Generic[T], ABC):
46
46
  @property # type: ignore
47
47
  @override
48
48
  def __class__(self) -> type: # pyright: ignore
49
- proxied = self.__get_proxied__()
49
+ try:
50
+ proxied = self.__get_proxied__()
51
+ except Exception:
52
+ return type(self)
50
53
  if issubclass(type(proxied), LazyProxy):
51
54
  return type(proxied)
52
55
  return proxied.__class__
@@ -0,0 +1,24 @@
1
+ from __future__ import annotations
2
+
3
+ from typing import Any
4
+ from typing_extensions import override
5
+
6
+ from ._proxy import LazyProxy
7
+
8
+
9
+ class ResourcesProxy(LazyProxy[Any]):
10
+ """A proxy for the `parallel.resources` module.
11
+
12
+ This is used so that we can lazily import `parallel.resources` only when
13
+ needed *and* so that users can just import `parallel` and reference `parallel.resources`
14
+ """
15
+
16
+ @override
17
+ def __load__(self) -> Any:
18
+ import importlib
19
+
20
+ mod = importlib.import_module("parallel.resources")
21
+ return mod
22
+
23
+
24
+ resources = ResourcesProxy().__as_proxied__()
parallel/_version.py CHANGED
@@ -1,4 +1,4 @@
1
1
  # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
2
 
3
3
  __title__ = "parallel"
4
- __version__ = "0.1.0" # x-release-please-version
4
+ __version__ = "0.1.2" # x-release-please-version
parallel/lib/_pydantic.py CHANGED
@@ -10,20 +10,22 @@ from .._compat import PYDANTIC_V2, model_json_schema
10
10
 
11
11
 
12
12
  def to_json_schema(
13
- model: type[pydantic.BaseModel] | pydantic.TypeAdapter[Any],
13
+ model_type: type[pydantic.BaseModel] | pydantic.TypeAdapter[Any],
14
14
  ) -> dict[str, Any]:
15
15
  """Convert a Pydantic model/type adapter to a JSON schema."""
16
- if inspect.isclass(model) and is_basemodel_type(model):
17
- return model_json_schema(model)
18
-
19
- if PYDANTIC_V2 and isinstance(model, pydantic.TypeAdapter):
20
- return model.json_schema()
21
-
22
- raise TypeError(f"Non BaseModel types are only supported with Pydantic v2 - {model}")
23
-
24
-
25
- def is_basemodel_type(typ: type | object) -> TypeGuard[type[pydantic.BaseModel]]:
26
- """Check if a type is a Pydantic BaseModel."""
27
- if not inspect.isclass(typ):
28
- return False
29
- return issubclass(typ, pydantic.BaseModel)
16
+ if is_basemodel_type(model_type):
17
+ schema = model_json_schema(model_type)
18
+ elif isinstance(model_type, pydantic.TypeAdapter):
19
+ if not PYDANTIC_V2:
20
+ raise TypeError(f"TypeAdapters are only supported with Pydantic v2 - {model_type}")
21
+ schema = model_type.json_schema()
22
+ else:
23
+ raise TypeError(f"Unsupported type: {model_type}")
24
+
25
+ # modify the schema to make it compatible with the API format
26
+ schema["additionalProperties"] = False
27
+ return schema
28
+
29
+ def is_basemodel_type(model_type: object) -> TypeGuard[type[pydantic.BaseModel]]:
30
+ """Check if a type is a Pydantic BaseModel to avoid using type: ignore."""
31
+ return inspect.isclass(model_type) and issubclass(model_type, pydantic.BaseModel)
parallel/lib/_time.py CHANGED
@@ -28,6 +28,24 @@ def _raise_timeout(run_id: str, exc: Union[Exception, None]) -> NoReturn:
28
28
  raise TimeoutError(f"Fetching task run result for run id {run_id} timed out.") from exc
29
29
 
30
30
 
31
+ def _is_retryable_error(status_code: int) -> bool:
32
+ """Determine if an error is retryable.
33
+
34
+ We retry the following HTTP status codes within the SDK:
35
+ - 408 (Request Timeout): The server timed out waiting for the request
36
+ - 503 (Service Unavailable): The server is temporarily unable to handle the request
37
+ - 504 (Gateway Timeout): The gateway server timed out
38
+
39
+ These errors typically indicate temporary issues with the server or network
40
+ that may resolve upon retry. We don't include 429 (Too Many Requests) as this
41
+ indicates rate limiting, which requires backing off rather than immediate retries.
42
+
43
+ Note: This is a low-level retry mechanism within the SDK. Customers may want to
44
+ implement their own retry logic at the application level for other error types.
45
+ """
46
+ return status_code in (408, 503, 504)
47
+
48
+
31
49
  @contextlib.contextmanager
32
50
  def timeout_retry_context(run_id: str, deadline: float) -> Iterator[None]:
33
51
  """Context manager for handling timeouts and retries when fetching task run results.
@@ -49,8 +67,7 @@ def timeout_retry_context(run_id: str, deadline: float) -> Iterator[None]:
49
67
  exc = e
50
68
  continue
51
69
  except APIStatusError as e:
52
- # retry on timeouts from the API
53
- if e.status_code == 408:
70
+ if _is_retryable_error(e.status_code):
54
71
  exc = e
55
72
  continue
56
73
  raise
@@ -42,7 +42,7 @@ class TaskRunResource(SyncAPIResource):
42
42
  This property can be used as a prefix for any HTTP method call to return
43
43
  the raw response object instead of the parsed content.
44
44
 
45
- For more information, see https://www.github.com/shapleyai/parallel-sdk-python#accessing-raw-response-data-eg-headers
45
+ For more information, see https://www.github.com/parallel-web/parallel-sdk-python#accessing-raw-response-data-eg-headers
46
46
  """
47
47
  return TaskRunResourceWithRawResponse(self)
48
48
 
@@ -51,7 +51,7 @@ class TaskRunResource(SyncAPIResource):
51
51
  """
52
52
  An alternative to `.with_raw_response` that doesn't eagerly read the response body.
53
53
 
54
- For more information, see https://www.github.com/shapleyai/parallel-sdk-python#with_streaming_response
54
+ For more information, see https://www.github.com/parallel-web/parallel-sdk-python#with_streaming_response
55
55
  """
56
56
  return TaskRunResourceWithStreamingResponse(self)
57
57
 
@@ -317,7 +317,7 @@ class AsyncTaskRunResource(AsyncAPIResource):
317
317
  This property can be used as a prefix for any HTTP method call to return
318
318
  the raw response object instead of the parsed content.
319
319
 
320
- For more information, see https://www.github.com/shapleyai/parallel-sdk-python#accessing-raw-response-data-eg-headers
320
+ For more information, see https://www.github.com/parallel-web/parallel-sdk-python#accessing-raw-response-data-eg-headers
321
321
  """
322
322
  return AsyncTaskRunResourceWithRawResponse(self)
323
323
 
@@ -326,7 +326,7 @@ class AsyncTaskRunResource(AsyncAPIResource):
326
326
  """
327
327
  An alternative to `.with_raw_response` that doesn't eagerly read the response body.
328
328
 
329
- For more information, see https://www.github.com/shapleyai/parallel-sdk-python#with_streaming_response
329
+ For more information, see https://www.github.com/parallel-web/parallel-sdk-python#with_streaming_response
330
330
  """
331
331
  return AsyncTaskRunResourceWithStreamingResponse(self)
332
332
 
@@ -29,12 +29,9 @@ class TaskRun(BaseModel):
29
29
  is_active: bool
30
30
  """Whether the run is currently active; i.e.
31
31
 
32
- status is one of {'queued', 'running', 'cancelling'}.
32
+ status is one of {'running', 'queued', 'cancelling'}.
33
33
  """
34
34
 
35
- message: Optional[str] = None
36
- """Human-readable status message for the run."""
37
-
38
35
  modified_at: Optional[str] = None
39
36
  """Timestamp of the last modification to the task, as an RFC 3339 string."""
40
37
 
@@ -1,9 +1,9 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: parallel-web
3
- Version: 0.1.0
3
+ Version: 0.1.2
4
4
  Summary: The official Python library for the Parallel API
5
- Project-URL: Homepage, https://github.com/shapleyai/parallel-sdk-python
6
- Project-URL: Repository, https://github.com/shapleyai/parallel-sdk-python
5
+ Project-URL: Homepage, https://github.com/parallel-web/parallel-sdk-python
6
+ Project-URL: Repository, https://github.com/parallel-web/parallel-sdk-python
7
7
  Author-email: Parallel <support@parallel.ai>
8
8
  License: MIT
9
9
  Classifier: Intended Audience :: Developers
@@ -31,7 +31,7 @@ Description-Content-Type: text/markdown
31
31
 
32
32
  # Parallel Python API library
33
33
 
34
- [![PyPI version](https://img.shields.io/pypi/v/parallel-web.svg)](https://pypi.org/project/parallel-web/)
34
+ [![PyPI version](https://github.com/parallel-web/parallel-sdk-python/tree/main/<https://img.shields.io/pypi/v/parallel-web.svg?label=pypi%20(stable)>)](https://pypi.org/project/parallel-web/)
35
35
 
36
36
  The Parallel Python library provides convenient access to the Parallel REST API from any Python 3.8+
37
37
  application. The library includes type definitions for all request params and response fields,
@@ -43,7 +43,7 @@ It is generated with [Stainless](https://www.stainless.com/).
43
43
  ## Documentation
44
44
 
45
45
  The REST API documentation can be found on our [docs](https://docs.parallel.ai).
46
- The full API of this Python library can be found in [api.md](https://github.com/shapleyai/parallel-sdk-python/tree/main/api.md).
46
+ The full API of this Python library can be found in [api.md](https://github.com/parallel-web/parallel-sdk-python/tree/main/api.md).
47
47
 
48
48
  ## Installation
49
49
 
@@ -54,7 +54,7 @@ pip install parallel-web
54
54
 
55
55
  ## Usage
56
56
 
57
- The full API of this library can be found in [api.md](https://github.com/shapleyai/parallel-sdk-python/tree/main/api.md).
57
+ The full API of this library can be found in [api.md](https://github.com/parallel-web/parallel-sdk-python/tree/main/api.md).
58
58
 
59
59
  ```python
60
60
  import os
@@ -223,15 +223,15 @@ from parallel.types import TaskSpecParam
223
223
  client = Parallel()
224
224
 
225
225
  task_run = client.task_run.create(
226
- input="France (2023)",
227
- processor="processor",
226
+ input={"country": "France", "year": 2023},
227
+ processor="core",
228
228
  task_spec={
229
229
  "output_schema": {
230
230
  "json_schema": {
231
231
  "additionalProperties": False,
232
232
  "properties": {
233
233
  "gdp": {
234
- "description": "GDP in USD for the year, formatted like '$3.1 trillion (2023)'",
234
+ "description": "GDP in USD for the year",
235
235
  "type": "string",
236
236
  }
237
237
  },
@@ -244,12 +244,16 @@ task_run = client.task_run.create(
244
244
  "json_schema": {
245
245
  "additionalProperties": False,
246
246
  "properties": {
247
- "gdp": {
248
- "description": "GDP in USD for the year, formatted like '$3.1 trillion (2023)'",
247
+ "country": {
248
+ "description": "Name of the country to research",
249
249
  "type": "string",
250
- }
250
+ },
251
+ "year": {
252
+ "description": "Year for which to retrieve information",
253
+ "type": "integer",
254
+ },
251
255
  },
252
- "required": ["gdp"],
256
+ "required": ["country", "year"],
253
257
  "type": "object",
254
258
  },
255
259
  "type": "json",
@@ -257,7 +261,7 @@ task_run = client.task_run.create(
257
261
  },
258
262
  )
259
263
 
260
- run_result = client.task_run.result(task_run.id)
264
+ run_result = client.task_run.result(task_run.run_id)
261
265
  print(run_result.output)
262
266
  ```
263
267
 
@@ -339,7 +343,7 @@ client.with_options(max_retries=5).task_run.execute(
339
343
  ### Timeouts
340
344
 
341
345
  By default requests time out after 1 minute. You can configure this with a `timeout` option,
342
- which accepts a float or an [`httpx.Timeout`](https://www.python-httpx.org/advanced/#fine-tuning-the-configuration) object:
346
+ which accepts a float or an [`httpx.Timeout`](https://www.python-httpx.org/advanced/timeouts/#fine-tuning-the-configuration) object:
343
347
 
344
348
  ```python
345
349
  from parallel import Parallel
@@ -365,7 +369,7 @@ client.with_options(timeout=5.0).task_run.execute(
365
369
 
366
370
  On timeout, an `APITimeoutError` is thrown.
367
371
 
368
- Note that requests that time out are [retried twice by default](https://github.com/shapleyai/parallel-sdk-python/tree/main/#retries).
372
+ Note that requests that time out are [retried twice by default](https://github.com/parallel-web/parallel-sdk-python/tree/main/#retries).
369
373
 
370
374
  ## Advanced
371
375
 
@@ -412,9 +416,9 @@ task_run = response.parse() # get the object that `task_run.execute()` would ha
412
416
  print(task_run.output)
413
417
  ```
414
418
 
415
- These methods return an [`APIResponse`](https://github.com/shapleyai/parallel-sdk-python/tree/main/src/parallel/_response.py) object.
419
+ These methods return an [`APIResponse`](https://github.com/parallel-web/parallel-sdk-python/tree/main/src/parallel/_response.py) object.
416
420
 
417
- The async client returns an [`AsyncAPIResponse`](https://github.com/shapleyai/parallel-sdk-python/tree/main/src/parallel/_response.py) with the same structure, the only difference being `await`able methods for reading the response content.
421
+ The async client returns an [`AsyncAPIResponse`](https://github.com/parallel-web/parallel-sdk-python/tree/main/src/parallel/_response.py) with the same structure, the only difference being `await`able methods for reading the response content.
418
422
 
419
423
  #### `.with_streaming_response`
420
424
 
@@ -522,7 +526,7 @@ This package generally follows [SemVer](https://semver.org/spec/v2.0.0.html) con
522
526
 
523
527
  We take backwards-compatibility seriously and work hard to ensure you can rely on a smooth upgrade experience.
524
528
 
525
- We are keen for your feedback; please open an [issue](https://www.github.com/shapleyai/parallel-sdk-python/issues) with questions, bugs, or suggestions.
529
+ We are keen for your feedback; please open an [issue](https://www.github.com/parallel-web/parallel-sdk-python/issues) with questions, bugs, or suggestions.
526
530
 
527
531
  ### Determining the installed version
528
532
 
@@ -541,4 +545,4 @@ Python 3.8 or higher.
541
545
 
542
546
  ## Contributing
543
547
 
544
- See [the contributing documentation](https://github.com/shapleyai/parallel-sdk-python/tree/main/./CONTRIBUTING.md).
548
+ See [the contributing documentation](https://github.com/parallel-web/parallel-sdk-python/tree/main/./CONTRIBUTING.md).
@@ -1,22 +1,23 @@
1
- parallel/__init__.py,sha256=45jJ0sRi-w409isfVygE4UsJ4yx4uAajWoaOUEtid0U,2476
2
- parallel/_base_client.py,sha256=DWE1Tf9a1m2Uuv3tk54JG0FVo6kGiS6EMvghRMRxqXg,64846
1
+ parallel/__init__.py,sha256=DLcZySDPIMWxygZrS91n0h7XUblDa7R2CKSqJCeBD-U,2587
2
+ parallel/_base_client.py,sha256=CvhCKe_bvHxjG_KkjU7MN8epnRjDAoZercR16F7hKXo,65886
3
3
  parallel/_client.py,sha256=-33nTbpzQe0MaMSXkPisZdlPG_phXweSGfssI4UXIKQ,15024
4
4
  parallel/_compat.py,sha256=Bdw3skNpgAyCAWXJRUwTLiM0lOD1sLHEFKtw7peWp5U,6981
5
5
  parallel/_constants.py,sha256=NJrT2b4m0CuDGEVBF1xwsrHOWLGPupleFrL9jGAlLwk,567
6
6
  parallel/_exceptions.py,sha256=lP7_D_HALN-Nt5bfw4AefEB7tYkrQ8ZcjCRdxm_HrsQ,3224
7
7
  parallel/_files.py,sha256=mf4dOgL4b0ryyZlbqLhggD3GVgDf6XxdGFAgce01ugE,3549
8
- parallel/_models.py,sha256=mB2r2VWQq49jG-F0RIXDrBxPp3v-Eg12wMOtVTNxtv4,29057
8
+ parallel/_models.py,sha256=G1vczEodX0vUySeVKbF-mbzlaObNL1oVAYH4c65agRk,29131
9
9
  parallel/_qs.py,sha256=AOkSz4rHtK4YI3ZU_kzea-zpwBUgEY8WniGmTPyEimc,4846
10
10
  parallel/_resource.py,sha256=QvY8l_r03hNBsFTTn3g7Pkx8OrDwIwROHaSEViWcYLA,1112
11
11
  parallel/_response.py,sha256=zJKnQ9YzrMZCTPWis4CdyGCAH0kzT4m1OHE74jiF0jA,28800
12
12
  parallel/_streaming.py,sha256=vH45vK3-83ruFalbvSgpE70zfwy8fjW9UwrO1TwjIfE,10108
13
- parallel/_types.py,sha256=sLRqW7zYEpLbSD4AuQ4UHoZoXMuu1p8hOq8LpwE69-k,6145
14
- parallel/_version.py,sha256=9X4SlrNWQKYPBlIjPqW5KAvoYD3JrSFlMBD_J44IF4E,160
13
+ parallel/_types.py,sha256=gdnumvz_C0ka1W865rehBsLCOgZyyHpKRedjJg7uRPY,6199
14
+ parallel/_version.py,sha256=WUXkK8O3I2gOafOqu7g-L_9WsH2ZQxqi0tbVT_oXd8k,160
15
15
  parallel/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
16
16
  parallel/_utils/__init__.py,sha256=Z5F2puD-cRsBEwlAuuuXDuIuKuJyLhtg0667MRHeBj4,2084
17
17
  parallel/_utils/_logs.py,sha256=5tqZJRHHRqxJfftED6vN1CHcwhRZDSvzy9SaxozEAe4,780
18
- parallel/_utils/_proxy.py,sha256=z3zsateHtb0EARTWKk8QZNHfPkqJbqwd1lM993LBwGE,1902
18
+ parallel/_utils/_proxy.py,sha256=aglnj2yBTDyGX9Akk2crZHrl10oqRmceUy2Zp008XEs,1975
19
19
  parallel/_utils/_reflection.py,sha256=ZmGkIgT_PuwedyNBrrKGbxoWtkpytJNU1uU4QHnmEMU,1364
20
+ parallel/_utils/_resources_proxy.py,sha256=xx_chZr_cBmnGMejQaqdjjzS6gjyOBjVARwb2lM7qm4,599
20
21
  parallel/_utils/_streams.py,sha256=SMC90diFFecpEg_zgDRVbdR3hSEIgVVij4taD-noMLM,289
21
22
  parallel/_utils/_sync.py,sha256=TpGLrrhRNWTJtODNE6Fup3_k7zrWm1j2RlirzBwre-0,2862
22
23
  parallel/_utils/_transform.py,sha256=n7kskEWz6o__aoNvhFoGVyDoalNe6mJwp-g7BWkdj88,15617
@@ -24,23 +25,23 @@ parallel/_utils/_typing.py,sha256=D0DbbNu8GnYQTSICnTSHDGsYXj8TcAKyhejb0XcnjtY,46
24
25
  parallel/_utils/_utils.py,sha256=nJWF6GJgM2imb1AYa1nZoE1f-Alo1EI0Y8L_q3a1gkw,12389
25
26
  parallel/lib/.keep,sha256=wuNrz-5SXo3jJaJOJgz4vFHM41YH_g20F5cRQo0vLes,224
26
27
  parallel/lib/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
27
- parallel/lib/_pydantic.py,sha256=90cesmaaPfF1CmlDVBDzFq4k1qciHTAwnWbHa159FwQ,886
28
- parallel/lib/_time.py,sha256=IoPTaxTh5bYaBqSH7zUSYoKfnfCX5G208xB9_s7BAn4,1726
28
+ parallel/lib/_pydantic.py,sha256=B_-msp3_jrPP09s-f73Xv4WEG212ECDfc0a_Gf-YZGE,1115
29
+ parallel/lib/_time.py,sha256=SAf1AP__EqprIPCqpe8JqfaB_rqv10uzhNBJbD_THSY,2542
29
30
  parallel/lib/_parsing/__init__.py,sha256=aEM9F2sU4s-CFpQgjydjfCAdxpusJ81jXI6KCoB8VPs,150
30
31
  parallel/lib/_parsing/_task_run_result.py,sha256=9o95RcH4bX0UbI7ow5bnECrXMS6Ll0SEQR4leTK3VQU,3608
31
32
  parallel/lib/_parsing/_task_spec.py,sha256=XkNWo2Ovu-anld8PAOIsi722vOXbDf2ex4p9rwWW51I,3067
32
33
  parallel/resources/__init__.py,sha256=jGILtGZMcUjnm_PAOAkggRZlretqp_r24lMj7qFWqIg,566
33
- parallel/resources/task_run.py,sha256=b0A5mh52CbYDJ6QeFJesCEDkeivwdX6E8TV6dsxDXaY,25315
34
+ parallel/resources/task_run.py,sha256=5FEtuqwYbR1Ict8s8zpkFHF6b0XGtgxVBxlnvKMfc0Y,25327
34
35
  parallel/types/__init__.py,sha256=7EXEF1xwgzRtPbtywm1_PnOzShi_mN3TfU8p_PErz5s,653
35
36
  parallel/types/json_schema_param.py,sha256=rn_85_uPZYkLYLZiM5erOuQ_trY4DcoB3XEpP4uvqyw,457
36
37
  parallel/types/parsed_task_run_result.py,sha256=Qw_QFQNmMcykdBKlMnx6hl5cua5wwv5BZEs3Oo3_5NE,1098
37
- parallel/types/task_run.py,sha256=kBC1pFRp4w9eTk2WVLE1e7QG85Zn6J_l5aJJoXqZtLU,1462
38
+ parallel/types/task_run.py,sha256=mdkBL1Ncvu5h2HeBSzF2vr7Q-ApOOStsZCeEwFl_uQA,1374
38
39
  parallel/types/task_run_create_params.py,sha256=kHEx3NInuAgTp5AebDHQIPyrqducGFUMV81Gtn7wtdI,957
39
40
  parallel/types/task_run_result.py,sha256=yd3Lz_YzCQGe5ynK5iI6J17tAs5nSG7FUJ3fSLOa7hM,3070
40
41
  parallel/types/task_run_result_params.py,sha256=tL4CK5c0-Wo21O1pmT4pDvwzG-svtEwYujyCp0ZgATs,360
41
42
  parallel/types/task_spec_param.py,sha256=qTENHBp7vRg-VDzK8HsLpTn3EJWIV0UVQaf45r9SfCs,1179
42
43
  parallel/types/text_schema_param.py,sha256=M9WEl2aOh4_hNSdGm2BOmtm1VGqxxTh3f-Hs4OB4aCQ,445
43
- parallel_web-0.1.0.dist-info/METADATA,sha256=H-ohJ34Ju20Os1LD1P6zU872ocIGgyYcYT23EfFlNUs,17361
44
- parallel_web-0.1.0.dist-info/WHEEL,sha256=C2FUgwZgiLbznR-k0b_5k3Ai_1aASOXDss3lzCUsUug,87
45
- parallel_web-0.1.0.dist-info/licenses/LICENSE,sha256=1rFsV0HhxaZBP55JM8Cu2w0Bw-uxTFtyTja_DE94oEM,1048
46
- parallel_web-0.1.0.dist-info/RECORD,,
44
+ parallel_web-0.1.2.dist-info/METADATA,sha256=f0gLsNP4XHVGgWeL88tVMkLzsd_Yw4e0I9as2DR5o0Y,17626
45
+ parallel_web-0.1.2.dist-info/WHEEL,sha256=C2FUgwZgiLbznR-k0b_5k3Ai_1aASOXDss3lzCUsUug,87
46
+ parallel_web-0.1.2.dist-info/licenses/LICENSE,sha256=1rFsV0HhxaZBP55JM8Cu2w0Bw-uxTFtyTja_DE94oEM,1048
47
+ parallel_web-0.1.2.dist-info/RECORD,,