Skip to main content

The Python SDK for Cudo Compute distributed compute platform.

Project description

Cudo Compute SDK

A Python SDK for the Cudo Compute Platform API.

Python PyPI License: Apache 2.0

GitHub Issues Pull Requests GitHub Contributors


A Python SDK for interacting with the Cudo Compute REST API. Manage virtual machines, storage, networks, and other cloud resources programmatically.

Features

  • Async/Await Support - Built on httpx for efficient async operations
  • Type Safe - Comprehensive type hints with Pydantic models
  • Full API Coverage - Complete support for VMs, storage, networking, and more
  • Well Tested - 112 tests with 78% code coverage
  • Great Documentation - Detailed docs with examples

Installation

Using pip

pip install cudo-compute-sdk

Using uv (recommended)

uv add cudo-compute-sdk

Quick Start

Basic Usage

import asyncio
from cudo_compute_sdk import CudoComputeSDK

async def main():
    # Initialize the SDK with your API key
    sdk = CudoComputeSDK(api_key="your-api-key-here")
    
    try:
        # List all projects
        projects = await sdk.list_projects()
        print(f"Found {len(projects)} projects")
        
        # List VMs in a project
        vms = await sdk.list_vms(project_id="my-project")
        for vm in vms:
            print(f"VM: {vm.id} - State: {vm.state}")
    
    finally:
        # Clean up
        await sdk.close()

asyncio.run(main())

Creating a Virtual Machine

async def create_vm_example():
    sdk = CudoComputeSDK(api_key="your-api-key")
    
    try:
        vm = await sdk.create_vm(
            project_id="my-project",
            vm_id="my-vm-001",
            data_center_id="gb-bournemouth-1",
            machine_type="standard",
            boot_disk_image_id="ubuntu-2204-lts",
            vcpus=2,
            memory_gib=4,
            gpus=0,
            ssh_key_source="SSH_KEY_SOURCE_USER"
        )
        print(f"Created VM: {vm.id}")
        print(f"IP Address: {vm.external_ip_address}")
    
    finally:
        await sdk.close()

Managing Storage

async def storage_example():
    sdk = CudoComputeSDK(api_key="your-api-key")
    
    try:
        # Create a disk
        disk = await sdk.create_disk(
            project_id="my-project",
            disk_id="data-disk-001",
            data_center_id="gb-bournemouth-1",
            size_gib=100
        )
        
        # Attach to VM
        await sdk.attach_disk(
            project_id="my-project",
            disk_id="data-disk-001",
            vm_id="my-vm-001"
        )
        
        print(f"Created and attached disk: {disk.id}")
    
    finally:
        await sdk.close()

API Key Setup

  1. Log in to Cudo Compute
  2. Navigate to your account settings
  3. Generate an API key
  4. Set it as an environment variable:
export CUDO_API_KEY="your-api-key-here"

Then use it in your code:

import os
from cudo_compute_sdk import CudoComputeSDK

sdk = CudoComputeSDK(api_key=os.getenv("CUDO_API_KEY"))

Documentation

Visit the full project documentation: Cudo Compute SDK Docs

Key Sections

Supported Operations

Virtual Machines

  • Create, start, stop, reboot, terminate VMs
  • Resize VMs (CPU, memory)
  • List and get VM details
  • Connect via web console
  • Monitor VM metrics

Data Centers & Machine Types

  • List available data centers
  • Get machine type specifications
  • Query pricing information

Storage

  • Create and manage disks
  • Attach/detach disks to VMs
  • Create and manage NFS volumes
  • Manage VM images (public and private)

Networking

  • Create and manage virtual networks
  • Configure security groups and rules
  • Manage SSH keys

Projects & Billing

  • List and manage projects
  • View billing account information

Development

Setup Development Environment

# Clone the repository
git clone https://github.com/vantagecompute/cudo-compute-sdk.git
cd cudo-compute-sdk

# Install dependencies
uv sync --extra dev

# Run tests
just unit

# Run type checking
just typecheck

# Format code
just fmt

# Run linter
just lint

Running Tests

# Run all unit tests with coverage
just unit

# Run tests with verbose output
uv run pytest tests/unit -v

# Run specific test file
uv run pytest tests/unit/test_sdk.py -v

Project Structure

cudo-compute-sdk/
├── cudo_compute_sdk/
│   ├── __init__.py          # Main SDK implementation
│   └── schema.py            # Pydantic models for API data
├── tests/
│   └── unit/
│       ├── test_sdk.py      # SDK method tests
│       └── test_schema.py   # Schema model tests
├── docusaurus/              # Documentation site
├── justfile                 # Development task runner
├── pyproject.toml           # Project configuration
└── README.md

Contributing

We welcome contributions! Here's how to get started:

  1. Fork the repository

    git clone https://github.com/your-username/cudo-compute-sdk.git
    
  2. Create a feature branch

    git checkout -b feature/your-feature-name
    
  3. Make your changes

    • Write tests for new functionality
    • Ensure all tests pass: just unit
    • Run type checking: just typecheck
    • Format code: just fmt
  4. Commit your changes

    git commit -m "feat: add your feature description"
    
  5. Push and create a Pull Request

    git push origin feature/your-feature-name
    

Coding Standards

  • Python 3.12+ required
  • Type hints on all public methods
  • Docstrings for all public methods (Google style)
  • Tests for all new functionality
  • 80%+ test coverage for new code

Development Commands

just unit          # Run unit tests with coverage
just typecheck     # Run static type checking
just fmt           # Format code with ruff
just lint          # Run linters (codespell + ruff)
just docs-dev      # Start documentation dev server
just docs-build    # Build documentation

Requirements

  • Python 3.12 or higher
  • Dependencies:
    • httpx >= 0.28.1 (async HTTP client)
    • pydantic >= 2.0.0 (data validation)

License

This project is licensed under the Apache License 2.0.

See the LICENSE file for details.

Key Points

  • ✅ Free to use, modify, and distribute
  • ✅ Commercial use permitted
  • ✅ Patent rights granted
  • ✅ Must include license and copyright notice
  • ✅ Changes must be documented

Support

Acknowledgments

Built with:

Copyright

Copyright 2025 Vantage Compute Corporation

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.


Made with ❤️ by Vantage Compute

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

cudo_compute_sdk-0.0.4.tar.gz (48.1 kB view details)

Uploaded Source

Built Distribution

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

cudo_compute_sdk-0.0.4-py3-none-any.whl (21.7 kB view details)

Uploaded Python 3

File details

Details for the file cudo_compute_sdk-0.0.4.tar.gz.

File metadata

  • Download URL: cudo_compute_sdk-0.0.4.tar.gz
  • Upload date:
  • Size: 48.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for cudo_compute_sdk-0.0.4.tar.gz
Algorithm Hash digest
SHA256 cc0766d8405e89c6333a857ce7136a1c00165327a8c1f103d9d9f4d5fdcb60c1
MD5 5e5b1205abbacb034d1d383e96180822
BLAKE2b-256 d03f15e570efbb599178b9b017b89b364a3addfd2cdc9cfd046ac83db4f5b1ab

See more details on using hashes here.

File details

Details for the file cudo_compute_sdk-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: cudo_compute_sdk-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 21.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for cudo_compute_sdk-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 8be4bd957141d0bcbc0bf4509d3d771b944707b770c223a7f3f8d3f4ee89ae01
MD5 702ef679b390ed9ca8fc6f012eec942f
BLAKE2b-256 6b58eb1bdaffe5c0f953e6ef934abf54c7178b59ba7a6a21891479913bd27a23

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