runwayml 3.0.0__py3-none-any.whl → 3.0.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.
- runwayml/_base_client.py +40 -2
- runwayml/_models.py +0 -1
- runwayml/_utils/_transform.py +24 -1
- runwayml/_utils/_typing.py +3 -1
- runwayml/_version.py +1 -1
- {runwayml-3.0.0.dist-info → runwayml-3.0.2.dist-info}/METADATA +1 -1
- {runwayml-3.0.0.dist-info → runwayml-3.0.2.dist-info}/RECORD +9 -9
- {runwayml-3.0.0.dist-info → runwayml-3.0.2.dist-info}/WHEEL +0 -0
- {runwayml-3.0.0.dist-info → runwayml-3.0.2.dist-info}/licenses/LICENSE +0 -0
runwayml/_base_client.py
CHANGED
@@ -98,7 +98,11 @@ _StreamT = TypeVar("_StreamT", bound=Stream[Any])
|
|
98
98
|
_AsyncStreamT = TypeVar("_AsyncStreamT", bound=AsyncStream[Any])
|
99
99
|
|
100
100
|
if TYPE_CHECKING:
|
101
|
-
from httpx._config import
|
101
|
+
from httpx._config import (
|
102
|
+
DEFAULT_TIMEOUT_CONFIG, # pyright: ignore[reportPrivateImportUsage]
|
103
|
+
)
|
104
|
+
|
105
|
+
HTTPX_DEFAULT_TIMEOUT = DEFAULT_TIMEOUT_CONFIG
|
102
106
|
else:
|
103
107
|
try:
|
104
108
|
from httpx._config import DEFAULT_TIMEOUT_CONFIG as HTTPX_DEFAULT_TIMEOUT
|
@@ -115,6 +119,7 @@ class PageInfo:
|
|
115
119
|
|
116
120
|
url: URL | NotGiven
|
117
121
|
params: Query | NotGiven
|
122
|
+
json: Body | NotGiven
|
118
123
|
|
119
124
|
@overload
|
120
125
|
def __init__(
|
@@ -130,19 +135,30 @@ class PageInfo:
|
|
130
135
|
params: Query,
|
131
136
|
) -> None: ...
|
132
137
|
|
138
|
+
@overload
|
139
|
+
def __init__(
|
140
|
+
self,
|
141
|
+
*,
|
142
|
+
json: Body,
|
143
|
+
) -> None: ...
|
144
|
+
|
133
145
|
def __init__(
|
134
146
|
self,
|
135
147
|
*,
|
136
148
|
url: URL | NotGiven = NOT_GIVEN,
|
149
|
+
json: Body | NotGiven = NOT_GIVEN,
|
137
150
|
params: Query | NotGiven = NOT_GIVEN,
|
138
151
|
) -> None:
|
139
152
|
self.url = url
|
153
|
+
self.json = json
|
140
154
|
self.params = params
|
141
155
|
|
142
156
|
@override
|
143
157
|
def __repr__(self) -> str:
|
144
158
|
if self.url:
|
145
159
|
return f"{self.__class__.__name__}(url={self.url})"
|
160
|
+
if self.json:
|
161
|
+
return f"{self.__class__.__name__}(json={self.json})"
|
146
162
|
return f"{self.__class__.__name__}(params={self.params})"
|
147
163
|
|
148
164
|
|
@@ -191,6 +207,19 @@ class BasePage(GenericModel, Generic[_T]):
|
|
191
207
|
options.url = str(url)
|
192
208
|
return options
|
193
209
|
|
210
|
+
if not isinstance(info.json, NotGiven):
|
211
|
+
if not is_mapping(info.json):
|
212
|
+
raise TypeError("Pagination is only supported with mappings")
|
213
|
+
|
214
|
+
if not options.json_data:
|
215
|
+
options.json_data = {**info.json}
|
216
|
+
else:
|
217
|
+
if not is_mapping(options.json_data):
|
218
|
+
raise TypeError("Pagination is only supported with mappings")
|
219
|
+
|
220
|
+
options.json_data = {**options.json_data, **info.json}
|
221
|
+
return options
|
222
|
+
|
194
223
|
raise ValueError("Unexpected PageInfo state")
|
195
224
|
|
196
225
|
|
@@ -409,7 +438,8 @@ class BaseClient(Generic[_HttpxClientT, _DefaultStreamT]):
|
|
409
438
|
|
410
439
|
idempotency_header = self._idempotency_header
|
411
440
|
if idempotency_header and options.method.lower() != "get" and idempotency_header not in headers:
|
412
|
-
|
441
|
+
options.idempotency_key = options.idempotency_key or self._idempotency_key()
|
442
|
+
headers[idempotency_header] = options.idempotency_key
|
413
443
|
|
414
444
|
# Don't set these headers if they were already set or removed by the caller. We check
|
415
445
|
# `custom_headers`, which can contain `Omit()`, instead of `headers` to account for the removal case.
|
@@ -943,6 +973,10 @@ class SyncAPIClient(BaseClient[httpx.Client, Stream[Any]]):
|
|
943
973
|
request = self._build_request(options, retries_taken=retries_taken)
|
944
974
|
self._prepare_request(request)
|
945
975
|
|
976
|
+
if options.idempotency_key:
|
977
|
+
# ensure the idempotency key is reused between requests
|
978
|
+
input_options.idempotency_key = options.idempotency_key
|
979
|
+
|
946
980
|
kwargs: HttpxSendArgs = {}
|
947
981
|
if self.custom_auth is not None:
|
948
982
|
kwargs["auth"] = self.custom_auth
|
@@ -1475,6 +1509,10 @@ class AsyncAPIClient(BaseClient[httpx.AsyncClient, AsyncStream[Any]]):
|
|
1475
1509
|
request = self._build_request(options, retries_taken=retries_taken)
|
1476
1510
|
await self._prepare_request(request)
|
1477
1511
|
|
1512
|
+
if options.idempotency_key:
|
1513
|
+
# ensure the idempotency key is reused between requests
|
1514
|
+
input_options.idempotency_key = options.idempotency_key
|
1515
|
+
|
1478
1516
|
kwargs: HttpxSendArgs = {}
|
1479
1517
|
if self.custom_auth is not None:
|
1480
1518
|
kwargs["auth"] = self.custom_auth
|
runwayml/_models.py
CHANGED
runwayml/_utils/_transform.py
CHANGED
@@ -5,13 +5,15 @@ import base64
|
|
5
5
|
import pathlib
|
6
6
|
from typing import Any, Mapping, TypeVar, cast
|
7
7
|
from datetime import date, datetime
|
8
|
-
from typing_extensions import Literal, get_args, override, get_type_hints
|
8
|
+
from typing_extensions import Literal, get_args, override, get_type_hints as _get_type_hints
|
9
9
|
|
10
10
|
import anyio
|
11
11
|
import pydantic
|
12
12
|
|
13
13
|
from ._utils import (
|
14
14
|
is_list,
|
15
|
+
is_given,
|
16
|
+
lru_cache,
|
15
17
|
is_mapping,
|
16
18
|
is_iterable,
|
17
19
|
)
|
@@ -108,6 +110,7 @@ def transform(
|
|
108
110
|
return cast(_T, transformed)
|
109
111
|
|
110
112
|
|
113
|
+
@lru_cache(maxsize=8096)
|
111
114
|
def _get_annotated_type(type_: type) -> type | None:
|
112
115
|
"""If the given type is an `Annotated` type then it is returned, if not `None` is returned.
|
113
116
|
|
@@ -258,6 +261,11 @@ def _transform_typeddict(
|
|
258
261
|
result: dict[str, object] = {}
|
259
262
|
annotations = get_type_hints(expected_type, include_extras=True)
|
260
263
|
for key, value in data.items():
|
264
|
+
if not is_given(value):
|
265
|
+
# we don't need to include `NotGiven` values here as they'll
|
266
|
+
# be stripped out before the request is sent anyway
|
267
|
+
continue
|
268
|
+
|
261
269
|
type_ = annotations.get(key)
|
262
270
|
if type_ is None:
|
263
271
|
# we do not have a type annotation for this field, leave it as is
|
@@ -415,6 +423,11 @@ async def _async_transform_typeddict(
|
|
415
423
|
result: dict[str, object] = {}
|
416
424
|
annotations = get_type_hints(expected_type, include_extras=True)
|
417
425
|
for key, value in data.items():
|
426
|
+
if not is_given(value):
|
427
|
+
# we don't need to include `NotGiven` values here as they'll
|
428
|
+
# be stripped out before the request is sent anyway
|
429
|
+
continue
|
430
|
+
|
418
431
|
type_ = annotations.get(key)
|
419
432
|
if type_ is None:
|
420
433
|
# we do not have a type annotation for this field, leave it as is
|
@@ -422,3 +435,13 @@ async def _async_transform_typeddict(
|
|
422
435
|
else:
|
423
436
|
result[_maybe_transform_key(key, type_)] = await _async_transform_recursive(value, annotation=type_)
|
424
437
|
return result
|
438
|
+
|
439
|
+
|
440
|
+
@lru_cache(maxsize=8096)
|
441
|
+
def get_type_hints(
|
442
|
+
obj: Any,
|
443
|
+
globalns: dict[str, Any] | None = None,
|
444
|
+
localns: Mapping[str, Any] | None = None,
|
445
|
+
include_extras: bool = False,
|
446
|
+
) -> dict[str, Any]:
|
447
|
+
return _get_type_hints(obj, globalns=globalns, localns=localns, include_extras=include_extras)
|
runwayml/_utils/_typing.py
CHANGED
@@ -13,6 +13,7 @@ from typing_extensions import (
|
|
13
13
|
get_origin,
|
14
14
|
)
|
15
15
|
|
16
|
+
from ._utils import lru_cache
|
16
17
|
from .._types import InheritsGeneric
|
17
18
|
from .._compat import is_union as _is_union
|
18
19
|
|
@@ -66,6 +67,7 @@ def is_type_alias_type(tp: Any, /) -> TypeIs[typing_extensions.TypeAliasType]:
|
|
66
67
|
|
67
68
|
|
68
69
|
# Extracts T from Annotated[T, ...] or from Required[Annotated[T, ...]]
|
70
|
+
@lru_cache(maxsize=8096)
|
69
71
|
def strip_annotated_type(typ: type) -> type:
|
70
72
|
if is_required_type(typ) or is_annotated_type(typ):
|
71
73
|
return strip_annotated_type(cast(type, get_args(typ)[0]))
|
@@ -108,7 +110,7 @@ def extract_type_var_from_base(
|
|
108
110
|
```
|
109
111
|
"""
|
110
112
|
cls = cast(object, get_origin(typ) or typ)
|
111
|
-
if cls in generic_bases:
|
113
|
+
if cls in generic_bases: # pyright: ignore[reportUnnecessaryContains]
|
112
114
|
# we're given the class directly
|
113
115
|
return extract_type_arg(typ, index)
|
114
116
|
|
runwayml/_version.py
CHANGED
@@ -1,17 +1,17 @@
|
|
1
1
|
runwayml/__init__.py,sha256=iXnJfH73wbj9IxfCHpwfWBxgOa9C4FRrrbBZM5f3biw,2476
|
2
|
-
runwayml/_base_client.py,sha256=
|
2
|
+
runwayml/_base_client.py,sha256=3ELTaBPe0-UwldzM1dKETvVBba-XCEPF9w8Rrr0c6DU,66246
|
3
3
|
runwayml/_client.py,sha256=oUOh2gdY1YtVefv51GTssitaCuDQIncvVlxTvzDJyec,17136
|
4
4
|
runwayml/_compat.py,sha256=VWemUKbj6DDkQ-O4baSpHVLJafotzeXmCQGJugfVTIw,6580
|
5
5
|
runwayml/_constants.py,sha256=S14PFzyN9-I31wiV7SmIlL5Ga0MLHxdvegInGdXH7tM,462
|
6
6
|
runwayml/_exceptions.py,sha256=p2Q8kywHCVQzArLQL4Ht-HetTBhAvevU6yDvEq7PpIE,3224
|
7
7
|
runwayml/_files.py,sha256=mf4dOgL4b0ryyZlbqLhggD3GVgDf6XxdGFAgce01ugE,3549
|
8
|
-
runwayml/_models.py,sha256=
|
8
|
+
runwayml/_models.py,sha256=q-l1tes71l6z-D5ffu9-G4UigTVVeJwiwIzA_gO4RFo,29045
|
9
9
|
runwayml/_qs.py,sha256=AOkSz4rHtK4YI3ZU_kzea-zpwBUgEY8WniGmTPyEimc,4846
|
10
10
|
runwayml/_resource.py,sha256=BF-j3xY5eRTKmuTxg8eDhLtLP4MLB1phDh_B6BKipKA,1112
|
11
11
|
runwayml/_response.py,sha256=3Tf7pmDYDMv5BJuF0ljEBtMMk5Q9T7jcWn7I6P-hbdM,28801
|
12
12
|
runwayml/_streaming.py,sha256=NSVuAgknVQWU1cgZEjQn01IdZKKynb5rOeYp5Lo-OEQ,10108
|
13
13
|
runwayml/_types.py,sha256=oHct1QQY_lI8bepCgfWDZm2N5VNi0e6o1iLeiTh4Y_0,6145
|
14
|
-
runwayml/_version.py,sha256=
|
14
|
+
runwayml/_version.py,sha256=e3bUSp3FFS0--Sj49tZWT_zFZktA99W6UJB8VrDSsaU,160
|
15
15
|
runwayml/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
16
16
|
runwayml/_utils/__init__.py,sha256=PNZ_QJuzZEgyYXqkO1HVhGkj5IU9bglVUcw7H-Knjzw,2062
|
17
17
|
runwayml/_utils/_logs.py,sha256=ZfS5W59hdqEBVV86lNrk28PhvUxtHOzs9JqiLhSu0pI,780
|
@@ -19,8 +19,8 @@ runwayml/_utils/_proxy.py,sha256=z3zsateHtb0EARTWKk8QZNHfPkqJbqwd1lM993LBwGE,190
|
|
19
19
|
runwayml/_utils/_reflection.py,sha256=ZmGkIgT_PuwedyNBrrKGbxoWtkpytJNU1uU4QHnmEMU,1364
|
20
20
|
runwayml/_utils/_streams.py,sha256=SMC90diFFecpEg_zgDRVbdR3hSEIgVVij4taD-noMLM,289
|
21
21
|
runwayml/_utils/_sync.py,sha256=TpGLrrhRNWTJtODNE6Fup3_k7zrWm1j2RlirzBwre-0,2862
|
22
|
-
runwayml/_utils/_transform.py,sha256=
|
23
|
-
runwayml/_utils/_typing.py,sha256=
|
22
|
+
runwayml/_utils/_transform.py,sha256=n7kskEWz6o__aoNvhFoGVyDoalNe6mJwp-g7BWkdj88,15617
|
23
|
+
runwayml/_utils/_typing.py,sha256=D0DbbNu8GnYQTSICnTSHDGsYXj8TcAKyhejb0XcnjtY,4602
|
24
24
|
runwayml/_utils/_utils.py,sha256=8UmbPOy_AAr2uUjjFui-VZSrVBHRj6bfNEKRp5YZP2A,12004
|
25
25
|
runwayml/lib/.keep,sha256=wuNrz-5SXo3jJaJOJgz4vFHM41YH_g20F5cRQo0vLes,224
|
26
26
|
runwayml/resources/__init__.py,sha256=SqcC1MLwxPaz2c7gRRBlOn9-2pDPMKTXD2gFbG5FJ2E,1597
|
@@ -32,7 +32,7 @@ runwayml/types/image_to_video_create_params.py,sha256=VNWGDEdqkhp-Br-19t8YYfaYMa
|
|
32
32
|
runwayml/types/image_to_video_create_response.py,sha256=l5GszzUSItV-ZYHCB8hH_GSVibUZEkzfRLrAhXkd8O4,346
|
33
33
|
runwayml/types/organization_retrieve_response.py,sha256=DV46yEIRjmL05uISc2-PpM5BGWu8gniA9TQ056abWLA,2721
|
34
34
|
runwayml/types/task_retrieve_response.py,sha256=v8y2bLxsW6srzScW-B3Akv72q_PI_NQmduGrGRQMHds,2139
|
35
|
-
runwayml-3.0.
|
36
|
-
runwayml-3.0.
|
37
|
-
runwayml-3.0.
|
38
|
-
runwayml-3.0.
|
35
|
+
runwayml-3.0.2.dist-info/METADATA,sha256=DwcgvLuTCeZS2a2pqMOIeVkPSJEOKYL0ILJ_zC-ZCkw,13516
|
36
|
+
runwayml-3.0.2.dist-info/WHEEL,sha256=C2FUgwZgiLbznR-k0b_5k3Ai_1aASOXDss3lzCUsUug,87
|
37
|
+
runwayml-3.0.2.dist-info/licenses/LICENSE,sha256=baeFj6izBWIm6A5_7N3-WAsy_VYpDF05Dd4zS1zsfZI,11338
|
38
|
+
runwayml-3.0.2.dist-info/RECORD,,
|
File without changes
|
File without changes
|