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.2b2.tar.gz (369.1 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.2b2-py3-none-any.whl (430.1 kB view details)

Uploaded Python 3

File details

Details for the file novita_sandbox-1.2.2b2.tar.gz.

File metadata

  • Download URL: novita_sandbox-1.2.2b2.tar.gz
  • Upload date:
  • Size: 369.1 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.2b2.tar.gz
Algorithm Hash digest
SHA256 1ec1e9045640a412675a117a9a1fc31eef571fb4120d4e2217b8ff9373cb4856
MD5 6daa47d8727d444cb4f9dfdae4636173
BLAKE2b-256 33b21ccef8e52450037f0c663da5a15154ee5c19857de2031a4beb0654f61b53

See more details on using hashes here.

File details

Details for the file novita_sandbox-1.2.2b2-py3-none-any.whl.

File metadata

  • Download URL: novita_sandbox-1.2.2b2-py3-none-any.whl
  • Upload date:
  • Size: 430.1 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.2b2-py3-none-any.whl
Algorithm Hash digest
SHA256 a27437b883b33eb81e9906bd83759dbb239944d4dae61e3ff1dcb2dc8ad7bbbd
MD5 2697b7e8f5b7017b9fd26e502ee3e542
BLAKE2b-256 259b0dc4a39c4c806d957f1d74ab3cc59131edb5cdf61c271b388d31b150c57d

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