Skip to main content

Novita Agent Sandbox SDK - Python library for Novita Agent Sandbox

Project description

Novita Agent Sandbox SDK for Python

A Python SDK for Novita Agent Sandbox environments that provides code execution, desktop automation, and cloud computing capabilities. Compatible with e2b.

📖 Documentation🔑 Get API Key

Features

  • Code Interpreter: Execute Python, JavaScript, and other languages in isolated environments
  • Desktop Automation: Control desktop applications and GUI interactions
  • Cloud Computing: Scalable sandbox environments for various computing tasks
  • Data Visualization: Built-in charting and visualization capabilities
  • File System Operations: Complete file system management and monitoring

Installation

pip install novita-sandbox

Quick Start

Authentication

Get your Novita API key from the key management page.

Core Sandbox

The basic package provides a way to interact with the sandbox environment.

from novita_sandbox.core import Sandbox
import os

# Using the official template `base` by default
sandbox = Sandbox.create(
    template="base",
    api_key=os.getenv("NOVITA_API_KEY", "")
)

# File operations
sandbox.files.write('/tmp/test.txt', 'Hello, World!')
content = sandbox.files.read('/tmp/test.txt')

# Command execution
result = sandbox.commands.run('ls -la /tmp')
print(result.stdout)

sandbox.kill()

Code Interpreter

The Code Interpreter sandbox provides a Jupyter-like environment for executing code using the official code-interpreter-v1 template.

from novita_sandbox.code_interpreter import Sandbox
import os

sandbox = Sandbox.create(
    api_key=os.getenv("NOVITA_API_KEY", "")
)

# Execute Python code
result = sandbox.run_code('print("Hello, World!")')
print(result.logs)

sandbox.kill()

Desktop Automation

The Desktop sandbox allows you to control desktop environments programmatically using the official desktop template.

from novita_sandbox.desktop import Sandbox
import os

desktop = Sandbox.create(
    api_key=os.getenv("NOVITA_API_KEY", "")
)

# Take a screenshot
screenshot = desktop.screenshot()

# Automate mouse and keyboard
desktop.left_click(100, 200)
desktop.press('Return')
desktop.write('Hello, World!')

desktop.kill()

Documentation

For comprehensive guides, API references, and examples, visit our official documentation.

Development

Install

poetry install --with dev --extras "all" 

Test

make test
make test-core
make test-code-interpreter
make test-desktop

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

novita_sandbox-1.2.1a1.tar.gz (368.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

novita_sandbox-1.2.1a1-py3-none-any.whl (428.0 kB view details)

Uploaded Python 3

File details

Details for the file novita_sandbox-1.2.1a1.tar.gz.

File metadata

  • Download URL: novita_sandbox-1.2.1a1.tar.gz
  • Upload date:
  • Size: 368.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.2 CPython/3.12.12 Linux/6.14.0-1017-azure

File hashes

Hashes for novita_sandbox-1.2.1a1.tar.gz
Algorithm Hash digest
SHA256 5252d9ca0012c2a094ccae83714969c6a5f7d80bacd2e592202815d46a1cdf4c
MD5 963ee7d902c055400cece67c94f66982
BLAKE2b-256 16a0909bf44b21fd07b5d79ad667f6f0b38790577a3bb606a0f6357e26926c03

See more details on using hashes here.

File details

Details for the file novita_sandbox-1.2.1a1-py3-none-any.whl.

File metadata

  • Download URL: novita_sandbox-1.2.1a1-py3-none-any.whl
  • Upload date:
  • Size: 428.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.2 CPython/3.12.12 Linux/6.14.0-1017-azure

File hashes

Hashes for novita_sandbox-1.2.1a1-py3-none-any.whl
Algorithm Hash digest
SHA256 a84b10299fa7338ed536e705e262a1546cc9682efb342718b32fef1f7cae37f0
MD5 de0bb775028f42e53cef8af64cee5bdc
BLAKE2b-256 adb8a76d7e339f405b7e9b0816a8e30e31b2a129f17f4df985002a7437a4222b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page