modal 1.0.6.dev9__tar.gz → 1.0.6.dev11__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.

Potentially problematic release.


This version of modal might be problematic. Click here for more details.

Files changed (184) hide show
  1. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/PKG-INFO +1 -1
  2. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_functions.py +19 -1
  3. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/function_utils.py +4 -3
  4. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/client.pyi +2 -2
  5. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/functions.pyi +6 -6
  6. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/parallel_map.py +8 -1
  7. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal.egg-info/PKG-INFO +1 -1
  8. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/api.proto +9 -0
  9. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/api_grpc.py +16 -0
  10. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/api_pb2.py +711 -691
  11. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/api_pb2.pyi +31 -2
  12. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/api_pb2_grpc.py +33 -0
  13. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/api_pb2_grpc.pyi +10 -0
  14. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/modal_api_grpc.py +1 -0
  15. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_version/__init__.py +1 -1
  16. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/LICENSE +0 -0
  17. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/README.md +0 -0
  18. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/__init__.py +0 -0
  19. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/__main__.py +0 -0
  20. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_clustered_functions.py +0 -0
  21. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_clustered_functions.pyi +0 -0
  22. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_container_entrypoint.py +0 -0
  23. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_ipython.py +0 -0
  24. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_location.py +0 -0
  25. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_object.py +0 -0
  26. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_output.py +0 -0
  27. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_partial_function.py +0 -0
  28. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_pty.py +0 -0
  29. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_resolver.py +0 -0
  30. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_resources.py +0 -0
  31. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_runtime/__init__.py +0 -0
  32. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_runtime/asgi.py +0 -0
  33. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_runtime/container_io_manager.py +0 -0
  34. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_runtime/container_io_manager.pyi +0 -0
  35. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_runtime/execution_context.py +0 -0
  36. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_runtime/execution_context.pyi +0 -0
  37. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_runtime/gpu_memory_snapshot.py +0 -0
  38. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_runtime/telemetry.py +0 -0
  39. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_runtime/user_code_imports.py +0 -0
  40. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_serialization.py +0 -0
  41. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_traceback.py +0 -0
  42. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_tunnel.py +0 -0
  43. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_tunnel.pyi +0 -0
  44. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_type_manager.py +0 -0
  45. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/__init__.py +0 -0
  46. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/app_utils.py +0 -0
  47. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/async_utils.py +0 -0
  48. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/blob_utils.py +0 -0
  49. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/bytes_io_segment_payload.py +0 -0
  50. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/deprecation.py +0 -0
  51. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/docker_utils.py +0 -0
  52. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/git_utils.py +0 -0
  53. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/grpc_testing.py +0 -0
  54. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/grpc_utils.py +0 -0
  55. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/hash_utils.py +0 -0
  56. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/http_utils.py +0 -0
  57. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/jwt_utils.py +0 -0
  58. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/logger.py +0 -0
  59. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/mount_utils.py +0 -0
  60. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/name_utils.py +0 -0
  61. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/package_utils.py +0 -0
  62. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/pattern_utils.py +0 -0
  63. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/rand_pb_testing.py +0 -0
  64. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/shell_utils.py +0 -0
  65. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_utils/time_utils.py +0 -0
  66. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_vendor/__init__.py +0 -0
  67. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_vendor/a2wsgi_wsgi.py +0 -0
  68. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_vendor/cloudpickle.py +0 -0
  69. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_vendor/tblib.py +0 -0
  70. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/_watcher.py +0 -0
  71. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/app.py +0 -0
  72. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/app.pyi +0 -0
  73. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/call_graph.py +0 -0
  74. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/__init__.py +0 -0
  75. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/_download.py +0 -0
  76. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/_traceback.py +0 -0
  77. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/app.py +0 -0
  78. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/cluster.py +0 -0
  79. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/config.py +0 -0
  80. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/container.py +0 -0
  81. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/dict.py +0 -0
  82. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/entry_point.py +0 -0
  83. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/environment.py +0 -0
  84. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/import_refs.py +0 -0
  85. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/launch.py +0 -0
  86. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/network_file_system.py +0 -0
  87. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/profile.py +0 -0
  88. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/programs/__init__.py +0 -0
  89. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/programs/run_jupyter.py +0 -0
  90. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/programs/vscode.py +0 -0
  91. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/queues.py +0 -0
  92. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/run.py +0 -0
  93. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/secret.py +0 -0
  94. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/token.py +0 -0
  95. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/utils.py +0 -0
  96. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cli/volume.py +0 -0
  97. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/client.py +0 -0
  98. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cloud_bucket_mount.py +0 -0
  99. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cloud_bucket_mount.pyi +0 -0
  100. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cls.py +0 -0
  101. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/cls.pyi +0 -0
  102. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/config.py +0 -0
  103. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/container_process.py +0 -0
  104. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/container_process.pyi +0 -0
  105. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/dict.py +0 -0
  106. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/dict.pyi +0 -0
  107. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/environments.py +0 -0
  108. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/environments.pyi +0 -0
  109. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/exception.py +0 -0
  110. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/experimental/__init__.py +0 -0
  111. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/experimental/ipython.py +0 -0
  112. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/file_io.py +0 -0
  113. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/file_io.pyi +0 -0
  114. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/file_pattern_matcher.py +0 -0
  115. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/functions.py +0 -0
  116. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/gpu.py +0 -0
  117. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/image.py +0 -0
  118. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/image.pyi +0 -0
  119. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/io_streams.py +0 -0
  120. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/io_streams.pyi +0 -0
  121. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/mount.py +0 -0
  122. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/mount.pyi +0 -0
  123. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/network_file_system.py +0 -0
  124. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/network_file_system.pyi +0 -0
  125. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/object.py +0 -0
  126. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/object.pyi +0 -0
  127. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/output.py +0 -0
  128. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/parallel_map.pyi +0 -0
  129. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/partial_function.py +0 -0
  130. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/partial_function.pyi +0 -0
  131. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/proxy.py +0 -0
  132. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/proxy.pyi +0 -0
  133. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/py.typed +0 -0
  134. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/queue.py +0 -0
  135. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/queue.pyi +0 -0
  136. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/requirements/2023.12.312.txt +0 -0
  137. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/requirements/2023.12.txt +0 -0
  138. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/requirements/2024.04.txt +0 -0
  139. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/requirements/2024.10.txt +0 -0
  140. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/requirements/PREVIEW.txt +0 -0
  141. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/requirements/README.md +0 -0
  142. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/requirements/base-images.json +0 -0
  143. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/retries.py +0 -0
  144. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/runner.py +0 -0
  145. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/runner.pyi +0 -0
  146. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/running_app.py +0 -0
  147. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/sandbox.py +0 -0
  148. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/sandbox.pyi +0 -0
  149. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/schedule.py +0 -0
  150. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/scheduler_placement.py +0 -0
  151. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/secret.py +0 -0
  152. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/secret.pyi +0 -0
  153. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/serving.py +0 -0
  154. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/serving.pyi +0 -0
  155. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/snapshot.py +0 -0
  156. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/snapshot.pyi +0 -0
  157. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/stream_type.py +0 -0
  158. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/token_flow.py +0 -0
  159. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/token_flow.pyi +0 -0
  160. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/volume.py +0 -0
  161. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal/volume.pyi +0 -0
  162. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal.egg-info/SOURCES.txt +0 -0
  163. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal.egg-info/dependency_links.txt +0 -0
  164. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal.egg-info/entry_points.txt +0 -0
  165. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal.egg-info/requires.txt +0 -0
  166. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal.egg-info/top_level.txt +0 -0
  167. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_docs/__init__.py +0 -0
  168. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_docs/gen_cli_docs.py +0 -0
  169. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_docs/gen_reference_docs.py +0 -0
  170. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_docs/mdmd/__init__.py +0 -0
  171. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_docs/mdmd/mdmd.py +0 -0
  172. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_docs/mdmd/signatures.py +0 -0
  173. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/__init__.py +0 -0
  174. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/modal_options_grpc.py +0 -0
  175. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/options.proto +0 -0
  176. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/options_grpc.py +0 -0
  177. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/options_pb2.py +0 -0
  178. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/options_pb2.pyi +0 -0
  179. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/options_pb2_grpc.py +0 -0
  180. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/options_pb2_grpc.pyi +0 -0
  181. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_proto/py.typed +0 -0
  182. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/modal_version/__main__.py +0 -0
  183. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/pyproject.toml +0 -0
  184. {modal-1.0.6.dev9 → modal-1.0.6.dev11}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: modal
