Skip to main content

Python SDK (alpha release)

Hyperstack provides SDKs for Python and Go, allowing developers to programmatically manage their cloud resources with ease. Similar to SDKs offered by other major cloud platforms, the Hyperstack SDKs enable you to integrate and automate interactions with cloud resources directly within your applications, covering services like virtual machines, Kubernetes clusters, and network configurations.

In this guide, you’ll find detailed instructions to use the Hyperstack SDK for Python. By following these steps, you can streamline cloud operations and management, bringing industry-standard practices directly into your codebase.

To view more examples and resources:

  • Check out our public GitHub repository here.
warning

The Hyperstack SDKs are currently in alpha, and some features may still be under development. Exercise caution when deploying production-level operations.


In this article

  1. Prerequisites
  2. Installation
  3. Usage
  4. Other resources

1. Prerequisites

Before you begin using any of the SDKs, ensure you have installed the programming language’s runtime environment on your system. You can download the required runtime from the official websites:

2. Installation

To install the Hyperstack SDKs, use one of the following commands:

pip install hyperstack

3. Usage

After installing the SDK, you can start using it in your Python scripts.

3.1 Authenticate

You can authenticate with the Hyperstack API using your API key.

To get your API key see instructions here

You can set the API key using the SDK configuration:

configuration = hyperstack.Configuration(
api_key={"apiKey": "[replace-with-your-hyperstack-api-key]"}
)
with hyperstack.ApiClient() as api_client:
# rest of code

Alternatively you can set the API key after initializing the Configuration class.

configuration = hyperstack.Configuration()
configuration.api_key["apiKey"] = "[replace-with-your-hyperstack-api-key]"

with hyperstack.ApiClient() as api_client:
# rest of code

3.2 Simple example

After setting the API key, you can use the following Python script to list all the virtual machines in your Hyperstack account. For this examples, make sure to set your API key as the environment variable HYPERSTACK_API_KEY.

import os
import json

import hyperstack
from hyperstack.rest import ApiException

# Define the configuration for the API client
configuration = hyperstack.Configuration(
api_key={"apiKey": os.environ["HYPERSTACK_API_KEY"]}
)

# Enter a context with an instance of the API client
with hyperstack.ApiClient(configuration) as api_client:
# Create an instance of the API class
api_instance = hyperstack.VirtualMachineApi(api_client)

try:
# List virtual machines
api_response = api_instance.list_virtual_machines()
instances = api_response.instances
instance_names = [instance.name for instance in instances]

# Print output
print("List of virtual machines:")
print(json.dumps(instance_names, indent=2))
except ApiException as e:
print(
f"An exception occurred while calling VirtualMachineApi.list_virtual_machines: {e}"
)

3.3 Advanced example

The following example demonstrates how to create a virtual machine with specific configurations. For this example, make sure to set your API key as the environment variable HYPERSTACK_API_KEY.

import os
import hyperstack

configuration = hyperstack.Configuration()
configuration.api_key["apiKey"] = os.environ["HYPERSTACK_API_KEY"]

with hyperstack.ApiClient(configuration) as api_client:
# Create an instance of the API class
api_instance = hyperstack.VirtualMachineApi(api_client)
payload = payload = hyperstack.CreateInstancesPayload(
name="my-vm-2",
environment_name="default-CANADA-1",
key_name="canada-key-prod-040624",
image_name="Ubuntu Server 22.04 LTS (Jammy Jellyfish)",
flavor_name="n1-cpu-medium",
count=1,
assign_floating_ip=True,
labels=["sdk-example"],
# Allow SSH
security_rules=[
hyperstack.CreateSecurityRulePayload(
direction="ingress",
ethertype="IPv4",
protocol="tcp",
remote_ip_prefix="0.0.0.0/0",
port_range_min=22,
port_range_max=22,
),
hyperstack.CreateSecurityRulePayload(
direction="ingress",
ethertype="IPv6",
protocol="tcp",
remote_ip_prefix="::/0",
port_range_min=22,
port_range_max=22,
),
],
)
try:
# Create virtual machine
api_response = api_instance.create_virtual_machines(payload)

instance_details = api_response.instances[0]
id = instance_details.id
print(f"Created virtual machine with ID: {id}")
except Exception as e:
print(
f"An exception occurred while calling VirtualMachineApi.create_virtual_machine: {e}"
)

4. Other resources

To explore more advanced usage and other examples, refer to our Python SDK GitHub repository.