Source code for sky.volumes.client.sdk

"""SDK functions for managed jobs."""
import json
import typing
from typing import Any, Dict, List

from sky import sky_logging
from sky.adaptors import common as adaptors_common
from sky.server import common as server_common
from sky.server.requests import payloads
from sky.usage import usage_lib
from sky.utils import annotations
from sky.utils import context
from sky.volumes import volume as volume_lib

if typing.TYPE_CHECKING:
    import requests
else:
    requests = adaptors_common.LazyImport('requests')

logger = sky_logging.init_logger(__name__)


[docs]@context.contextual @usage_lib.entrypoint @server_common.check_server_healthy_or_start @annotations.client_api def apply(volume: volume_lib.Volume) -> server_common.RequestId[None]: """Creates or registers a volume. Example: .. code-block:: python import sky.volumes cfg = { 'name': 'pvc', 'type': 'k8s-pvc', 'size': '100GB', 'labels': { 'key': 'value', }, } vol = sky.volumes.Volume.from_yaml_config(cfg) request_id = sky.volumes.apply(vol) sky.get(request_id) or import sky.volumes vol = sky.volumes.Volume( name='vol', type='runpod-network-volume', infra='runpod/ca/CA-MTL-1', size='100GB', ) request_id = sky.volumes.apply(vol) sky.get(request_id) Args: volume: The volume to apply. Returns: The request ID of the apply request. """ body = payloads.VolumeApplyBody( name=volume.name, volume_type=volume.type, cloud=volume.cloud, region=volume.region, zone=volume.zone, size=volume.size, config=volume.config, labels=volume.labels, ) response = requests.post(f'{server_common.get_server_url()}/volumes/apply', json=json.loads(body.model_dump_json()), cookies=server_common.get_api_cookie_jar()) return server_common.get_request_id(response)
[docs]@context.contextual @usage_lib.entrypoint @server_common.check_server_healthy_or_start @annotations.client_api def ls() -> server_common.RequestId[List[Dict[str, Any]]]: """Lists all volumes. Returns: The request ID of the list request. """ response = requests.get(f'{server_common.get_server_url()}/volumes', cookies=server_common.get_api_cookie_jar()) return server_common.get_request_id(response)
[docs]@context.contextual @usage_lib.entrypoint @server_common.check_server_healthy_or_start @annotations.client_api def delete(names: List[str]) -> server_common.RequestId[None]: """Deletes volumes. Args: names: List of volume names to delete. Returns: The request ID of the delete request. """ body = payloads.VolumeDeleteBody(names=names) response = requests.post(f'{server_common.get_server_url()}/volumes/delete', json=json.loads(body.model_dump_json()), cookies=server_common.get_api_cookie_jar()) return server_common.get_request_id(response)