3
- Version: 1.0.6.dev9
3
+ Version: 1.0.6.dev11
4
4
  Summary: Python client library for Modal
5
5
  Author-email: Modal Labs <support@modal.com>
6
6
  License: Apache-2.0
@@ -40,6 +40,7 @@ from ._utils.async_utils import (
40
40
  synchronizer,
41
41
  warn_if_generator_is_not_consumed,
42
42
  )
43
+ from ._utils.blob_utils import MAX_OBJECT_SIZE_BYTES
43
44
  from ._utils.deprecation import deprecation_warning, warn_if_passing_namespace
44
45
  from ._utils.function_utils import (
45
46
  ATTEMPT_TIMEOUT_GRACE_PERIOD,
@@ -145,6 +146,7 @@ class _Invocation:
145
146
  args,
146
147
  kwargs,
147
148
  stub,
149
+ max_object_size_bytes=function._max_object_size_bytes,
148
150
  method_name=function._use_method_name,
149
151
  function_call_invocation_type=function_call_invocation_type,
150
152
  )
@@ -386,7 +388,13 @@ class _InputPlaneInvocation:
386
388
  function_id = function.object_id
387
389
  control_plane_stub = client.stub
388
390
  # Note: Blob upload is done on the control plane stub, not the input plane stub!
