このコンテンツはまだ日本語訳がありません。
Sandbox
Sandbox class for Daytona SDK.
Constructors
new Sandbox()
def initialize(code_toolbox:, sandbox_dto:, config:, sandbox_api:, get_proxy_toolbox_url:)Returns:
Sandbox- a new instance of Sandbox
Methods
id()
def id()Returns:
String- The ID of the sandbox
organization_id()
def organization_id()Returns:
String- The organization ID of the sandbox
snapshot()
def snapshot()Returns:
String- The snapshot used for the sandbox
user()
def user()Returns:
String- The user associated with the project
env()
def env()Returns:
Hash\<String, String\>- Environment variables for the sandbox
labels()
def labels()Returns:
Hash\<String, String\>- Labels for the sandbox
public()
def public()Returns:
Boolean- Whether the sandbox http preview is public
network_block_all()
def network_block_all()Returns:
Boolean- Whether to block all network access for the sandbox
network_allow_list()
def network_allow_list()Returns:
String- Comma-separated list of allowed CIDR network addresses for the sandbox
target()
def target()Returns:
String- The target environment for the sandbox
cpu()
def cpu()Returns:
Float- The CPU quota for the sandbox
gpu()
def gpu()Returns:
Float- The GPU quota for the sandbox
memory()
def memory()Returns:
Float- The memory quota for the sandbox
disk()
def disk()Returns:
Float- The disk quota for the sandbox
state()
def state()Returns:
DaytonaApiClient:SandboxState- The state of the sandbox
desired_state()
def desired_state()Returns:
DaytonaApiClient:SandboxDesiredState- The desired state of the sandbox
error_reason()
def error_reason()Returns:
String- The error reason of the sandbox
backup_state()
def backup_state()Returns:
String- The state of the backup
backup_created_at()
def backup_created_at()Returns:
String- The creation timestamp of the last backup
auto_stop_interval()
def auto_stop_interval()Returns:
Float- Auto-stop interval in minutes (0 means disabled)
auto_archive_interval()
def auto_archive_interval()Returns:
Float- Auto-archive interval in minutes
auto_delete_interval()
def auto_delete_interval()(negative value means disabled, 0 means delete immediately upon stopping)
Returns:
Float- Auto-delete interval in minutes
volumes()
def volumes()Returns:
Array\<DaytonaApiClient:SandboxVolume\>- Array of volumes attached to the sandbox
build_info()
def build_info()Returns:
DaytonaApiClient:BuildInfo- Build information for the sandbox
created_at()
def created_at()Returns:
String- The creation timestamp of the sandbox
updated_at()
def updated_at()Returns:
String- The last update timestamp of the sandbox
daemon_version()
def daemon_version()Returns:
String- The version of the daemon running in the sandbox
code_toolbox()
def code_toolbox()Returns:
Daytona:SandboxPythonCodeToolbox, Daytona:SandboxTsCodeToolbox
config()
def config()Returns:
Daytona:Config
sandbox_api()
def sandbox_api()Returns:
DaytonaApiClient:SandboxApi
process()
def process()Returns:
Daytona:Process
fs()
def fs()Returns:
Daytona:FileSystem
git()
def git()Returns:
Daytona:Git
computer_use()
def computer_use()Returns:
Daytona:ComputerUse
code_interpreter()
def code_interpreter()Returns:
Daytona:CodeInterpreter
archive()
def archive()Archives the sandbox, making it inactive and preserving its state. When sandboxes are archived, the entire filesystem state is moved to cost-effective object storage, making it possible to keep sandboxes available for an extended period. The tradeoff between archived and stopped states is that starting an archived sandbox takes more time, depending on its size. Sandbox must be stopped before archiving.
Returns:
void
auto_archive_interval=()
def auto_archive_interval=(interval)Sets the auto-archive interval for the Sandbox. The Sandbox will automatically archive after being continuously stopped for the specified interval.
Parameters:
intervalInteger -
Returns:
Integer
Raises:
Daytona:Sdk:Error-
auto_delete_interval=()
def auto_delete_interval=(interval)Sets the auto-delete interval for the Sandbox. The Sandbox will automatically delete after being continuously stopped for the specified interval.
Parameters:
intervalInteger -
Returns:
Integer
Raises:
Daytona:Sdk:Error-
auto_stop_interval=()
def auto_stop_interval=(interval)Sets the auto-stop interval for the Sandbox. The Sandbox will automatically stop after being idle (no new events) for the specified interval. Events include any state changes or interactions with the Sandbox through the SDK. Interactions using Sandbox Previews are not included.
Parameters:
intervalInteger -
Returns:
Integer
Raises:
Daytona:Sdk:Error-
create_ssh_access()
def create_ssh_access(expires_in_minutes)Creates an SSH access token for the sandbox.
Parameters:
expires_in_minutesInteger - TThe number of minutes the SSH access token will be valid for
Returns:
DaytonaApiClient:SshAccessDto
delete()
def delete()Returns:
void
get_user_home_dir()
def get_user_home_dir()Gets the user’s home directory path for the logged in user inside the Sandbox.
Returns:
String- The absolute path to the Sandbox user’s home directory for the logged in user
Examples:
user_home_dir = sandbox.get_user_home_dirputs "Sandbox user home: #{user_home_dir}"get_work_dir()
def get_work_dir()Gets the working directory path inside the Sandbox.
Returns:
String- The absolute path to the Sandbox working directory. Uses the WORKDIR specified in the Dockerfile if present, or falling back to the user’s home directory if not.
Examples:
work_dir = sandbox.get_work_dirputs "Sandbox working directory: #{work_dir}"labels=()
def labels=(labels)Sets labels for the Sandbox.
Parameters:
labelsHash<String, String> -
Returns:
Hash\<String, String\>
preview_url()
def preview_url(port)Retrieves the preview link for the sandbox at the specified port. If the port is closed, it will be opened automatically. For private sandboxes, a token is included to grant access to the URL.
Parameters:
portInteger -
Returns:
DaytonaApiClient:PortPreviewUrl
create_signed_preview_url()
def create_signed_preview_url(port, expires_in_seconds)Creates a signed preview URL for the sandbox at the specified port.
Parameters:
portInteger - The port to open the preview link onexpires_in_secondsInteger, nil - The number of seconds the signed preview URL will be valid for. Defaults to 60 seconds.
Returns:
DaytonaApiClient:SignedPortPreviewUrl- The signed preview URL response object
Examples:
signed_url = sandbox.create_signed_preview_url(3000, 120)puts "Signed URL: #{signed_url.url}"puts "Token: #{signed_url.token}"expire_signed_preview_url()
def expire_signed_preview_url(port, token)Expires a signed preview URL for the sandbox at the specified port.
Parameters:
portInteger - The port to expire the signed preview URL ontokenString - The token to expire
Returns:
void
Examples:
sandbox.expire_signed_preview_url(3000, "token-value")refresh()
def refresh()Refresh the Sandbox data from the API.
Returns:
void
refresh_activity()
def refresh_activity()Refreshes the sandbox activity to reset the timer for automated lifecycle management actions.
This method updates the sandbox’s last activity timestamp without changing its state. It is useful for keeping long-running sessions alive while there is still user activity.
Returns:
void
Examples:
sandbox.refresh_activityrevoke_ssh_access()
def revoke_ssh_access(token)Revokes an SSH access token for the sandbox.
Parameters:
tokenString -
Returns:
void
start()
def start(timeout)Starts the Sandbox and waits for it to be ready.
Parameters:
timeoutNumeric - Maximum wait time in seconds (defaults to 60 s).
Returns:
void
recover()
def recover(timeout)Recovers the Sandbox from a recoverable error and waits for it to be ready.
Parameters:
timeoutNumeric - Maximum wait time in seconds (defaults to 60 s).
Returns:
void
Examples:
sandbox = daytona.get('my-sandbox-id')sandbox.recover(timeout: 40) # Wait up to 40 secondsputs 'Sandbox recovered successfully'stop()
def stop(timeout)Stops the Sandbox and waits for it to be stopped.
Parameters:
timeoutNumeric - Maximum wait time in seconds (defaults to 60 s).
Returns:
void
create_lsp_server()
def create_lsp_server(language_id:, path_to_project:)Creates a new Language Server Protocol (LSP) server instance. The LSP server provides language-specific features like code completion, diagnostics, and more.
Parameters:
language_idSymbol - The language server type (e.g., Daytona::LspServer::Language::PYTHON)path_to_projectString - Path to the project root directory. Relative paths are resolved based on the sandbox working directory.
Returns:
Daytona:LspServer
validate_ssh_access()
def validate_ssh_access(token)Validates an SSH access token for the sandbox.
Parameters:
tokenString -
Returns:
DaytonaApiClient:SshAccessValidationDto
wait_for_sandbox_start()
def wait_for_sandbox_start(_timeout)Waits for the Sandbox to reach the ‘started’ state. Polls the Sandbox status until it reaches the ‘started’ state or encounters an error.
Parameters:
timeoutNumeric - Maximum wait time in seconds (defaults to 60 s).
Returns:
void
wait_for_sandbox_stop()
def wait_for_sandbox_stop(_timeout)Waits for the Sandbox to reach the ‘stopped’ state. Polls the Sandbox status until it reaches the ‘stopped’ state or encounters an error. Treats destroyed as stopped to cover ephemeral sandboxes that are automatically deleted after stopping.
Parameters:
timeoutNumeric - Maximum wait time in seconds (defaults to 60 s).
Returns:
void