modal 1.0.5.dev29__tar.gz → 1.0.5.dev31__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.
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/PKG-INFO +1 -1
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_functions.py +2 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/client.pyi +2 -2
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/functions.pyi +6 -6
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/sandbox.py +1 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/volume.py +37 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/volume.pyi +44 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal.egg-info/PKG-INFO +1 -1
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/api.proto +15 -1
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/api_grpc.py +16 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/api_pb2.py +624 -593
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/api_pb2.pyi +48 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/api_pb2_grpc.py +33 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/api_pb2_grpc.pyi +10 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/modal_api_grpc.py +1 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_version/__init__.py +1 -1
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/LICENSE +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/README.md +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/__init__.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/__main__.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_clustered_functions.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_clustered_functions.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_container_entrypoint.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_ipython.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_location.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_object.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_output.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_partial_function.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_pty.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_resolver.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_resources.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_runtime/__init__.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_runtime/asgi.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_runtime/container_io_manager.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_runtime/container_io_manager.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_runtime/execution_context.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_runtime/execution_context.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_runtime/gpu_memory_snapshot.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_runtime/telemetry.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_runtime/user_code_imports.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_serialization.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_traceback.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_tunnel.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_tunnel.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_type_manager.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/__init__.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/app_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/async_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/blob_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/bytes_io_segment_payload.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/deprecation.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/docker_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/function_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/git_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/grpc_testing.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/grpc_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/hash_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/http_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/jwt_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/logger.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/mount_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/name_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/package_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/pattern_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/rand_pb_testing.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/shell_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_utils/time_utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_vendor/__init__.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_vendor/a2wsgi_wsgi.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_vendor/cloudpickle.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_vendor/tblib.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/_watcher.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/app.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/app.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/call_graph.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/__init__.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/_download.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/_traceback.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/app.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/cluster.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/config.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/container.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/dict.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/entry_point.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/environment.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/import_refs.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/launch.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/network_file_system.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/profile.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/programs/__init__.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/programs/run_jupyter.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/programs/vscode.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/queues.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/run.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/secret.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/token.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/utils.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cli/volume.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/client.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cloud_bucket_mount.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cloud_bucket_mount.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cls.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/cls.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/config.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/container_process.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/container_process.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/dict.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/dict.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/environments.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/environments.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/exception.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/experimental/__init__.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/experimental/ipython.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/file_io.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/file_io.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/file_pattern_matcher.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/functions.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/gpu.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/image.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/image.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/io_streams.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/io_streams.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/mount.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/mount.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/network_file_system.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/network_file_system.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/object.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/object.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/output.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/parallel_map.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/parallel_map.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/partial_function.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/partial_function.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/proxy.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/proxy.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/py.typed +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/queue.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/queue.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/requirements/2023.12.312.txt +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/requirements/2023.12.txt +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/requirements/2024.04.txt +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/requirements/2024.10.txt +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/requirements/PREVIEW.txt +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/requirements/README.md +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/requirements/base-images.json +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/retries.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/runner.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/runner.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/running_app.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/sandbox.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/schedule.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/scheduler_placement.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/secret.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/secret.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/serving.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/serving.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/snapshot.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/snapshot.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/stream_type.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/token_flow.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal/token_flow.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal.egg-info/SOURCES.txt +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal.egg-info/dependency_links.txt +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal.egg-info/entry_points.txt +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal.egg-info/requires.txt +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal.egg-info/top_level.txt +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_docs/__init__.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_docs/gen_cli_docs.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_docs/gen_reference_docs.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_docs/mdmd/__init__.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_docs/mdmd/mdmd.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_docs/mdmd/signatures.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/__init__.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/modal_options_grpc.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/options.proto +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/options_grpc.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/options_pb2.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/options_pb2.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/options_pb2_grpc.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/options_pb2_grpc.pyi +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_proto/py.typed +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/modal_version/__main__.py +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/pyproject.toml +0 -0
- {modal-1.0.5.dev29 → modal-1.0.5.dev31}/setup.cfg +0 -0
@@ -854,6 +854,7 @@ class _Function(typing.Generic[P, ReturnType, OriginalReturnType], _Object, type
|
|
854
854
|
mount_path=path,
|
855
855
|
volume_id=volume.object_id,
|
856
856
|
allow_background_commits=True,
|
857
|
+
read_only=volume._read_only,
|
857
858
|
)
|
858
859
|
for path, volume in validated_volumes_no_cloud_buckets
|
859
860
|
]
|
@@ -1107,6 +1108,7 @@ class _Function(typing.Generic[P, ReturnType, OriginalReturnType], _Object, type
|
|
1107
1108
|
mount_path=path,
|
1108
1109
|
volume_id=volume.object_id,
|
1109
1110
|
allow_background_commits=True,
|
1111
|
+
read_only=volume._read_only,
|
1110
1112
|
)
|
1111
1113
|
for path, volume in options.validated_volumes
|
1112
1114
|
]
|
@@ -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.5.
|
34
|
+
version: str = "1.0.5.dev31",
|
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.5.
|
163
|
+
version: str = "1.0.5.dev31",
|
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[
|
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.
|
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[
|
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.
|
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[
|
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.
|
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."""
|
@@ -135,6 +135,34 @@ class _Volume(_Object, type_prefix="vo"):
|
|
135
135
|
|
136
136
|
_lock: Optional[asyncio.Lock] = None
|
137
137
|
_metadata: "typing.Optional[api_pb2.VolumeMetadata]"
|
138
|
+
_read_only: bool = False
|
139
|
+
|
140
|
+
def read_only(self) -> "_Volume":
|
141
|
+
"""Configure Volume to mount as read-only.
|
142
|
+
|
143
|
+
**Example**
|
144
|
+
|
145
|
+
```python
|
146
|
+
import modal
|
147
|
+
|
148
|
+
volume = modal.Volume.from_name("my-volume", create_if_missing=True)
|
149
|
+
|
150
|
+
@app.function(volumes={"/mnt/items": volume.read_only()})
|
151
|
+
def f():
|
152
|
+
with open("/mnt/items/my-file.txt") as f:
|
153
|
+
return f.read()
|
154
|
+
```
|
155
|
+
|
156
|
+
The Volume is mounted as a read-only volume in a function. Any file system write operation into the
|
157
|
+
mounted volume will result in an error.
|
158
|
+
"""
|
159
|
+
|
160
|
+
async def _load(new_volume: _Volume, resolver: Resolver, existing_object_id: Optional[str]):
|
161
|
+
new_volume._initialize_from_other(self)
|
162
|
+
new_volume._read_only = True
|
163
|
+
|
164
|
+
obj = _Volume._from_loader(_load, "Volume()", hydrate_lazily=True, deps=lambda: [self])
|
165
|
+
return obj
|
138
166
|
|
139
167
|
async def _get_lock(self):
|
140
168
|
# To (mostly*) prevent multiple concurrent operations on the same volume, which can cause problems under
|
@@ -495,6 +523,9 @@ class _Volume(_Object, type_prefix="vo"):
|
|
495
523
|
@live_method
|
496
524
|
async def remove_file(self, path: str, recursive: bool = False) -> None:
|
497
525
|
"""Remove a file or directory from a volume."""
|
526
|
+
if self._read_only:
|
527
|
+
raise InvalidError("Read-only Volume can not be written to")
|
528
|
+
|
498
529
|
if self._is_v1:
|
499
530
|
req = api_pb2.VolumeRemoveFileRequest(volume_id=self.object_id, path=path, recursive=recursive)
|
500
531
|
await retry_transient_errors(self._client.stub.VolumeRemoveFile, req)
|
@@ -527,6 +558,9 @@ class _Volume(_Object, type_prefix="vo"):
|
|
527
558
|
like `os.rename()` and then `commit()` the volume. The `copy_files()` method is useful when you don't have
|
528
559
|
the volume mounted as a filesystem, e.g. when running a script on your local computer.
|
529
560
|
"""
|
561
|
+
if self._read_only:
|
562
|
+
raise InvalidError("Read-only Volume can not be written to")
|
563
|
+
|
530
564
|
if self._is_v1:
|
531
565
|
if recursive:
|
532
566
|
raise ValueError("`recursive` is not supported for V1 volumes")
|
@@ -560,6 +594,9 @@ class _Volume(_Object, type_prefix="vo"):
|
|
560
594
|
batch.put_file(io.BytesIO(b"some data"), "/foobar")
|
561
595
|
```
|
562
596
|
"""
|
597
|
+
if self._read_only:
|
598
|
+
raise InvalidError("Read-only Volume can not be written to")
|
599
|
+
|
563
600
|
return _AbstractVolumeUploadContextManager.resolve(
|
564
601
|
self._metadata.version, self.object_id, self._client, force=force
|
565
602
|
)
|
@@ -101,6 +101,28 @@ class _Volume(modal._object._Object):
|
|
101
101
|
|
102
102
|
_lock: typing.Optional[asyncio.locks.Lock]
|
103
103
|
_metadata: typing.Optional[modal_proto.api_pb2.VolumeMetadata]
|
104
|
+
_read_only: bool
|
105
|
+
|
106
|
+
def read_only(self) -> _Volume:
|
107
|
+
"""Configure Volume to mount as read-only.
|
108
|
+
|
109
|
+
**Example**
|
110
|
+
|
111
|
+
```python
|
112
|
+
import modal
|
113
|
+
|
114
|
+
volume = modal.Volume.from_name("my-volume", create_if_missing=True)
|
115
|
+
|
116
|
+
@app.function(volumes={"/mnt/items": volume.read_only()})
|
117
|
+
def f():
|
118
|
+
with open("/mnt/items/my-file.txt") as f:
|
119
|
+
return f.read()
|
120
|
+
```
|
121
|
+
|
122
|
+
The Volume is mounted as a read-only volume in a function. Any file system write operation into the
|
123
|
+
mounted volume will result in an error.
|
124
|
+
"""
|
125
|
+
...
|
104
126
|
|
105
127
|
async def _get_lock(self): ...
|
106
128
|
@staticmethod
|
@@ -371,11 +393,33 @@ class Volume(modal.object.Object):
|
|
371
393
|
|
372
394
|
_lock: typing.Optional[asyncio.locks.Lock]
|
373
395
|
_metadata: typing.Optional[modal_proto.api_pb2.VolumeMetadata]
|
396
|
+
_read_only: bool
|
374
397
|
|
375
398
|
def __init__(self, *args, **kwargs):
|
376
399
|
"""mdmd:hidden"""
|
377
400
|
...
|
378
401
|
|
402
|
+
def read_only(self) -> Volume:
|
403
|
+
"""Configure Volume to mount as read-only.
|
404
|
+
|
405
|
+
**Example**
|
406
|
+
|
407
|
+
```python
|
408
|
+
import modal
|
409
|
+
|
410
|
+
volume = modal.Volume.from_name("my-volume", create_if_missing=True)
|
411
|
+
|
412
|
+
@app.function(volumes={"/mnt/items": volume.read_only()})
|
413
|
+
def f():
|
414
|
+
with open("/mnt/items/my-file.txt") as f:
|
415
|
+
return f.read()
|
416
|
+
```
|
417
|
+
|
418
|
+
The Volume is mounted as a read-only volume in a function. Any file system write operation into the
|
419
|
+
mounted volume will result in an error.
|
420
|
+
"""
|
421
|
+
...
|
422
|
+
|
379
423
|
class ___get_lock_spec(typing_extensions.Protocol[SUPERSELF]):
|
380
424
|
def __call__(self, /): ...
|
381
425
|
async def aio(self, /): ...
|
@@ -1246,8 +1246,21 @@ message FlashContainerDeregisterRequest {
|
|
1246
1246
|
string service_name = 1;
|
1247
1247
|
}
|
1248
1248
|
|
1249
|
+
message FlashContainerListRequest {
|
1250
|
+
string function_id = 1;
|
1251
|
+
}
|
1252
|
+
|
1253
|
+
message FlashContainerListResponse {
|
1254
|
+
message Container {
|
1255
|
+
string task_id = 1;
|
1256
|
+
string host = 2;
|
1257
|
+
uint32 port = 3;
|
1258
|
+
}
|
1259
|
+
repeated Container containers = 1;
|
1260
|
+
}
|
1261
|
+
|
1249
1262
|
message FlashContainerRegisterRequest {
|
1250
|
-
string service_name = 1;
|
1263
|
+
string service_name = 1; // not used?
|
1251
1264
|
uint32 priority = 2;
|
1252
1265
|
uint32 weight = 3;
|
1253
1266
|
string host = 4;
|
@@ -3294,6 +3307,7 @@ service ModalClient {
|
|
3294
3307
|
|
3295
3308
|
// Modal Flash (experimental)
|
3296
3309
|
rpc FlashContainerDeregister(FlashContainerDeregisterRequest) returns (google.protobuf.Empty);
|
3310
|
+
rpc FlashContainerList(FlashContainerListRequest) returns (FlashContainerListResponse);
|
3297
3311
|
rpc FlashContainerRegister(FlashContainerRegisterRequest) returns (FlashContainerRegisterResponse);
|
3298
3312
|
|
3299
3313
|
// Functions
|
@@ -246,6 +246,10 @@ class ModalClientBase(abc.ABC):
|
|
246
246
|
async def FlashContainerDeregister(self, stream: 'grpclib.server.Stream[modal_proto.api_pb2.FlashContainerDeregisterRequest, google.protobuf.empty_pb2.Empty]') -> None:
|
247
247
|
pass
|
248
248
|
|
249
|
+
@abc.abstractmethod
|
250
|
+
async def FlashContainerList(self, stream: 'grpclib.server.Stream[modal_proto.api_pb2.FlashContainerListRequest, modal_proto.api_pb2.FlashContainerListResponse]') -> None:
|
251
|
+
pass
|
252
|
+
|
249
253
|
@abc.abstractmethod
|
250
254
|
async def FlashContainerRegister(self, stream: 'grpclib.server.Stream[modal_proto.api_pb2.FlashContainerRegisterRequest, modal_proto.api_pb2.FlashContainerRegisterResponse]') -> None:
|
251
255
|
pass
|
@@ -982,6 +986,12 @@ class ModalClientBase(abc.ABC):
|
|
982
986
|
modal_proto.api_pb2.FlashContainerDeregisterRequest,
|
983
987
|
google.protobuf.empty_pb2.Empty,
|
984
988
|
),
|
989
|
+
'/modal.client.ModalClient/FlashContainerList': grpclib.const.Handler(
|
990
|
+
self.FlashContainerList,
|
991
|
+
grpclib.const.Cardinality.UNARY_UNARY,
|
992
|
+
modal_proto.api_pb2.FlashContainerListRequest,
|
993
|
+
modal_proto.api_pb2.FlashContainerListResponse,
|
994
|
+
),
|
985
995
|
'/modal.client.ModalClient/FlashContainerRegister': grpclib.const.Handler(
|
986
996
|
self.FlashContainerRegister,
|
987
997
|
grpclib.const.Cardinality.UNARY_UNARY,
|
@@ -1918,6 +1928,12 @@ class ModalClientStub:
|
|
1918
1928
|
modal_proto.api_pb2.FlashContainerDeregisterRequest,
|
1919
1929
|
google.protobuf.empty_pb2.Empty,
|
1920
1930
|
)
|
1931
|
+
self.FlashContainerList = grpclib.client.UnaryUnaryMethod(
|
1932
|
+
channel,
|
1933
|
+
'/modal.client.ModalClient/FlashContainerList',
|
1934
|
+
modal_proto.api_pb2.FlashContainerListRequest,
|
1935
|
+
modal_proto.api_pb2.FlashContainerListResponse,
|
1936
|
+
)
|
1921
1937
|
self.FlashContainerRegister = grpclib.client.UnaryUnaryMethod(
|
1922
1938
|
channel,
|
1923
1939
|
'/modal.client.ModalClient/FlashContainerRegister',
|