dstack 0.18.41__tar.gz → 0.18.43__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 dstack might be problematic. Click here for more details.
- {dstack-0.18.41 → dstack-0.18.43}/PKG-INFO +2 -2
- {dstack-0.18.41 → dstack-0.18.43}/README.md +1 -1
- {dstack-0.18.41 → dstack-0.18.43}/setup.py +2 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/__init__.py +2 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/apply.py +4 -2
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/attach.py +21 -1
- dstack-0.18.43/src/dstack/_internal/cli/commands/completion.py +20 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/delete.py +3 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/fleet.py +2 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/gateway.py +7 -2
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/logs.py +3 -2
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/stats.py +2 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/stop.py +2 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/volume.py +2 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/main.py +6 -0
- dstack-0.18.43/src/dstack/_internal/cli/services/completion.py +86 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/services/configurators/run.py +10 -17
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/utils/fleet.py +5 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/utils/volume.py +9 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/aws/compute.py +24 -11
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/aws/resources.py +3 -3
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/azure/compute.py +14 -8
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/azure/resources.py +2 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/base/compute.py +102 -2
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/base/offers.py +7 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/cudo/compute.py +8 -4
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/datacrunch/compute.py +10 -4
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/gcp/auth.py +19 -13
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/gcp/compute.py +27 -20
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/gcp/resources.py +3 -10
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/kubernetes/compute.py +4 -3
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/lambdalabs/compute.py +9 -3
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/nebius/compute.py +2 -2
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/oci/compute.py +10 -4
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/runpod/compute.py +11 -4
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/tensordock/compute.py +14 -3
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/vastai/compute.py +12 -2
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/vultr/api_client.py +3 -3
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/vultr/compute.py +9 -3
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/aws.py +2 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/base.py +1 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/configurations.py +0 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/runs.py +3 -3
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/volumes.py +23 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/services/__init__.py +5 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/services/configs/__init__.py +3 -0
- dstack-0.18.43/src/dstack/_internal/server/background/tasks/common.py +22 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/background/tasks/process_instances.py +13 -21
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/background/tasks/process_running_jobs.py +13 -16
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/background/tasks/process_submitted_jobs.py +12 -7
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/background/tasks/process_terminating_jobs.py +7 -2
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/background/tasks/process_volumes.py +11 -1
- dstack-0.18.43/src/dstack/_internal/server/migrations/versions/a751ef183f27_move_attachment_data_to_volumes_.py +34 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/models.py +17 -19
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/logs.py +3 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/aws.py +31 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/gcp.py +8 -15
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/config.py +11 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/fleets.py +5 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/jobs/__init__.py +14 -11
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/jobs/configurators/dev.py +1 -3
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/jobs/configurators/task.py +1 -3
- dstack-0.18.43/src/dstack/_internal/server/services/logs/__init__.py +78 -0
- dstack-0.18.41/src/dstack/_internal/server/services/logs.py → dstack-0.18.43/src/dstack/_internal/server/services/logs/aws.py +12 -207
- dstack-0.18.43/src/dstack/_internal/server/services/logs/base.py +47 -0
- dstack-0.18.43/src/dstack/_internal/server/services/logs/filelog.py +110 -0
- dstack-0.18.43/src/dstack/_internal/server/services/logs/gcp.py +165 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/offers.py +7 -7
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/pools.py +19 -20
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/proxy/routers/service_proxy.py +14 -7
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/runner/client.py +8 -5
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/volumes.py +68 -9
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/settings.py +3 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/index.html +1 -1
- dstack-0.18.41/src/dstack/_internal/server/statics/main-ad5150a441de98cd8987.css → dstack-0.18.43/src/dstack/_internal/server/statics/main-7510e71dfa9749a4e70e.css +1 -1
- dstack-0.18.41/src/dstack/_internal/server/statics/main-2ac66bfcbd2e39830b88.js → dstack-0.18.43/src/dstack/_internal/server/statics/main-fe8fd9db55df8d10e648.js +66 -66
- dstack-0.18.41/src/dstack/_internal/server/statics/main-2ac66bfcbd2e39830b88.js.map → dstack-0.18.43/src/dstack/_internal/server/statics/main-fe8fd9db55df8d10e648.js.map +1 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/testing/common.py +46 -17
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/_public/runs.py +1 -1
- dstack-0.18.43/src/dstack/version.py +3 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack.egg-info/PKG-INFO +2 -2
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack.egg-info/SOURCES.txt +15 -4
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack.egg-info/requires.txt +2 -1
- dstack-0.18.43/src/tests/_internal/core/backends/base/test_compute.py +56 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/background/tasks/test_process_running_jobs.py +2 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/background/tasks/test_process_submitted_jobs.py +5 -3
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/background/tasks/test_process_terminating_jobs.py +11 -6
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/conftest.py +4 -5
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/routers/test_backends.py +1 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/routers/test_logs.py +1 -1
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/routers/test_runs.py +2 -2
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/routers/test_volumes.py +9 -2
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/services/runner/test_client.py +22 -3
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/services/test_logs.py +3 -3
- dstack-0.18.43/src/tests/_internal/server/services/test_offers.py +167 -0
- dstack-0.18.43/src/tests/_internal/server/services/test_pools.py +191 -0
- dstack-0.18.43/src/tests/api/__init__.py +0 -0
- dstack-0.18.41/src/dstack/version.py +0 -3
- dstack-0.18.41/src/tests/_internal/server/services/test_pools.py +0 -87
- {dstack-0.18.41 → dstack-0.18.43}/LICENSE.md +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/setup.cfg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/init.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/pool.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/ps.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/run.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/commands/server.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/services/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/services/args.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/services/configurators/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/services/configurators/base.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/services/configurators/fleet.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/services/configurators/gateway.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/services/configurators/volume.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/services/profile.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/services/repos.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/utils/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/utils/common.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/utils/gateway.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/utils/rich.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/utils/run.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/cli/utils/updates.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/compat.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/aws/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/aws/auth.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/aws/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/azure/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/azure/auth.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/azure/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/azure/utils.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/base/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/base/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/cudo/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/cudo/api_client.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/cudo/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/datacrunch/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/datacrunch/api_client.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/datacrunch/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/gcp/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/gcp/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/kubernetes/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/kubernetes/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/kubernetes/utils.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/lambdalabs/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/lambdalabs/api_client.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/lambdalabs/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/local/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/local/compute.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/nebius/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/nebius/api_client.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/nebius/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/nebius/types.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/oci/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/oci/auth.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/oci/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/oci/exceptions.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/oci/region.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/oci/resources.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/remote/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/remote/provisioning.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/runpod/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/runpod/api_client.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/runpod/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/tensordock/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/tensordock/api_client.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/tensordock/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/vastai/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/vastai/api_client.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/vastai/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/vultr/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/backends/vultr/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/consts.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/errors.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/azure.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/cudo.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/datacrunch.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/dstack.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/gcp.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/kubernetes.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/lambdalabs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/nebius.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/oci.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/runpod.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/tensordock.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/vastai.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/backends/vultr.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/common.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/envs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/fleets.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/gateways.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/instances.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/logs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/metrics.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/placement.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/pools.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/profiles.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/projects.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/repos/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/repos/base.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/repos/local.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/repos/remote.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/repos/virtual.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/resources.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/secrets.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/server.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/services.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/unix.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/models/users.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/services/api_client.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/services/diff.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/services/logs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/services/profiles.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/services/repos.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/services/ssh/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/services/ssh/attach.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/services/ssh/client.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/services/ssh/ports.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/core/services/ssh/tunnel.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/app.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/auth.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/const.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/deps.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/main.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/models.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/repo/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/repo/repo.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/repo/state_v1.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/resources/nginx/00-log-format.conf +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/resources/nginx/entrypoint.jinja2 +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/resources/nginx/service.jinja2 +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/routers/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/routers/auth.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/routers/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/routers/registry.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/routers/stats.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/schemas/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/schemas/common.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/schemas/config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/schemas/registry.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/schemas/stats.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/services/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/services/nginx.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/services/registry.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/services/server_client.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/services/stats.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/testing/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/gateway/testing/common.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/auth.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/deps.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/errors.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/models.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/repo.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/routers/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/routers/model_proxy.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/schemas/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/schemas/model_proxy.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/services/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/services/model_proxy/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/services/model_proxy/clients/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/services/model_proxy/clients/base.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/services/model_proxy/clients/openai.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/services/model_proxy/clients/tgi.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/services/model_proxy/model_proxy.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/services/service_connection.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/testing/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/testing/auth.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/proxy/lib/testing/common.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/app.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/background/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/background/tasks/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/background/tasks/process_fleets.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/background/tasks/process_gateways.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/background/tasks/process_metrics.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/background/tasks/process_placement_groups.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/background/tasks/process_runs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/db.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/deps.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/main.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/env.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/065588ec72b8_add_vultr_to_backendtype_enum.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/0e33559e16ed_update_instancestatus.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/112753bc17dd_remove_nullable_fields.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/1338b788b612_reverse_job_instance_relationship.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/14f2cb002fc2_add_jobmodel_removed_flag.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/1a48dfe44a40_rework_termination_handling.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/1e3fb39ef74b_add_remote_connection_details.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/1e76fb0dde87_add_jobmodel_inactivity_secs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/23e01c56279a_make_blob_nullable.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/252d3743b641_.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/27d3e55759fa_add_pools.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/29826f417010_remove_instancemodel_retry_policy.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/29c08c6a8cb3_.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/3cf77fb8bcf1_store_repo_clone_url.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/3dbdce90d0e0_fix_code_uq_constraint.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/48ad3ecbaea2_do_not_delete_projects_and_runs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/4ae1a5b0e7f1_add_run_list_index.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/4b4319398164_introduce_runs_processing.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/51d45659d574_add_instancemodel_blocks_fields.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/54a77e19c64c_add_manager_project_role.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/555138b1f77f_change_instancemodel_for_asynchronous_.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/58aa5162dcc3_add_gatewaymodel_configuration.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/5ad8debc8fe6_fixes_for_psql.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/5ec538b70e71_replace_instansestatus.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/63c3f19cb184_add_jobterminationreason_inactivity_.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/686fb8341ea5_add_user_emails.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/710e5b3fac8f_add_encryption.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/7b24b1c8eba7_add_instancemodel_last_processed_at.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/803c7e9ed85d_add_jobmodel_job_runtime_data.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/82b32a135ea2_.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/866ec1d67184_replace_retrypolicy_limit_with_.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/91a12fff6c76_add_repocredsmodel.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/91ac5e543037_extend_repos_creds_column.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/98cd9c8b5927_add_volumemodel.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/99b4c8c954ea_add_termination_reason_message.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/9eea6af28e10_added_fail_reason_for_instancemodel.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/a060e2440936_.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/a7b46c073fa1_add_placementgroupmodel.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/afbc600ff2b2_add_created_at_to_usermodel_and_.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/b4d6ad60db08_add_instancemodel_unreachable.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/b88d55c2a07d_replace_instancestatus_ready.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/bfba43f6def2_.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/c00090eaef21_support_fleets.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/c154eece89da_add_fields_for_async_gateway_creation.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/c20626d03cfb_add_jobmetricspoint.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/c48df7985d57_add_instance_termination_retries.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/c83d45f9a971_replace_string_with_text.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/d0bb68e48b9f_add_project_owners_and_quotas.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/d3e8af4786fa_gateway_compute_flag_deleted.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/d6b11105f659_add_usermodel_active.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/da574e93fee0_add_jobmodel_volumes_detached_at.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/dfffd6a1165c_add_fields_for_gateways_behind_alb.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/e3b7db07727f_add_gatewaycomputemodel_app_updated_at.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/e6391ca6a264_separate_gateways_from_compute.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/ea60480f82bb_add_membermodel_member_num.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/ed0ca30e13bb_migrate_instancestatus_provisioning.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/fe72c4de8376_add_gateways.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/migrations/versions/ffa99edd1988_add_jobterminationreason_max_duration_.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/backends.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/fleets.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/gateways.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/instances.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/metrics.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/pools.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/projects.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/repos.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/runs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/secrets.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/server.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/users.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/routers/volumes.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/backends.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/common.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/fleets.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/gateways.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/instances.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/logs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/pools.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/projects.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/repos.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/runner.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/runs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/secrets.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/users.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/schemas/volumes.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/security/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/security/permissions.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/azure.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/base.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/cudo.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/datacrunch.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/kubernetes.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/lambdalabs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/nebius.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/oci.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/runpod.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/tensordock.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/vastai.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/configurators/vultr.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/backends/handlers.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/docker.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/encryption/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/encryption/keys/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/encryption/keys/aes.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/encryption/keys/base.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/encryption/keys/identity.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/gateways/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/gateways/client.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/gateways/connection.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/gateways/pool.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/jobs/configurators/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/jobs/configurators/base.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/jobs/configurators/extensions/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/jobs/configurators/extensions/base.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/jobs/configurators/extensions/vscode.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/jobs/configurators/service.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/locking.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/logging.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/metrics.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/permissions.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/placement.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/projects.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/proxy/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/proxy/auth.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/proxy/deps.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/proxy/repo.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/proxy/routers/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/proxy/services/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/proxy/services/service_proxy.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/repos.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/runner/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/runner/ssh.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/runs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/services/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/services/autoscalers.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/services/options.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/storage.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/services/users.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/00a6e1fb461ed2929fb9.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/0cae4d9f0a36034984a7.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/391de232cc0e30cae513.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/4e0eead8c1a73689ef9d.svg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/544afa2f63428c2235b0.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/54a4f50f74c6b9381530.svg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/68dd1360a7d2611e0132.svg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/69544b4c81973b54a66f.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/77a8b02b17af19e39266.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/83a93a8871c219104367.svg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/8f28bb8e9999e5e6a48b.svg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/9124086961ab8c366bc4.svg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/9a9ebaeb54b025dbac0a.svg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/a3428392dc534f3b15c4.svg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/ae22625574d69361f72c.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/android-chrome-144x144.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/android-chrome-192x192.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/android-chrome-256x256.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/android-chrome-36x36.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/android-chrome-384x384.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/android-chrome-48x48.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/android-chrome-512x512.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/android-chrome-72x72.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/android-chrome-96x96.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-icon-1024x1024.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-icon-114x114.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-icon-120x120.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-icon-144x144.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-icon-152x152.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-icon-167x167.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-icon-180x180.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-icon-57x57.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-icon-60x60.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-icon-72x72.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-icon-76x76.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-icon-precomposed.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-icon.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1125x2436.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1136x640.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1170x2532.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1179x2556.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1242x2208.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1242x2688.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1284x2778.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1290x2796.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1334x750.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1488x2266.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1536x2048.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1620x2160.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1640x2160.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1668x2224.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1668x2388.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-1792x828.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2048x1536.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2048x2732.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2160x1620.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2160x1640.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2208x1242.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2224x1668.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2266x1488.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2388x1668.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2436x1125.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2532x1170.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2556x1179.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2688x1242.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2732x2048.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2778x1284.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-2796x1290.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-640x1136.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-750x1334.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/apple-touch-startup-image-828x1792.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/browserconfig.xml +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/favicon-16x16.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/favicon-32x32.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/favicon-48x48.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/favicon.ico +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/manifest.webmanifest +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/mstile-144x144.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/mstile-150x150.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/mstile-310x150.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/mstile-310x310.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/mstile-70x70.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/yandex-browser-50x50.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/assets/yandex-browser-manifest.json +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/b7ae68f44193474fc578.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/d2f008c75b2b5b191f3f.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/d44c33e1b92e05c379fd.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/dd43ff0552815179d7ab.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/dd4e7166c0b9aac197d7.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/e30b27916930d43d2271.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/e467d7d60aae81ab198b.svg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/eb9b344b73818fe2b71a.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/f517dd626eb964120de0.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/f958aecddee5d8e3222c.png +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/manifest.json +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/robots.txt +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/static/media/github.1f7102513534c83a9d8d735d2b8c12a2.svg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/static/media/logo.f602feeb138844eda97c8cb641461448.svg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/static/media/okta.12f178e6873a1100965f2a4dbd18fcec.svg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/statics/static/media/theme.3994c817bb7dda191c1c9640dee0bf42.svg +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/testing/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/testing/conf.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/utils/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/utils/common.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/utils/logging.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/server/utils/routers.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/settings.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/common.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/crypto.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/dxf.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/env.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/gpu.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/hash.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/ignore.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/interpolator.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/logging.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/network.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/path.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/random_names.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/_internal/utils/ssh.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/_public/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/_public/backends.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/_public/pools.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/_public/repos.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/_public/resources.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/huggingface/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/_backends.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/_fleets.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/_gateways.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/_group.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/_logs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/_metrics.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/_pools.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/_projects.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/_repos.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/_runs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/_secrets.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/_users.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/_volumes.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/server/utils.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/api/utils.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack/core/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack.egg-info/dependency_links.txt +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack.egg-info/entry_points.txt +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/dstack.egg-info/top_level.txt +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/cli/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/cli/commands/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/cli/commands/test_config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/cli/commands/test_dstack.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/cli/common.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/cli/services/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/cli/services/configurators/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/cli/services/configurators/test_fleet.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/cli/services/configurators/test_profile.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/cli/services/configurators/test_run.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/backends/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/backends/aws/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/backends/aws/test_resources.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/backends/azure/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/backends/azure/test_compute.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/backends/azure/test_resources.py +0 -0
- {dstack-0.18.41/src/tests/_internal/core/backends/gcp → dstack-0.18.43/src/tests/_internal/core/backends/base}/__init__.py +0 -0
- {dstack-0.18.41/src/tests/_internal/core/backends/kubernetes → dstack-0.18.43/src/tests/_internal/core/backends/gcp}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/backends/gcp/test_resources.py +0 -0
- {dstack-0.18.41/src/tests/_internal/core/backends/oci → dstack-0.18.43/src/tests/_internal/core/backends/kubernetes}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/backends/kubernetes/test_compute.py +0 -0
- {dstack-0.18.41/src/tests/_internal/core/models → dstack-0.18.43/src/tests/_internal/core/backends/oci}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/backends/oci/test_resources.py +0 -0
- {dstack-0.18.41/src/tests/_internal/core/models/repos → dstack-0.18.43/src/tests/_internal/core/models}/__init__.py +0 -0
- {dstack-0.18.41/src/tests/_internal/core/services → dstack-0.18.43/src/tests/_internal/core/models/repos}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/models/repos/test_remote.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/models/test_configurations.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/models/test_instances.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/models/test_resources.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/models/test_runs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/models/test_unix.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/models/test_volumes.py +0 -0
- {dstack-0.18.41/src/tests/_internal/core/services/ssh → dstack-0.18.43/src/tests/_internal/core/services}/__init__.py +0 -0
- {dstack-0.18.41/src/tests/_internal/proxy → dstack-0.18.43/src/tests/_internal/core/services/ssh}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/services/ssh/test_client.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/services/ssh/test_tunnel.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/core/services/test_logs.py +0 -0
- {dstack-0.18.41/src/tests/_internal/proxy/gateway → dstack-0.18.43/src/tests/_internal/proxy}/__init__.py +0 -0
- {dstack-0.18.41/src/tests/_internal/proxy/gateway/repo → dstack-0.18.43/src/tests/_internal/proxy/gateway}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/proxy/gateway/conftest.py +0 -0
- {dstack-0.18.41/src/tests/_internal/proxy/gateway/routers → dstack-0.18.43/src/tests/_internal/proxy/gateway/repo}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/proxy/gateway/repo/test_repo.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/proxy/gateway/repo/test_state_v1.py +0 -0
- {dstack-0.18.41/src/tests/_internal/proxy/gateway/services → dstack-0.18.43/src/tests/_internal/proxy/gateway/routers}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/proxy/gateway/routers/test_registry.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/proxy/gateway/routers/test_stats.py +0 -0
- {dstack-0.18.41/src/tests/_internal/proxy/lib → dstack-0.18.43/src/tests/_internal/proxy/gateway/services}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/proxy/gateway/services/test_stats.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/proxy/gateway/test_app.py +0 -0
- {dstack-0.18.41/src/tests/_internal/proxy/lib/routers → dstack-0.18.43/src/tests/_internal/proxy/lib}/__init__.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server → dstack-0.18.43/src/tests/_internal/proxy/lib/routers}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/proxy/lib/routers/test_model_proxy.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server/background → dstack-0.18.43/src/tests/_internal/server}/__init__.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server/background/tasks → dstack-0.18.43/src/tests/_internal/server/background}/__init__.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server/routers → dstack-0.18.43/src/tests/_internal/server/background/tasks}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/background/tasks/test_process_fleets.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/background/tasks/test_process_gateways.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/background/tasks/test_process_instances.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/background/tasks/test_process_metrics.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/background/tasks/test_process_placement_groups.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/background/tasks/test_process_runs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/background/tasks/test_process_submitted_volumes.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server/services → dstack-0.18.43/src/tests/_internal/server/routers}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/routers/test_fleets.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/routers/test_gateways.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/routers/test_instances.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/routers/test_metrics.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/routers/test_pools.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/routers/test_projects.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/routers/test_repos.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/routers/test_server.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/routers/test_users.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server/services/encryption → dstack-0.18.43/src/tests/_internal/server/services}/__init__.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server/services/encryption/keys → dstack-0.18.43/src/tests/_internal/server/services/encryption}/__init__.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server/services/jobs → dstack-0.18.43/src/tests/_internal/server/services/encryption/keys}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/services/encryption/keys/test_aes.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/services/encryption/test_encryption.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server/services/jobs/configurators → dstack-0.18.43/src/tests/_internal/server/services/jobs}/__init__.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server/services/proxy → dstack-0.18.43/src/tests/_internal/server/services/jobs/configurators}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/services/jobs/configurators/test_base.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server/services/proxy/routers → dstack-0.18.43/src/tests/_internal/server/services/proxy}/__init__.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server/services/runner → dstack-0.18.43/src/tests/_internal/server/services/proxy/routers}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/services/proxy/routers/test_service_proxy.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server/services/services → dstack-0.18.43/src/tests/_internal/server/services/runner}/__init__.py +0 -0
- {dstack-0.18.41/src/tests/_internal/server/utils → dstack-0.18.43/src/tests/_internal/server/services/services}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/services/services/test_autoscalers.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/services/test_config.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/services/test_docker.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/services/test_fleets.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/services/test_repos.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/services/test_runs.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/test_app.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/test_migrations.py +0 -0
- {dstack-0.18.41/src/tests/_internal → dstack-0.18.43/src/tests/_internal/server}/utils/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/utils/test_common.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/server/utils/test_routers.py +0 -0
- {dstack-0.18.41/src/tests/api → dstack-0.18.43/src/tests/_internal/utils}/__init__.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/utils/test_common.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/utils/test_env.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/utils/test_gpu.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/utils/test_interpolator.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/utils/test_network.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/utils/test_path.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/_internal/utils/test_ssh.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/api/test_utils.py +0 -0
- {dstack-0.18.41 → dstack-0.18.43}/src/tests/conftest.py +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: dstack
|
|
3
|
-
Version: 0.18.
|
|
3
|
+
Version: 0.18.43
|
|
4
4
|
Summary: dstack is an open-source orchestration engine for running AI workloads on any cloud or on-premises.
|
|
5
5
|
Home-page: https://dstack.ai
|
|
6
6
|
Author: Andrey Cheptsov
|
|
@@ -52,9 +52,9 @@ for AI workloads both in the cloud and on-prem, speeding up the development, tra
|
|
|
52
52
|
|
|
53
53
|
## Major news ✨
|
|
54
54
|
|
|
55
|
+
- [2025/02] [dstack 0.18.41: GPU blocks, Proxy jump, inactivity duration, and more](https://github.com/dstackai/dstack/releases/tag/0.18.41)
|
|
55
56
|
- [2025/01] [dstack 0.18.38: Intel Gaudi](https://github.com/dstackai/dstack/releases/tag/0.18.38)
|
|
56
57
|
- [2025/01] [dstack 0.18.35: Vultr](https://github.com/dstackai/dstack/releases/tag/0.18.35)
|
|
57
|
-
- [2024/12] [dstack 0.18.32: TPU v6e](https://github.com/dstackai/dstack/releases/tag/0.18.32)
|
|
58
58
|
- [2024/12] [dstack 0.18.30: AWS Capacity Reservations and Capacity Blocks](https://github.com/dstackai/dstack/releases/tag/0.18.30)
|
|
59
59
|
- [2024/10] [dstack 0.18.21: Instance volumes](https://github.com/dstackai/dstack/releases/tag/0.18.21)
|
|
60
60
|
- [2024/10] [dstack 0.18.18: Hardware metrics monitoring](https://github.com/dstackai/dstack/releases/tag/0.18.18)
|
|
@@ -25,9 +25,9 @@ for AI workloads both in the cloud and on-prem, speeding up the development, tra
|
|
|
25
25
|
|
|
26
26
|
## Major news ✨
|
|
27
27
|
|
|
28
|
+
- [2025/02] [dstack 0.18.41: GPU blocks, Proxy jump, inactivity duration, and more](https://github.com/dstackai/dstack/releases/tag/0.18.41)
|
|
28
29
|
- [2025/01] [dstack 0.18.38: Intel Gaudi](https://github.com/dstackai/dstack/releases/tag/0.18.38)
|
|
29
30
|
- [2025/01] [dstack 0.18.35: Vultr](https://github.com/dstackai/dstack/releases/tag/0.18.35)
|
|
30
|
-
- [2024/12] [dstack 0.18.32: TPU v6e](https://github.com/dstackai/dstack/releases/tag/0.18.32)
|
|
31
31
|
- [2024/12] [dstack 0.18.30: AWS Capacity Reservations and Capacity Blocks](https://github.com/dstackai/dstack/releases/tag/0.18.30)
|
|
32
32
|
- [2024/10] [dstack 0.18.21: Instance volumes](https://github.com/dstackai/dstack/releases/tag/0.18.21)
|
|
33
33
|
- [2024/10] [dstack 0.18.18: Hardware metrics monitoring](https://github.com/dstackai/dstack/releases/tag/0.18.18)
|
|
@@ -5,6 +5,7 @@ from typing import List, Optional
|
|
|
5
5
|
|
|
6
6
|
from rich_argparse import RichHelpFormatter
|
|
7
7
|
|
|
8
|
+
from dstack._internal.cli.services.completion import ProjectNameCompleter
|
|
8
9
|
from dstack._internal.cli.utils.common import configure_logging
|
|
9
10
|
from dstack.api import Client
|
|
10
11
|
|
|
@@ -61,7 +62,7 @@ class APIBaseCommand(BaseCommand):
|
|
|
61
62
|
help="The name of the project. Defaults to [code]$DSTACK_PROJECT[/]",
|
|
62
63
|
metavar="NAME",
|
|
63
64
|
default=os.getenv("DSTACK_PROJECT"),
|
|
64
|
-
)
|
|
65
|
+
).completer = ProjectNameCompleter()
|
|
65
66
|
|
|
66
67
|
def _command(self, args: argparse.Namespace):
|
|
67
68
|
configure_logging()
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import argparse
|
|
2
2
|
from pathlib import Path
|
|
3
3
|
|
|
4
|
+
from argcomplete import FilesCompleter
|
|
5
|
+
|
|
4
6
|
from dstack._internal.cli.commands import APIBaseCommand
|
|
5
7
|
from dstack._internal.cli.services.configurators import (
|
|
6
8
|
get_apply_configurator_class,
|
|
@@ -42,7 +44,7 @@ class ApplyCommand(APIBaseCommand):
|
|
|
42
44
|
metavar="FILE",
|
|
43
45
|
help="The path to the configuration file. Defaults to [code]$PWD/.dstack.yml[/]",
|
|
44
46
|
dest="configuration_file",
|
|
45
|
-
)
|
|
47
|
+
).completer = FilesCompleter(allowednames=["*.yml", "*.yaml"])
|
|
46
48
|
self._parser.add_argument(
|
|
47
49
|
"-y",
|
|
48
50
|
"--yes",
|
|
@@ -57,7 +59,7 @@ class ApplyCommand(APIBaseCommand):
|
|
|
57
59
|
self._parser.add_argument(
|
|
58
60
|
"-d",
|
|
59
61
|
"--detach",
|
|
60
|
-
help="Exit immediately after
|
|
62
|
+
help="Exit immediately after submitting configuration",
|
|
61
63
|
action="store_true",
|
|
62
64
|
)
|
|
63
65
|
repo_group = self._parser.add_argument_group("Repo Options")
|
|
@@ -6,6 +6,11 @@ from typing import Optional
|
|
|
6
6
|
|
|
7
7
|
from dstack._internal.cli.commands import APIBaseCommand
|
|
8
8
|
from dstack._internal.cli.services.args import port_mapping
|
|
9
|
+
from dstack._internal.cli.services.completion import RunNameCompleter
|
|
10
|
+
from dstack._internal.cli.services.configurators.run import (
|
|
11
|
+
get_run_exit_code,
|
|
12
|
+
print_finished_message,
|
|
13
|
+
)
|
|
9
14
|
from dstack._internal.cli.utils.common import console
|
|
10
15
|
from dstack._internal.core.consts import DSTACK_RUNNER_HTTP_PORT
|
|
11
16
|
from dstack._internal.core.errors import CLIError
|
|
@@ -57,7 +62,7 @@ class AttachCommand(APIBaseCommand):
|
|
|
57
62
|
type=int,
|
|
58
63
|
default=0,
|
|
59
64
|
)
|
|
60
|
-
self._parser.add_argument("run_name")
|
|
65
|
+
self._parser.add_argument("run_name").completer = RunNameCompleter()
|
|
61
66
|
|
|
62
67
|
def _command(self, args: argparse.Namespace):
|
|
63
68
|
super()._command(args)
|
|
@@ -99,6 +104,21 @@ class AttachCommand(APIBaseCommand):
|
|
|
99
104
|
pass
|
|
100
105
|
finally:
|
|
101
106
|
run.detach()
|
|
107
|
+
# TODO: Handle run resubmissions similar to dstack apply
|
|
108
|
+
|
|
109
|
+
# After reading the logs, the run may not be marked as finished immediately.
|
|
110
|
+
# Give the run some time to transition to a finished state before exiting.
|
|
111
|
+
for _ in range(30):
|
|
112
|
+
run.refresh()
|
|
113
|
+
if run.status.is_finished():
|
|
114
|
+
print_finished_message(run)
|
|
115
|
+
exit(get_run_exit_code(run))
|
|
116
|
+
time.sleep(1)
|
|
117
|
+
console.print(
|
|
118
|
+
"[error]Lost run connection. Timed out waiting for run final status."
|
|
119
|
+
" Check `dstack ps` to see if it's done or failed."
|
|
120
|
+
)
|
|
121
|
+
exit(1)
|
|
102
122
|
|
|
103
123
|
|
|
104
124
|
_IGNORED_PORTS = [DSTACK_RUNNER_HTTP_PORT]
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import argcomplete
|
|
2
|
+
|
|
3
|
+
from dstack._internal.cli.commands import BaseCommand
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
class CompletionCommand(BaseCommand):
|
|
7
|
+
NAME = "completion"
|
|
8
|
+
DESCRIPTION = "Generate shell completion scripts"
|
|
9
|
+
|
|
10
|
+
def _register(self):
|
|
11
|
+
super()._register()
|
|
12
|
+
self._parser.add_argument(
|
|
13
|
+
"shell",
|
|
14
|
+
help="The shell to generate the completion script for",
|
|
15
|
+
choices=["bash", "zsh"],
|
|
16
|
+
)
|
|
17
|
+
|
|
18
|
+
def _command(self, args):
|
|
19
|
+
super()._command(args)
|
|
20
|
+
print(argcomplete.shellcode(["dstack"], shell=args.shell))
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import argparse
|
|
2
2
|
from pathlib import Path
|
|
3
3
|
|
|
4
|
+
from argcomplete import FilesCompleter
|
|
5
|
+
|
|
4
6
|
from dstack._internal.cli.commands import APIBaseCommand
|
|
5
7
|
from dstack._internal.cli.services.configurators import (
|
|
6
8
|
get_apply_configurator_class,
|
|
@@ -22,7 +24,7 @@ class DeleteCommand(APIBaseCommand):
|
|
|
22
24
|
metavar="FILE",
|
|
23
25
|
help="The path to the configuration file. Defaults to [code]$PWD/.dstack.yml[/]",
|
|
24
26
|
dest="configuration_file",
|
|
25
|
-
)
|
|
27
|
+
).completer = FilesCompleter(allowednames=["*.yml", "*.yaml"])
|
|
26
28
|
self._parser.add_argument(
|
|
27
29
|
"-y",
|
|
28
30
|
"--yes",
|
|
@@ -4,6 +4,7 @@ import time
|
|
|
4
4
|
from rich.live import Live
|
|
5
5
|
|
|
6
6
|
from dstack._internal.cli.commands import APIBaseCommand
|
|
7
|
+
from dstack._internal.cli.services.completion import FleetNameCompleter
|
|
7
8
|
from dstack._internal.cli.utils.common import (
|
|
8
9
|
LIVE_TABLE_PROVISION_INTERVAL_SECS,
|
|
9
10
|
LIVE_TABLE_REFRESH_RATE_PER_SEC,
|
|
@@ -47,7 +48,7 @@ class FleetCommand(APIBaseCommand):
|
|
|
47
48
|
delete_parser.add_argument(
|
|
48
49
|
"name",
|
|
49
50
|
help="The name of the fleet",
|
|
50
|
-
)
|
|
51
|
+
).completer = FleetNameCompleter()
|
|
51
52
|
delete_parser.add_argument(
|
|
52
53
|
"-i",
|
|
53
54
|
"--instance",
|
|
@@ -4,6 +4,7 @@ import time
|
|
|
4
4
|
from rich.live import Live
|
|
5
5
|
|
|
6
6
|
from dstack._internal.cli.commands import APIBaseCommand
|
|
7
|
+
from dstack._internal.cli.services.completion import GatewayNameCompleter
|
|
7
8
|
from dstack._internal.cli.utils.common import (
|
|
8
9
|
LIVE_TABLE_PROVISION_INTERVAL_SECS,
|
|
9
10
|
LIVE_TABLE_REFRESH_RATE_PER_SEC,
|
|
@@ -59,7 +60,9 @@ class GatewayCommand(APIBaseCommand):
|
|
|
59
60
|
"delete", help="Delete a gateway", formatter_class=self._parser.formatter_class
|
|
60
61
|
)
|
|
61
62
|
delete_parser.set_defaults(subfunc=self._delete)
|
|
62
|
-
delete_parser.add_argument(
|
|
63
|
+
delete_parser.add_argument(
|
|
64
|
+
"name", help="The name of the gateway"
|
|
65
|
+
).completer = GatewayNameCompleter()
|
|
63
66
|
delete_parser.add_argument(
|
|
64
67
|
"-y", "--yes", action="store_true", help="Don't ask for confirmation"
|
|
65
68
|
)
|
|
@@ -68,7 +71,9 @@ class GatewayCommand(APIBaseCommand):
|
|
|
68
71
|
"update", help="Update a gateway", formatter_class=self._parser.formatter_class
|
|
69
72
|
)
|
|
70
73
|
update_parser.set_defaults(subfunc=self._update)
|
|
71
|
-
update_parser.add_argument(
|
|
74
|
+
update_parser.add_argument(
|
|
75
|
+
"name", help="The name of the gateway"
|
|
76
|
+
).completer = GatewayNameCompleter()
|
|
72
77
|
update_parser.add_argument(
|
|
73
78
|
"--set-default", action="store_true", help="Set it the default gateway for the project"
|
|
74
79
|
)
|
|
@@ -3,6 +3,7 @@ import sys
|
|
|
3
3
|
from pathlib import Path
|
|
4
4
|
|
|
5
5
|
from dstack._internal.cli.commands import APIBaseCommand
|
|
6
|
+
from dstack._internal.cli.services.completion import RunNameCompleter
|
|
6
7
|
from dstack._internal.core.errors import CLIError
|
|
7
8
|
from dstack._internal.utils.logging import get_logger
|
|
8
9
|
|
|
@@ -33,7 +34,7 @@ class LogsCommand(APIBaseCommand):
|
|
|
33
34
|
)
|
|
34
35
|
self._parser.add_argument(
|
|
35
36
|
"--replica",
|
|
36
|
-
help="The
|
|
37
|
+
help="The replica number. Defaults to 0.",
|
|
37
38
|
type=int,
|
|
38
39
|
default=0,
|
|
39
40
|
)
|
|
@@ -43,7 +44,7 @@ class LogsCommand(APIBaseCommand):
|
|
|
43
44
|
type=int,
|
|
44
45
|
default=0,
|
|
45
46
|
)
|
|
46
|
-
self._parser.add_argument("run_name")
|
|
47
|
+
self._parser.add_argument("run_name").completer = RunNameCompleter(all=True)
|
|
47
48
|
|
|
48
49
|
def _command(self, args: argparse.Namespace):
|
|
49
50
|
super()._command(args)
|
|
@@ -7,6 +7,7 @@ from rich.live import Live
|
|
|
7
7
|
from rich.table import Table
|
|
8
8
|
|
|
9
9
|
from dstack._internal.cli.commands import APIBaseCommand
|
|
10
|
+
from dstack._internal.cli.services.completion import RunNameCompleter
|
|
10
11
|
from dstack._internal.cli.utils.common import (
|
|
11
12
|
LIVE_TABLE_PROVISION_INTERVAL_SECS,
|
|
12
13
|
LIVE_TABLE_REFRESH_RATE_PER_SEC,
|
|
@@ -25,7 +26,7 @@ class StatsCommand(APIBaseCommand):
|
|
|
25
26
|
|
|
26
27
|
def _register(self):
|
|
27
28
|
super()._register()
|
|
28
|
-
self._parser.add_argument("run_name")
|
|
29
|
+
self._parser.add_argument("run_name").completer = RunNameCompleter()
|
|
29
30
|
self._parser.add_argument(
|
|
30
31
|
"-w",
|
|
31
32
|
"--watch",
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import argparse
|
|
2
2
|
|
|
3
3
|
from dstack._internal.cli.commands import APIBaseCommand
|
|
4
|
+
from dstack._internal.cli.services.completion import RunNameCompleter
|
|
4
5
|
from dstack._internal.cli.utils.common import confirm_ask
|
|
5
6
|
from dstack._internal.core.errors import CLIError
|
|
6
7
|
|
|
@@ -13,7 +14,7 @@ class StopCommand(APIBaseCommand):
|
|
|
13
14
|
super()._register()
|
|
14
15
|
self._parser.add_argument("-x", "--abort", action="store_true")
|
|
15
16
|
self._parser.add_argument("-y", "--yes", action="store_true")
|
|
16
|
-
self._parser.add_argument("run_name")
|
|
17
|
+
self._parser.add_argument("run_name").completer = RunNameCompleter()
|
|
17
18
|
|
|
18
19
|
def _command(self, args: argparse.Namespace):
|
|
19
20
|
super()._command(args)
|
|
@@ -4,6 +4,7 @@ import time
|
|
|
4
4
|
from rich.live import Live
|
|
5
5
|
|
|
6
6
|
from dstack._internal.cli.commands import APIBaseCommand
|
|
7
|
+
from dstack._internal.cli.services.completion import VolumeNameCompleter
|
|
7
8
|
from dstack._internal.cli.utils.common import (
|
|
8
9
|
LIVE_TABLE_PROVISION_INTERVAL_SECS,
|
|
9
10
|
LIVE_TABLE_REFRESH_RATE_PER_SEC,
|
|
@@ -47,7 +48,7 @@ class VolumeCommand(APIBaseCommand):
|
|
|
47
48
|
delete_parser.add_argument(
|
|
48
49
|
"name",
|
|
49
50
|
help="The name of the volume",
|
|
50
|
-
)
|
|
51
|
+
).completer = VolumeNameCompleter()
|
|
51
52
|
delete_parser.add_argument(
|
|
52
53
|
"-y", "--yes", help="Don't ask for confirmation", action="store_true"
|
|
53
54
|
)
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import argparse
|
|
2
2
|
|
|
3
|
+
import argcomplete
|
|
3
4
|
from rich.markup import escape
|
|
4
5
|
from rich_argparse import RichHelpFormatter
|
|
5
6
|
|
|
6
7
|
from dstack._internal.cli.commands.apply import ApplyCommand
|
|
7
8
|
from dstack._internal.cli.commands.attach import AttachCommand
|
|
9
|
+
from dstack._internal.cli.commands.completion import CompletionCommand
|
|
8
10
|
from dstack._internal.cli.commands.config import ConfigCommand
|
|
9
11
|
from dstack._internal.cli.commands.delete import DeleteCommand
|
|
10
12
|
from dstack._internal.cli.commands.fleet import FleetCommand
|
|
@@ -72,9 +74,13 @@ def main():
|
|
|
72
74
|
StatsCommand.register(subparsers)
|
|
73
75
|
StopCommand.register(subparsers)
|
|
74
76
|
VolumeCommand.register(subparsers)
|
|
77
|
+
CompletionCommand.register(subparsers)
|
|
78
|
+
|
|
79
|
+
argcomplete.autocomplete(parser, always_complete_options=False)
|
|
75
80
|
|
|
76
81
|
args, unknown_args = parser.parse_known_args()
|
|
77
82
|
args.unknown = unknown_args
|
|
83
|
+
|
|
78
84
|
try:
|
|
79
85
|
check_for_updates()
|
|
80
86
|
get_ssh_client_info()
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import argparse
|
|
2
|
+
import os
|
|
3
|
+
from abc import ABC, abstractmethod
|
|
4
|
+
from typing import Iterable, List, Optional
|
|
5
|
+
|
|
6
|
+
import argcomplete
|
|
7
|
+
from argcomplete.completers import BaseCompleter
|
|
8
|
+
|
|
9
|
+
from dstack._internal.core.errors import ConfigurationError
|
|
10
|
+
from dstack._internal.core.services.configs import ConfigManager
|
|
11
|
+
from dstack.api import Client
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
class BaseAPINameCompleter(BaseCompleter, ABC):
|
|
15
|
+
"""
|
|
16
|
+
Base class for name completers that fetch resource names via the API.
|
|
17
|
+
"""
|
|
18
|
+
|
|
19
|
+
def __init__(self):
|
|
20
|
+
super().__init__()
|
|
21
|
+
|
|
22
|
+
def get_api(self, parsed_args: argparse.Namespace) -> Optional[Client]:
|
|
23
|
+
argcomplete.debug(f"{self.__class__.__name__}: Retrieving API client")
|
|
24
|
+
project = getattr(parsed_args, "project", os.getenv("DSTACK_PROJECT"))
|
|
25
|
+
try:
|
|
26
|
+
return Client.from_config(project_name=project)
|
|
27
|
+
except ConfigurationError as e:
|
|
28
|
+
argcomplete.debug(f"{self.__class__.__name__}: Error initializing API client: {e}")
|
|
29
|
+
return None
|
|
30
|
+
|
|
31
|
+
def __call__(self, prefix: str, parsed_args: argparse.Namespace, **kwargs) -> List[str]:
|
|
32
|
+
api = self.get_api(parsed_args)
|
|
33
|
+
if api is None:
|
|
34
|
+
return []
|
|
35
|
+
|
|
36
|
+
argcomplete.debug(f"{self.__class__.__name__}: Fetching completions")
|
|
37
|
+
try:
|
|
38
|
+
resource_names = self.fetch_resource_names(api)
|
|
39
|
+
return [name for name in resource_names if name.startswith(prefix)]
|
|
40
|
+
except Exception as e:
|
|
41
|
+
argcomplete.debug(
|
|
42
|
+
f"{self.__class__.__name__}: Error fetching resource completions: {e}"
|
|
43
|
+
)
|
|
44
|
+
return []
|
|
45
|
+
|
|
46
|
+
@abstractmethod
|
|
47
|
+
def fetch_resource_names(self, api: Client) -> Iterable[str]:
|
|
48
|
+
"""
|
|
49
|
+
Returns an iterable of resource names.
|
|
50
|
+
"""
|
|
51
|
+
pass
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
class RunNameCompleter(BaseAPINameCompleter):
|
|
55
|
+
def __init__(self, all: bool = False):
|
|
56
|
+
super().__init__()
|
|
57
|
+
self.all = all
|
|
58
|
+
|
|
59
|
+
def fetch_resource_names(self, api: Client) -> Iterable[str]:
|
|
60
|
+
return [r.name for r in api.runs.list(self.all)]
|
|
61
|
+
|
|
62
|
+
|
|
63
|
+
class FleetNameCompleter(BaseAPINameCompleter):
|
|
64
|
+
def fetch_resource_names(self, api: Client) -> Iterable[str]:
|
|
65
|
+
return [r.name for r in api.client.fleets.list(api.project)]
|
|
66
|
+
|
|
67
|
+
|
|
68
|
+
class VolumeNameCompleter(BaseAPINameCompleter):
|
|
69
|
+
def fetch_resource_names(self, api: Client) -> Iterable[str]:
|
|
70
|
+
return [r.name for r in api.client.volumes.list(api.project)]
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
class GatewayNameCompleter(BaseAPINameCompleter):
|
|
74
|
+
def fetch_resource_names(self, api: Client) -> Iterable[str]:
|
|
75
|
+
return [r.name for r in api.client.gateways.list(api.project)]
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
class ProjectNameCompleter(BaseCompleter):
|
|
79
|
+
"""
|
|
80
|
+
Completer for local project names.
|
|
81
|
+
"""
|
|
82
|
+
|
|
83
|
+
def __call__(self, prefix: str, parsed_args: argparse.Namespace, **kwargs) -> List[str]:
|
|
84
|
+
argcomplete.debug(f"{self.__class__.__name__}: Listing projects from ConfigManager")
|
|
85
|
+
projects = ConfigManager().list_projects()
|
|
86
|
+
return [p for p in projects if p.startswith(prefix)]
|
|
@@ -34,7 +34,6 @@ from dstack._internal.core.models.configurations import (
|
|
|
34
34
|
BaseRunConfigurationWithPorts,
|
|
35
35
|
DevEnvironmentConfiguration,
|
|
36
36
|
PortMapping,
|
|
37
|
-
PythonVersion,
|
|
38
37
|
RunConfigurationType,
|
|
39
38
|
ServiceConfiguration,
|
|
40
39
|
TaskConfiguration,
|
|
@@ -73,12 +72,6 @@ class BaseRunConfigurator(ApplyEnvVarsConfiguratorMixin, BaseApplyConfigurator):
|
|
|
73
72
|
):
|
|
74
73
|
self.apply_args(conf, configurator_args, unknown_args)
|
|
75
74
|
self.validate_gpu_vendor_and_image(conf)
|
|
76
|
-
if conf.python == PythonVersion.PY38:
|
|
77
|
-
logger.warning(
|
|
78
|
-
"Specifying [code]python: 3.8[/] in run configurations is deprecated"
|
|
79
|
-
" and will be forbidden in a future [code]dstack[/] release."
|
|
80
|
-
" Please upgrade your configuration to a newer Python version."
|
|
81
|
-
)
|
|
82
75
|
if repo is None:
|
|
83
76
|
repo = self.api.repos.load(Path.cwd())
|
|
84
77
|
config_manager = ConfigManager()
|
|
@@ -238,8 +231,8 @@ class BaseRunConfigurator(ApplyEnvVarsConfiguratorMixin, BaseApplyConfigurator):
|
|
|
238
231
|
reattach = True
|
|
239
232
|
break
|
|
240
233
|
if run.status.is_finished():
|
|
241
|
-
|
|
242
|
-
exit(
|
|
234
|
+
print_finished_message(run)
|
|
235
|
+
exit(get_run_exit_code(run))
|
|
243
236
|
time.sleep(1)
|
|
244
237
|
if not reattach:
|
|
245
238
|
console.print(
|
|
@@ -439,7 +432,7 @@ class RunWithPortsConfigurator(BaseRunConfigurator):
|
|
|
439
432
|
):
|
|
440
433
|
super().apply_args(conf, args, unknown)
|
|
441
434
|
if args.ports:
|
|
442
|
-
conf.ports = list(
|
|
435
|
+
conf.ports = list(_merge_ports(conf.ports, args.ports).values())
|
|
443
436
|
|
|
444
437
|
|
|
445
438
|
class TaskConfigurator(RunWithPortsConfigurator):
|
|
@@ -475,17 +468,17 @@ class ServiceConfigurator(BaseRunConfigurator):
|
|
|
475
468
|
self.interpolate_run_args(conf.commands, unknown)
|
|
476
469
|
|
|
477
470
|
|
|
478
|
-
def
|
|
479
|
-
|
|
480
|
-
|
|
471
|
+
def _merge_ports(conf: List[PortMapping], args: List[PortMapping]) -> Dict[int, PortMapping]:
|
|
472
|
+
_unique_ports_constraint([pm.container_port for pm in conf])
|
|
473
|
+
_unique_ports_constraint([pm.container_port for pm in args])
|
|
481
474
|
ports = {pm.container_port: pm for pm in conf}
|
|
482
475
|
for pm in args: # override conf
|
|
483
476
|
ports[pm.container_port] = pm
|
|
484
|
-
|
|
477
|
+
_unique_ports_constraint([pm.local_port for pm in ports.values() if pm.local_port is not None])
|
|
485
478
|
return ports
|
|
486
479
|
|
|
487
480
|
|
|
488
|
-
def
|
|
481
|
+
def _unique_ports_constraint(ports: List[int]):
|
|
489
482
|
used_ports = set()
|
|
490
483
|
for i in ports:
|
|
491
484
|
if i in used_ports:
|
|
@@ -514,7 +507,7 @@ def _print_service_urls(run: Run) -> None:
|
|
|
514
507
|
console.print()
|
|
515
508
|
|
|
516
509
|
|
|
517
|
-
def
|
|
510
|
+
def print_finished_message(run: Run):
|
|
518
511
|
if run.status == RunStatus.DONE:
|
|
519
512
|
console.print("[code]Done[/]")
|
|
520
513
|
return
|
|
@@ -542,7 +535,7 @@ def _print_finished_message(run: Run):
|
|
|
542
535
|
console.print(f"[error]{message}[/]")
|
|
543
536
|
|
|
544
537
|
|
|
545
|
-
def
|
|
538
|
+
def get_run_exit_code(run: Run) -> int:
|
|
546
539
|
if run.status == RunStatus.DONE:
|
|
547
540
|
return 0
|
|
548
541
|
return 1
|
|
@@ -45,7 +45,11 @@ def get_fleets_table(
|
|
|
45
45
|
status = instance.status.value
|
|
46
46
|
total_blocks = instance.total_blocks
|
|
47
47
|
busy_blocks = instance.busy_blocks
|
|
48
|
-
if
|
|
48
|
+
if (
|
|
49
|
+
instance.status in [InstanceStatus.IDLE, InstanceStatus.BUSY]
|
|
50
|
+
and total_blocks is not None
|
|
51
|
+
and total_blocks > 1
|
|
52
|
+
):
|
|
49
53
|
status = f"{busy_blocks}/{total_blocks} {InstanceStatus.BUSY.value}"
|
|
50
54
|
if (
|
|
51
55
|
instance.status in [InstanceStatus.IDLE, InstanceStatus.BUSY]
|
|
@@ -22,6 +22,8 @@ def get_volumes_table(
|
|
|
22
22
|
if verbose:
|
|
23
23
|
table.add_column("REGION")
|
|
24
24
|
table.add_column("STATUS")
|
|
25
|
+
if verbose:
|
|
26
|
+
table.add_column("ATTACHED")
|
|
25
27
|
table.add_column("CREATED")
|
|
26
28
|
if verbose:
|
|
27
29
|
table.add_column("ERROR")
|
|
@@ -37,11 +39,18 @@ def get_volumes_table(
|
|
|
37
39
|
and volume.provisioning_data.availability_zone is not None
|
|
38
40
|
):
|
|
39
41
|
region += f" ({volume.provisioning_data.availability_zone})"
|
|
42
|
+
attached = "-"
|
|
43
|
+
if volume.attachments is not None:
|
|
44
|
+
attached = ", ".join(
|
|
45
|
+
{va.instance.fleet_name for va in volume.attachments if va.instance.fleet_name}
|
|
46
|
+
)
|
|
47
|
+
attached = attached or "-"
|
|
40
48
|
row = {
|
|
41
49
|
"NAME": volume.name,
|
|
42
50
|
"BACKEND": backend,
|
|
43
51
|
"REGION": region,
|
|
44
52
|
"STATUS": volume.status,
|
|
53
|
+
"ATTACHED": attached,
|
|
45
54
|
"CREATED": format_date(volume.created_at),
|
|
46
55
|
"ERROR": volume.status_message,
|
|
47
56
|
}
|
|
@@ -11,8 +11,11 @@ from dstack._internal import settings
|
|
|
11
11
|
from dstack._internal.core.backends.aws.config import AWSConfig
|
|
12
12
|
from dstack._internal.core.backends.base.compute import (
|
|
13
13
|
Compute,
|
|
14
|
+
generate_unique_gateway_instance_name,
|
|
15
|
+
generate_unique_instance_name,
|
|
16
|
+
generate_unique_volume_name,
|
|
14
17
|
get_gateway_user_data,
|
|
15
|
-
|
|
18
|
+
get_job_instance_name,
|
|
16
19
|
get_user_data,
|
|
17
20
|
merge_tags,
|
|
18
21
|
)
|
|
@@ -152,10 +155,12 @@ class AWSCompute(Compute):
|
|
|
152
155
|
if zones is not None and len(zones) == 0:
|
|
153
156
|
raise NoCapacityError("No eligible availability zones")
|
|
154
157
|
|
|
158
|
+
instance_name = generate_unique_instance_name(instance_config)
|
|
155
159
|
tags = {
|
|
156
|
-
"Name":
|
|
160
|
+
"Name": instance_name,
|
|
157
161
|
"owner": "dstack",
|
|
158
162
|
"dstack_project": project_name,
|
|
163
|
+
"dstack_name": instance_config.instance_name,
|
|
159
164
|
"dstack_user": instance_config.user,
|
|
160
165
|
}
|
|
161
166
|
tags = merge_tags(tags=tags, backend_tags=self.config.tags)
|
|
@@ -214,7 +219,7 @@ class AWSCompute(Compute):
|
|
|
214
219
|
disk_size=disk_size,
|
|
215
220
|
image_id=image_id,
|
|
216
221
|
instance_type=instance_offer.instance.name,
|
|
217
|
-
|
|
222
|
+
iam_instance_profile=self.config.iam_instance_profile,
|
|
218
223
|
user_data=get_user_data(authorized_keys=instance_config.get_public_keys()),
|
|
219
224
|
tags=aws_resources.make_tags(tags),
|
|
220
225
|
security_group_id=aws_resources.create_security_group(
|
|
@@ -259,6 +264,9 @@ class AWSCompute(Compute):
|
|
|
259
264
|
)
|
|
260
265
|
except botocore.exceptions.ClientError as e:
|
|
261
266
|
logger.warning("Got botocore.exceptions.ClientError: %s", e)
|
|
267
|
+
if e.response["Error"]["Code"] == "InvalidParameterValue":
|
|
268
|
+
msg = e.response["Error"].get("Message", "")
|
|
269
|
+
raise ComputeError(f"Invalid AWS request: {msg}")
|
|
262
270
|
continue
|
|
263
271
|
raise NoCapacityError()
|
|
264
272
|
|
|
@@ -274,7 +282,7 @@ class AWSCompute(Compute):
|
|
|
274
282
|
# TODO: run_job is the same for vm-based backends, refactor
|
|
275
283
|
instance_config = InstanceConfiguration(
|
|
276
284
|
project_name=run.project_name,
|
|
277
|
-
instance_name=
|
|
285
|
+
instance_name=get_job_instance_name(run, job), # TODO: generate name
|
|
278
286
|
ssh_keys=[
|
|
279
287
|
SSHKey(public=project_ssh_public_key.strip()),
|
|
280
288
|
],
|
|
@@ -342,10 +350,12 @@ class AWSCompute(Compute):
|
|
|
342
350
|
ec2_resource = self.session.resource("ec2", region_name=configuration.region)
|
|
343
351
|
ec2_client = self.session.client("ec2", region_name=configuration.region)
|
|
344
352
|
|
|
353
|
+
instance_name = generate_unique_gateway_instance_name(configuration)
|
|
345
354
|
tags = {
|
|
346
|
-
"Name":
|
|
355
|
+
"Name": instance_name,
|
|
347
356
|
"owner": "dstack",
|
|
348
357
|
"dstack_project": configuration.project_name,
|
|
358
|
+
"dstack_name": configuration.instance_name,
|
|
349
359
|
}
|
|
350
360
|
if settings.DSTACK_VERSION is not None:
|
|
351
361
|
tags["dstack_version"] = settings.DSTACK_VERSION
|
|
@@ -373,7 +383,7 @@ class AWSCompute(Compute):
|
|
|
373
383
|
disk_size=10,
|
|
374
384
|
image_id=aws_resources.get_gateway_image_id(ec2_client),
|
|
375
385
|
instance_type="t2.micro",
|
|
376
|
-
|
|
386
|
+
iam_instance_profile=None,
|
|
377
387
|
user_data=get_gateway_user_data(configuration.ssh_key_pub),
|
|
378
388
|
tags=tags,
|
|
379
389
|
security_group_id=security_group_id,
|
|
@@ -403,7 +413,7 @@ class AWSCompute(Compute):
|
|
|
403
413
|
|
|
404
414
|
logger.debug("Creating ALB for gateway %s...", configuration.instance_name)
|
|
405
415
|
response = elb_client.create_load_balancer(
|
|
406
|
-
Name=f"{
|
|
416
|
+
Name=f"{instance_name}-lb",
|
|
407
417
|
Subnets=subnets_ids,
|
|
408
418
|
SecurityGroups=[security_group_id],
|
|
409
419
|
Scheme="internet-facing" if configuration.public_ip else "internal",
|
|
@@ -418,7 +428,7 @@ class AWSCompute(Compute):
|
|
|
418
428
|
|
|
419
429
|
logger.debug("Creating Target Group for gateway %s...", configuration.instance_name)
|
|
420
430
|
response = elb_client.create_target_group(
|
|
421
|
-
Name=f"{
|
|
431
|
+
Name=f"{instance_name}-tg",
|
|
422
432
|
Protocol="HTTP",
|
|
423
433
|
Port=80,
|
|
424
434
|
VpcId=vpc_id,
|
|
@@ -535,11 +545,13 @@ class AWSCompute(Compute):
|
|
|
535
545
|
def create_volume(self, volume: Volume) -> VolumeProvisioningData:
|
|
536
546
|
ec2_client = self.session.client("ec2", region_name=volume.configuration.region)
|
|
537
547
|
|
|
548
|
+
volume_name = generate_unique_volume_name(volume)
|
|
538
549
|
tags = {
|
|
539
|
-
"Name":
|
|
550
|
+
"Name": volume_name,
|
|
540
551
|
"owner": "dstack",
|
|
541
|
-
"dstack_user": volume.user,
|
|
542
552
|
"dstack_project": volume.project_name,
|
|
553
|
+
"dstack_name": volume.name,
|
|
554
|
+
"dstack_user": volume.user,
|
|
543
555
|
}
|
|
544
556
|
tags = merge_tags(tags=tags, backend_tags=self.config.tags)
|
|
545
557
|
|
|
@@ -635,11 +647,12 @@ class AWSCompute(Compute):
|
|
|
635
647
|
ec2_client = self.session.client("ec2", region_name=volume.configuration.region)
|
|
636
648
|
|
|
637
649
|
logger.debug("Detaching EBS volume %s from instance %s", volume.volume_id, instance_id)
|
|
650
|
+
attachment_data = get_or_error(volume.get_attachment_data_for_instance(instance_id))
|
|
638
651
|
try:
|
|
639
652
|
ec2_client.detach_volume(
|
|
640
653
|
VolumeId=volume.volume_id,
|
|
641
654
|
InstanceId=instance_id,
|
|
642
|
-
Device=
|
|
655
|
+
Device=attachment_data.device_name,
|
|
643
656
|
Force=force,
|
|
644
657
|
)
|
|
645
658
|
except botocore.exceptions.ClientError as e:
|