389
- input_item = await _create_input(args, kwargs, control_plane_stub, method_name=function._use_method_name)
391
+ input_item = await _create_input(
392
+ args,
393
+ kwargs,
394
+ control_plane_stub,
395
+ max_object_size_bytes=function._max_object_size_bytes,
396
+ method_name=function._use_method_name,
397
+ )
390
398
 
391
399
  request = api_pb2.AttemptStartRequest(
392
400
  function_id=function_id,
@@ -1414,6 +1422,15 @@ class _Function(typing.Generic[P, ReturnType, OriginalReturnType], _Object, type
1414
1422
  self._definition_id = metadata.definition_id
1415
1423
  self._input_plane_url = metadata.input_plane_url
1416
1424
  self._input_plane_region = metadata.input_plane_region
1425
+ # The server may pass back a larger max object size for some input plane users. This applies to input plane
1426
+ # users only - anyone using the control plane will get the standard limit.
1427
+ # There are some cases like FunctionPrecreate where this value is not set at all. We expect that this field
1428
+ # will eventually be hydrated with the correct value, but just to be defensive, if the field is not set we use
1429
+ # MAX_OBJECT_SIZE_BYTES, otherwise it would get set to 0. Accidentally using 0 would cause us to blob upload
1430
+ # everything, so let's avoid that.
1431
+ self._max_object_size_bytes = (
1432
+ metadata.max_object_size_bytes if metadata.HasField("max_object_size_bytes") else MAX_OBJECT_SIZE_BYTES
1433
+ )
1417
1434
 
1418
1435
  def _get_metadata(self):
1419
1436
  # Overridden concrete implementation of base class method
@@ -1430,6 +1447,7 @@ class _Function(typing.Generic[P, ReturnType, OriginalReturnType], _Object, type
1430
1447
  function_schema=self._metadata.function_schema if self._metadata else None,
1431
1448
  input_plane_url=self._input_plane_url,
1432
1449
  input_plane_region=self._input_plane_region,
1450
+ max_object_size_bytes=self._max_object_size_bytes,
1433
1451
  )
1434
1452
 
1435
1453
  def _check_no_web_url(self, fn_name: str):
@@ -34,7 +34,6 @@ from ..exception import (
34
34
  from ..mount import ROOT_DIR, _is_modal_path, _Mount
35
35
  from .blob_utils import (
36
36
  MAX_ASYNC_OBJECT_SIZE_BYTES,
37
- MAX_OBJECT_SIZE_BYTES,
38
37
  blob_download,
39
38
  blob_upload_with_r2_failure_info,
40
39
  )
@@ -518,12 +517,13 @@ async def _process_result(result: api_pb2.GenericResult, data_format: int, stub,
518
517
 
519
518
  def should_upload(
520
519
  num_bytes: int,
520
+ max_object_size_bytes: int,
521
521
  function_call_invocation_type: Optional["api_pb2.FunctionCallInvocationType.ValueType"],
522
522
  ) -> bool:
523
523
  """
524
524
  Determine if the input should be uploaded to blob storage.
525
525
  """
526
- return num_bytes > MAX_OBJECT_SIZE_BYTES or (
526
+ return num_bytes > max_object_size_bytes or (
527
527
  function_call_invocation_type == api_pb2.FUNCTION_CALL_INVOCATION_TYPE_ASYNC
528
528
  and num_bytes > MAX_ASYNC_OBJECT_SIZE_BYTES
529
529
  )
@@ -534,6 +534,7 @@ async def _create_input(
534
534
  kwargs,
535
535
  stub: ModalClientModal,
536
536
  *,
537
+ max_object_size_bytes: int,
537
538
  idx: Optional[int] = None,
538
539
  method_name: Optional[str] = None,
539
540
  function_call_invocation_type: Optional["api_pb2.FunctionCallInvocationType.ValueType"] = None,
@@ -548,7 +549,7 @@ async def _create_input(
548
549
 
549
550
  args_serialized = serialize((args, kwargs))
550
551
 
551
- if should_upload(len(args_serialized), function_call_invocation_type):
552
+ if should_upload(len(args_serialized), max_object_size_bytes, function_call_invocation_type):
552
553
  args_blob_id, r2_failed, r2_latency_ms = await blob_upload_with_r2_failure_info(args_serialized, stub)
553
554
  return api_pb2.FunctionPutInputsItem(
554
555
  input=api_pb2.FunctionInput(
@@ -31,7 +31,7 @@ class _Client:
31
31
  server_url: str,
32
32
  client_type: int,
33
33
  credentials: typing.Optional[tuple[str, str]],
34
- version: str = "1.0.6.dev9",
34
+ version: str = "1.0.6.dev11",
35
35
  ):
36
36
  """mdmd:hidden
37
37
  The Modal client object is not intended to be instantiated directly by users.
@@ -160,7 +160,7 @@ class Client:
160
160
  server_url: str,
161
161
  client_type: int,
162
162
  credentials: typing.Optional[tuple[str, str]],
163
- version: str = "1.0.6.dev9",
163
+ version: str = "1.0.6.dev11",
164
164
  ):
165
165
  """mdmd:hidden
166
166
  The Modal client object is not intended to be instantiated directly by users.
@@ -428,7 +428,7 @@ class Function(
428
428
 
429
429
  _call_generator: ___call_generator_spec[typing_extensions.Self]
430
430
 
431
- class __remote_spec(typing_extensions.Protocol[P_INNER, ReturnType_INNER, SUPERSELF]):
431
+ class __remote_spec(typing_extensions.Protocol[ReturnType_INNER, P_INNER, SUPERSELF]):
432
432
  def __call__(self, /, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> ReturnType_INNER:
433
433
  """Calls the function remotely, executing it with the given arguments and returning the execution's result."""
434
434
  ...
@@ -437,7 +437,7 @@ class Function(
437
437
  """Calls the function remotely, executing it with the given arguments and returning the execution's result."""
438
438
  ...
439
439
 
440
- remote: __remote_spec[modal._functions.P, modal._functions.ReturnType, typing_extensions.Self]
440
+ remote: __remote_spec[modal._functions.ReturnType, modal._functions.P, typing_extensions.Self]
441
441
 
442
442
  class __remote_gen_spec(typing_extensions.Protocol[SUPERSELF]):
443
443
  def __call__(self, /, *args, **kwargs) -> typing.Generator[typing.Any, None, None]:
@@ -464,7 +464,7 @@ class Function(
464
464
  """
465
465
  ...
466
466
 
467
- class ___experimental_spawn_spec(typing_extensions.Protocol[P_INNER, ReturnType_INNER, SUPERSELF]):
467
+ class ___experimental_spawn_spec(typing_extensions.Protocol[ReturnType_INNER, P_INNER, SUPERSELF]):
468
468
  def __call__(self, /, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> FunctionCall[ReturnType_INNER]:
469
469
  """[Experimental] Calls the function with the given arguments, without waiting for the results.
470
470
 
@@ -488,7 +488,7 @@ class Function(
488
488
  ...
489
489
 
490
490
  _experimental_spawn: ___experimental_spawn_spec[
491
- modal._functions.P, modal._functions.ReturnType, typing_extensions.Self
491
+ modal._functions.ReturnType, modal._functions.P, typing_extensions.Self
492
492
  ]
493
493
 
494
494
  class ___spawn_map_inner_spec(typing_extensions.Protocol[P_INNER, SUPERSELF]):
@@ -497,7 +497,7 @@ class Function(
497
497
 
498
498
  _spawn_map_inner: ___spawn_map_inner_spec[modal._functions.P, typing_extensions.Self]
499
499
 
500
- class __spawn_spec(typing_extensions.Protocol[P_INNER, ReturnType_INNER, SUPERSELF]):
500
+ class __spawn_spec(typing_extensions.Protocol[ReturnType_INNER, P_INNER, SUPERSELF]):
501
501
  def __call__(self, /, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> FunctionCall[ReturnType_INNER]:
502
502
  """Calls the function with the given arguments, without waiting for the results.
503
503
 
@@ -518,7 +518,7 @@ class Function(
518
518
  """
519
519
  ...
520
520
 
521
- spawn: __spawn_spec[modal._functions.P, modal._functions.ReturnType, typing_extensions.Self]
521
+ spawn: __spawn_spec[modal._functions.ReturnType, modal._functions.P, typing_extensions.Self]
522
522
 
523
523
  def get_raw_f(self) -> collections.abc.Callable[..., typing.Any]:
524
524
  """Return the inner Python object wrapped by this Modal Function."""
@@ -139,7 +139,14 @@ async def _map_invocation(
139
139
  idx = inputs_created
140
140
  update_state(set_inputs_created=inputs_created + 1)
141
141
  (args, kwargs) = argskwargs
142
- return await _create_input(args, kwargs, client.stub, idx=idx, method_name=function._use_method_name)
142
+ return await _create_input(
143
+ args,
144
+ kwargs,
145
+ client.stub,
146
+ max_object_size_bytes=function._max_object_size_bytes,
147
+ idx=idx,
148
+ method_name=function._use_method_name,
149
+ )
143
150
 
144
151
  async def input_iter():
145
152
  while 1:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: modal
3
- Version: 1.0.6.dev9
3
+ Version: 1.0.6.dev11
4
4
  Summary: Python client library for Modal
5
5
  Author-email: Modal Labs <support@modal.com>
6
6
  License: Apache-2.0
@@ -1013,6 +1013,12 @@ message ContainerLogRequest {
1013
1013
  repeated TaskLogs logs = 3;
1014
1014
  }
1015
1015
 
1016
+ message ContainerReloadVolumesRequest {
1017
+ string task_id = 1;
1018
+ }
1019
+
1020
+ message ContainerReloadVolumesResponse { }
1021
+
1016
1022
  message ContainerStopRequest {
1017
1023
  string task_id = 1 [ (modal.options.audit_target_attr) = true ];
1018
1024
  }
@@ -1718,6 +1724,8 @@ message FunctionHandleMetadata {
1718
1724
  FunctionSchema function_schema = 45;
1719
1725
  optional string input_plane_url = 46;
1720
1726
  optional string input_plane_region = 47;
1727
+ // Use optional to ensure unset values default to None instead of 0
1728
+ optional uint64 max_object_size_bytes = 48;
1721
1729
  }
1722
1730
 
1723
1731
  message FunctionInput {
@@ -3281,6 +3289,7 @@ service ModalClient {
3281
3289
  rpc ContainerHeartbeat(ContainerHeartbeatRequest) returns (ContainerHeartbeatResponse);
3282
3290
  rpc ContainerHello(google.protobuf.Empty) returns (google.protobuf.Empty);
3283
3291
  rpc ContainerLog(ContainerLogRequest) returns (google.protobuf.Empty);
3292
+ rpc ContainerReloadVolumes(ContainerReloadVolumesRequest) returns (ContainerReloadVolumesResponse);
3284
3293
  rpc ContainerStop(ContainerStopRequest) returns (ContainerStopResponse);
3285
3294
 
3286
3295
  // Dicts
@@ -162,6 +162,10 @@ class ModalClientBase(abc.ABC):
162
162
  async def ContainerLog(self, stream: 'grpclib.server.Stream[modal_proto.api_pb2.ContainerLogRequest, google.protobuf.empty_pb2.Empty]') -> None:
163
163
  pass
164
164
 
165
+ @abc.abstractmethod
166
+ async def ContainerReloadVolumes(self, stream: 'grpclib.server.Stream[modal_proto.api_pb2.ContainerReloadVolumesRequest, modal_proto.api_pb2.ContainerReloadVolumesResponse]') -> None:
167
+ pass
168
+
165
169
  @abc.abstractmethod
166
170
  async def ContainerStop(self, stream: 'grpclib.server.Stream[modal_proto.api_pb2.ContainerStopRequest, modal_proto.api_pb2.ContainerStopResponse]') -> None:
167
171
  pass
@@ -860,6 +864,12 @@ class ModalClientBase(abc.ABC):
860
864
  modal_proto.api_pb2.ContainerLogRequest,
861
865
  google.protobuf.empty_pb2.Empty,
862
866
  ),
867
+ '/modal.client.ModalClient/ContainerReloadVolumes': grpclib.const.Handler(
868
+ self.ContainerReloadVolumes,
869
+ grpclib.const.Cardinality.UNARY_UNARY,
870
+ modal_proto.api_pb2.ContainerReloadVolumesRequest,
871
+ modal_proto.api_pb2.ContainerReloadVolumesResponse,
872
+ ),
863
873
  '/modal.client.ModalClient/ContainerStop': grpclib.const.Handler(
864
874
  self.ContainerStop,
865
875
  grpclib.const.Cardinality.UNARY_UNARY,
@@ -1802,6 +1812,12 @@ class ModalClientStub:
1802
1812
  modal_proto.api_pb2.ContainerLogRequest,
1803
1813
  google.protobuf.empty_pb2.Empty,
1804
1814
  )
1815
+ self.ContainerReloadVolumes = grpclib.client.UnaryUnaryMethod(
1816
+ channel,
1817
+ '/modal.client.ModalClient/ContainerReloadVolumes',
1818
+ modal_proto.api_pb2.ContainerReloadVolumesRequest,
1819
+ modal_proto.api_pb2.ContainerReloadVolumesResponse,
1820
+ )
1805
1821
  self.ContainerStop = grpclib.client.UnaryUnaryMethod(
1806
1822
  channel,
1807
1823
  '/modal.client.ModalClient/ContainerStop',