runwayml 3.7.1__tar.gz → 3.8.0__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.
- {runwayml-3.7.1 → runwayml-3.8.0}/.gitignore +0 -1
- runwayml-3.8.0/.release-please-manifest.json +3 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/CHANGELOG.md +21 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/PKG-INFO +1 -1
- {runwayml-3.7.1 → runwayml-3.8.0}/pyproject.toml +1 -1
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_base_client.py +4 -1
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_files.py +4 -4
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_models.py +23 -2
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_version.py +1 -1
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_models.py +28 -1
- runwayml-3.7.1/.release-please-manifest.json +0 -3
- {runwayml-3.7.1 → runwayml-3.8.0}/CONTRIBUTING.md +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/LICENSE +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/README.md +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/SECURITY.md +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/api.md +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/bin/check-release-environment +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/bin/publish-pypi +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/examples/.keep +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/examples/generate_image.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/mypy.ini +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/noxfile.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/release-please-config.json +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/requirements-dev.lock +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/requirements.lock +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/__init__.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_client.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_compat.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_constants.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_exceptions.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_qs.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_resource.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_response.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_streaming.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_types.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/__init__.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_logs.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_proxy.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_reflection.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_resources_proxy.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_streams.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_sync.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_transform.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_typing.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_utils.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/lib/.keep +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/lib/polling.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/py.typed +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/__init__.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/character_performance.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/image_to_video.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/organization.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/tasks.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/text_to_image.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/video_upscale.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/__init__.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/character_performance_create_params.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/character_performance_create_response.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/image_to_video_create_params.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/image_to_video_create_response.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/organization_retrieve_response.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/organization_retrieve_usage_params.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/organization_retrieve_usage_response.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/task_retrieve_response.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/text_to_image_create_params.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/text_to_image_create_response.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/video_upscale_create_params.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/video_upscale_create_response.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/__init__.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/__init__.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/test_character_performance.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/test_image_to_video.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/test_organization.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/test_tasks.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/test_text_to_image.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/test_video_upscale.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/conftest.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/sample_file.txt +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_client.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_deepcopy.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_extract_files.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_files.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_qs.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_required_args.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_response.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_streaming.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_transform.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_utils/test_proxy.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_utils/test_typing.py +0 -0
- {runwayml-3.7.1 → runwayml-3.8.0}/tests/utils.py +0 -0
@@ -1,5 +1,26 @@
|
|
1
1
|
# Changelog
|
2
2
|
|
3
|
+
## 3.8.0 (2025-07-31)
|
4
|
+
|
5
|
+
Full Changelog: [v3.7.2...v3.8.0](https://github.com/runwayml/sdk-python/compare/v3.7.2...v3.8.0)
|
6
|
+
|
7
|
+
### Features
|
8
|
+
|
9
|
+
* **client:** support file upload requests ([9a12ee4](https://github.com/runwayml/sdk-python/commit/9a12ee479c6d796eaec598e33abf8e0664941cbb))
|
10
|
+
|
11
|
+
|
12
|
+
### Chores
|
13
|
+
|
14
|
+
* **project:** add settings file for vscode ([d2a3908](https://github.com/runwayml/sdk-python/commit/d2a3908101120d546238608608109960d9d9d0e1))
|
15
|
+
|
16
|
+
## 3.7.2 (2025-07-23)
|
17
|
+
|
18
|
+
Full Changelog: [v3.7.1...v3.7.2](https://github.com/runwayml/sdk-python/compare/v3.7.1...v3.7.2)
|
19
|
+
|
20
|
+
### Bug Fixes
|
21
|
+
|
22
|
+
* **parsing:** parse extra field types ([dc5dd24](https://github.com/runwayml/sdk-python/commit/dc5dd24d7ab7904c7c246ba7255c54c85e7dee40))
|
23
|
+
|
3
24
|
## 3.7.1 (2025-07-22)
|
4
25
|
|
5
26
|
Full Changelog: [v3.7.0...v3.7.1](https://github.com/runwayml/sdk-python/compare/v3.7.0...v3.7.1)
|
@@ -532,7 +532,10 @@ class BaseClient(Generic[_HttpxClientT, _DefaultStreamT]):
|
|
532
532
|
is_body_allowed = options.method.lower() != "get"
|
533
533
|
|
534
534
|
if is_body_allowed:
|
535
|
-
|
535
|
+
if isinstance(json_data, bytes):
|
536
|
+
kwargs["content"] = json_data
|
537
|
+
else:
|
538
|
+
kwargs["json"] = json_data if is_given(json_data) else None
|
536
539
|
kwargs["files"] = files
|
537
540
|
else:
|
538
541
|
headers.pop("Content-Type", None)
|
@@ -69,12 +69,12 @@ def _transform_file(file: FileTypes) -> HttpxFileTypes:
|
|
69
69
|
return file
|
70
70
|
|
71
71
|
if is_tuple_t(file):
|
72
|
-
return (file[0],
|
72
|
+
return (file[0], read_file_content(file[1]), *file[2:])
|
73
73
|
|
74
74
|
raise TypeError(f"Expected file types input to be a FileContent type or to be a tuple")
|
75
75
|
|
76
76
|
|
77
|
-
def
|
77
|
+
def read_file_content(file: FileContent) -> HttpxFileContent:
|
78
78
|
if isinstance(file, os.PathLike):
|
79
79
|
return pathlib.Path(file).read_bytes()
|
80
80
|
return file
|
@@ -111,12 +111,12 @@ async def _async_transform_file(file: FileTypes) -> HttpxFileTypes:
|
|
111
111
|
return file
|
112
112
|
|
113
113
|
if is_tuple_t(file):
|
114
|
-
return (file[0], await
|
114
|
+
return (file[0], await async_read_file_content(file[1]), *file[2:])
|
115
115
|
|
116
116
|
raise TypeError(f"Expected file types input to be a FileContent type or to be a tuple")
|
117
117
|
|
118
118
|
|
119
|
-
async def
|
119
|
+
async def async_read_file_content(file: FileContent) -> HttpxFileContent:
|
120
120
|
if isinstance(file, os.PathLike):
|
121
121
|
return await anyio.Path(file).read_bytes()
|
122
122
|
|
@@ -208,14 +208,18 @@ class BaseModel(pydantic.BaseModel):
|
|
208
208
|
else:
|
209
209
|
fields_values[name] = field_get_default(field)
|
210
210
|
|
211
|
+
extra_field_type = _get_extra_fields_type(__cls)
|
212
|
+
|
211
213
|
_extra = {}
|
212
214
|
for key, value in values.items():
|
213
215
|
if key not in model_fields:
|
216
|
+
parsed = construct_type(value=value, type_=extra_field_type) if extra_field_type is not None else value
|
217
|
+
|
214
218
|
if PYDANTIC_V2:
|
215
|
-
_extra[key] =
|
219
|
+
_extra[key] = parsed
|
216
220
|
else:
|
217
221
|
_fields_set.add(key)
|
218
|
-
fields_values[key] =
|
222
|
+
fields_values[key] = parsed
|
219
223
|
|
220
224
|
object.__setattr__(m, "__dict__", fields_values)
|
221
225
|
|
@@ -370,6 +374,23 @@ def _construct_field(value: object, field: FieldInfo, key: str) -> object:
|
|
370
374
|
return construct_type(value=value, type_=type_, metadata=getattr(field, "metadata", None))
|
371
375
|
|
372
376
|
|
377
|
+
def _get_extra_fields_type(cls: type[pydantic.BaseModel]) -> type | None:
|
378
|
+
if not PYDANTIC_V2:
|
379
|
+
# TODO
|
380
|
+
return None
|
381
|
+
|
382
|
+
schema = cls.__pydantic_core_schema__
|
383
|
+
if schema["type"] == "model":
|
384
|
+
fields = schema["schema"]
|
385
|
+
if fields["type"] == "model-fields":
|
386
|
+
extras = fields.get("extras_schema")
|
387
|
+
if extras and "cls" in extras:
|
388
|
+
# mypy can't narrow the type
|
389
|
+
return extras["cls"] # type: ignore[no-any-return]
|
390
|
+
|
391
|
+
return None
|
392
|
+
|
393
|
+
|
373
394
|
def is_basemodel(type_: type) -> bool:
|
374
395
|
"""Returns whether or not the given type is either a `BaseModel` or a union of `BaseModel`"""
|
375
396
|
if is_union(type_):
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import json
|
2
|
-
from typing import Any, Dict, List, Union, Optional, cast
|
2
|
+
from typing import TYPE_CHECKING, Any, Dict, List, Union, Optional, cast
|
3
3
|
from datetime import datetime, timezone
|
4
4
|
from typing_extensions import Literal, Annotated, TypeAliasType
|
5
5
|
|
@@ -934,3 +934,30 @@ def test_nested_discriminated_union() -> None:
|
|
934
934
|
)
|
935
935
|
assert isinstance(model, Type1)
|
936
936
|
assert isinstance(model.value, InnerType2)
|
937
|
+
|
938
|
+
|
939
|
+
@pytest.mark.skipif(not PYDANTIC_V2, reason="this is only supported in pydantic v2 for now")
|
940
|
+
def test_extra_properties() -> None:
|
941
|
+
class Item(BaseModel):
|
942
|
+
prop: int
|
943
|
+
|
944
|
+
class Model(BaseModel):
|
945
|
+
__pydantic_extra__: Dict[str, Item] = Field(init=False) # pyright: ignore[reportIncompatibleVariableOverride]
|
946
|
+
|
947
|
+
other: str
|
948
|
+
|
949
|
+
if TYPE_CHECKING:
|
950
|
+
|
951
|
+
def __getattr__(self, attr: str) -> Item: ...
|
952
|
+
|
953
|
+
model = construct_type(
|
954
|
+
type_=Model,
|
955
|
+
value={
|
956
|
+
"a": {"prop": 1},
|
957
|
+
"other": "foo",
|
958
|
+
},
|
959
|
+
)
|
960
|
+
assert isinstance(model, Model)
|
961
|
+
assert model.a.prop == 1
|
962
|
+
assert isinstance(model.a, Item)
|
963
|
+
assert model.other == "foo"
|
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
|
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
|
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
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/character_performance_create_response.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/organization_retrieve_usage_response.py
RENAMED
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
|
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
|
File without changes
|
File without changes
|