Skip to main content

(Unofficial) Modern Python SDK for the Novita AI API

Project description

(Unofficial) Novita AI Python SDK

CI Python 3.11+ License: MIT

(Unofficial,) Modern, fully type-safe Python SDK for the Novita AI API. Built with Pydantic v2 and httpx.

Features

  • Fully Type-Safe: Complete type hints for excellent IDE support
  • Async & Sync: Both synchronous and asynchronous clients
  • Pydantic Models: Request/response validation with Pydantic v2
  • Modern Stack: Built on httpx and modern Python practices

Installation

pip install novita-sdk

Quick Start

Authentication

Set your API key as an environment variable:

export NOVITA_API_KEY="your-api-key-here"

Or pass it directly to the client:

from novita import NovitaClient

client = NovitaClient(api_key="your-api-key-here")

Synchronous Client

from novita import NovitaClient, CreateInstanceRequest, Kind

client = NovitaClient()

request = CreateInstanceRequest(
    name="my-gpu-instance",
    product_id="prod-123",  # fetch via client.gpu.products.list()
    gpu_num=1,
    rootfs_size=50,
    image_url="ubuntu:22.04",
    kind=Kind.gpu,
)
response = client.gpu.instances.create(request)
print(f"Created instance: {response.id}")

instances = client.gpu.instances.list()
for instance in instances:
    print(f"{instance.name}: {instance.status.value}")

client.close()

Asynchronous Client

import asyncio
from novita import AsyncNovitaClient, CreateInstanceRequest, Kind

async def main():
    async with AsyncNovitaClient() as client:
        request = CreateInstanceRequest(
            name="my-async-instance",
            product_id="prod-123",
            gpu_num=1,
            rootfs_size=50,
            image_url="ubuntu:22.04",
            kind=Kind.gpu,
        )
        response = await client.gpu.instances.create(request)
        print(f"Created: {response.id}")

        instance = await client.gpu.instances.get(response.id)
        print(f"Status: {instance.status.value}")

asyncio.run(main())

📚 Examples

For more detailed examples and use cases, check out the examples/ directory:

See the examples README for detailed instructions.

Advanced Usage

Context Managers

Both clients support context managers for automatic cleanup:

# Synchronous
with NovitaClient() as client:
    instances = client.gpu.instances.list()
    # Client automatically closed

# Asynchronous
async with AsyncNovitaClient() as client:
    instances = await client.gpu.instances.list()
    # Client automatically closed

Custom Configuration

client = NovitaClient(
    api_key="your-key",
    base_url="https://custom-api.novita.ai",  # Custom base URL
    timeout=120.0  # Custom timeout in seconds
)

Price Conversion

Important: The Novita API returns prices in an unusual format (units of 1/100,000 USD). This SDK automatically converts all prices to standard USD for your convenience.

For example:

  • API returns 67000 → SDK provides $0.67/hour
  • API returns 35000 → SDK provides $0.35/hour

This conversion is applied to:

  • GPUProduct.price - On-demand pricing
  • GPUProduct.spot_price - Spot instance pricing
  • SubscriptionPrice.price - Monthly subscription pricing
  • CPUProduct.price - CPU instance pricing

The raw API values are still available if needed via *_raw fields (price_raw, spot_price_raw, etc.):

products = client.gpu.products.list()
product = products[0]

print(f"Converted: ${product.price}/hour")  # e.g., $0.67/hour
print(f"Raw API value: {product.price_raw}")  # e.g., 67000
print(f"Spot (converted): ${product.spot_price}/hour")
print(f"Spot (raw): {product.spot_price_raw}")

API Resources

The SDK provides complete coverage of the Novita GPU Cloud API:

  • Instances - GPU instance lifecycle management
  • Products - GPU and CPU product listings with filtering
  • Endpoints - API endpoint management
  • Networks - VPC network configuration
  • Templates - Instance template management
  • Jobs - Job execution and control
  • Metrics - Instance performance metrics
  • Storages - Network storage management
  • Image Registry - Container registry authentication
  • Images - Image prewarm task management
  • Clusters - Available GPU cluster information

Development

Pre-commit Hooks

This project uses pre-commit hooks to ensure code quality. The hooks automatically run on every commit and check:

  • Linting - Ruff checks for code issues
  • Formatting - Ruff formats code consistently
  • Type checking - MyPy validates type hints
  • Unit tests - Fast test suite ensures no regressions
  • File checks - Trailing whitespace, end-of-file, YAML/TOML validation

Install the hooks:

make pre-commit-install

Run manually on all files:

make pre-commit-run

Skip hooks for a specific commit (use sparingly):

git commit --no-verify

Requirements

  • Python 3.11 or higher

License

This project is licensed under the MIT License - see the LICENSE file for details.

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_sdk-0.4.0.tar.gz (27.2 kB view details)

Uploaded Source

Built Distribution

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

novita_sdk-0.4.0-py3-none-any.whl (32.3 kB view details)

Uploaded Python 3

File details

Details for the file novita_sdk-0.4.0.tar.gz.

File metadata

  • Download URL: novita_sdk-0.4.0.tar.gz
  • Upload date:
  • Size: 27.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for novita_sdk-0.4.0.tar.gz
Algorithm Hash digest
SHA256 20a35e50ab1e0a11ff9abc65eddfb80b70d8a727fec19bef08daba6c55189145
MD5 6c189ad5e2f04b2e0fac6f6ec1e5f2b8
BLAKE2b-256 1495453bfac7969f3a6babe88b44b6fd48d54704da1a180cf5f608560bed41a0

See more details on using hashes here.

Provenance

The following attestation bundles were made for novita_sdk-0.4.0.tar.gz:

Publisher: publish-pypi.yaml on php-workx/novita-sdk-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file novita_sdk-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: novita_sdk-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 32.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for novita_sdk-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3aa2b8c7c9e6916e03875b857413f0c5e7442f245ae4e7cc02e9cf268058a65e
MD5 077c05a81067093ffd88573ebb4c6769
BLAKE2b-256 53d863f5ddb2bb48aca1350fae694b9ed04a1785661faae6c0d0ae41cea1b798

See more details on using hashes here.

Provenance

The following attestation bundles were made for novita_sdk-0.4.0-py3-none-any.whl:

Publisher: publish-pypi.yaml on php-workx/novita-sdk-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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