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.
Files changed (90) hide show
  1. {runwayml-3.7.1 → runwayml-3.8.0}/.gitignore +0 -1
  2. runwayml-3.8.0/.release-please-manifest.json +3 -0
  3. {runwayml-3.7.1 → runwayml-3.8.0}/CHANGELOG.md +21 -0
  4. {runwayml-3.7.1 → runwayml-3.8.0}/PKG-INFO +1 -1
  5. {runwayml-3.7.1 → runwayml-3.8.0}/pyproject.toml +1 -1
  6. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_base_client.py +4 -1
  7. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_files.py +4 -4
  8. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_models.py +23 -2
  9. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_version.py +1 -1
  10. {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_models.py +28 -1
  11. runwayml-3.7.1/.release-please-manifest.json +0 -3
  12. {runwayml-3.7.1 → runwayml-3.8.0}/CONTRIBUTING.md +0 -0
  13. {runwayml-3.7.1 → runwayml-3.8.0}/LICENSE +0 -0
  14. {runwayml-3.7.1 → runwayml-3.8.0}/README.md +0 -0
  15. {runwayml-3.7.1 → runwayml-3.8.0}/SECURITY.md +0 -0
  16. {runwayml-3.7.1 → runwayml-3.8.0}/api.md +0 -0
  17. {runwayml-3.7.1 → runwayml-3.8.0}/bin/check-release-environment +0 -0
  18. {runwayml-3.7.1 → runwayml-3.8.0}/bin/publish-pypi +0 -0
  19. {runwayml-3.7.1 → runwayml-3.8.0}/examples/.keep +0 -0
  20. {runwayml-3.7.1 → runwayml-3.8.0}/examples/generate_image.py +0 -0
  21. {runwayml-3.7.1 → runwayml-3.8.0}/mypy.ini +0 -0
  22. {runwayml-3.7.1 → runwayml-3.8.0}/noxfile.py +0 -0
  23. {runwayml-3.7.1 → runwayml-3.8.0}/release-please-config.json +0 -0
  24. {runwayml-3.7.1 → runwayml-3.8.0}/requirements-dev.lock +0 -0
  25. {runwayml-3.7.1 → runwayml-3.8.0}/requirements.lock +0 -0
  26. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/__init__.py +0 -0
  27. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_client.py +0 -0
  28. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_compat.py +0 -0
  29. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_constants.py +0 -0
  30. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_exceptions.py +0 -0
  31. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_qs.py +0 -0
  32. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_resource.py +0 -0
  33. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_response.py +0 -0
  34. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_streaming.py +0 -0
  35. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_types.py +0 -0
  36. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/__init__.py +0 -0
  37. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_logs.py +0 -0
  38. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_proxy.py +0 -0
  39. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_reflection.py +0 -0
  40. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_resources_proxy.py +0 -0
  41. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_streams.py +0 -0
  42. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_sync.py +0 -0
  43. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_transform.py +0 -0
  44. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_typing.py +0 -0
  45. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/_utils/_utils.py +0 -0
  46. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/lib/.keep +0 -0
  47. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/lib/polling.py +0 -0
  48. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/py.typed +0 -0
  49. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/__init__.py +0 -0
  50. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/character_performance.py +0 -0
  51. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/image_to_video.py +0 -0
  52. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/organization.py +0 -0
  53. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/tasks.py +0 -0
  54. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/text_to_image.py +0 -0
  55. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/resources/video_upscale.py +0 -0
  56. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/__init__.py +0 -0
  57. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/character_performance_create_params.py +0 -0
  58. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/character_performance_create_response.py +0 -0
  59. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/image_to_video_create_params.py +0 -0
  60. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/image_to_video_create_response.py +0 -0
  61. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/organization_retrieve_response.py +0 -0
  62. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/organization_retrieve_usage_params.py +0 -0
  63. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/organization_retrieve_usage_response.py +0 -0
  64. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/task_retrieve_response.py +0 -0
  65. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/text_to_image_create_params.py +0 -0
  66. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/text_to_image_create_response.py +0 -0
  67. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/video_upscale_create_params.py +0 -0
  68. {runwayml-3.7.1 → runwayml-3.8.0}/src/runwayml/types/video_upscale_create_response.py +0 -0
  69. {runwayml-3.7.1 → runwayml-3.8.0}/tests/__init__.py +0 -0
  70. {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/__init__.py +0 -0
  71. {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/test_character_performance.py +0 -0
  72. {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/test_image_to_video.py +0 -0
  73. {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/test_organization.py +0 -0
  74. {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/test_tasks.py +0 -0
  75. {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/test_text_to_image.py +0 -0
  76. {runwayml-3.7.1 → runwayml-3.8.0}/tests/api_resources/test_video_upscale.py +0 -0
  77. {runwayml-3.7.1 → runwayml-3.8.0}/tests/conftest.py +0 -0
  78. {runwayml-3.7.1 → runwayml-3.8.0}/tests/sample_file.txt +0 -0
  79. {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_client.py +0 -0
  80. {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_deepcopy.py +0 -0
  81. {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_extract_files.py +0 -0
  82. {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_files.py +0 -0
  83. {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_qs.py +0 -0
  84. {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_required_args.py +0 -0
  85. {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_response.py +0 -0
  86. {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_streaming.py +0 -0
  87. {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_transform.py +0 -0
  88. {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_utils/test_proxy.py +0 -0
  89. {runwayml-3.7.1 → runwayml-3.8.0}/tests/test_utils/test_typing.py +0 -0
  90. {runwayml-3.7.1 → runwayml-3.8.0}/tests/utils.py +0 -0
@@ -1,5 +1,4 @@
1
1
  .prism.log
2
- .vscode
3
2
  _dev
4
3
 
5
4
  __pycache__
@@ -0,0 +1,3 @@
1
+ {
2
+ ".": "3.8.0"
3
+ }
@@ -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)
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: runwayml
3
- Version: 3.7.1
3
+ Version: 3.8.0
4
4
  Summary: The official Python library for the runwayml API
5
5
  Project-URL: Homepage, https://github.com/runwayml/sdk-python
6
6
  Project-URL: Repository, https://github.com/runwayml/sdk-python
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "runwayml"
3
- version = "3.7.1"
3
+ version = "3.8.0"
4
4
  description = "The official Python library for the runwayml API"
5
5
  dynamic = ["readme"]
6
6
  license = "Apache-2.0"
@@ -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
- kwargs["json"] = json_data if is_given(json_data) else None
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], _read_file_content(file[1]), *file[2:])
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 _read_file_content(file: FileContent) -> HttpxFileContent:
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 _async_read_file_content(file[1]), *file[2:])
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 _async_read_file_content(file: FileContent) -> HttpxFileContent:
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] = value
219
+ _extra[key] = parsed
216
220
  else:
217
221
  _fields_set.add(key)
218
- fields_values[key] = value
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,4 +1,4 @@
1
1
  # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
2
 
3
3
  __title__ = "runwayml"
4
- __version__ = "3.7.1" # x-release-please-version
4
+ __version__ = "3.8.0" # x-release-please-version
@@ -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"
@@ -1,3 +0,0 @@
1
- {
2
- ".": "3.7.1"
3
- }
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