Python SDK for interacting with the Qubicon platform through the library or CLI
Project description
Qubicon SDK
Overview
The Qubicon SDK is a Python client library designed for interacting with the Qubicon API. It provides methods for authentication, process management, model creation, data extraction, and more.
This SDK wraps the OpenAPI-generated client and adds custom functionalities to streamline interactions with the Qubicon platform.
Usage Modes
The Qubicon SDK can be used in two ways:
- As a Python Library – Import and use the SDK programmatically in your Python applications.
- As an Interactive CLI – Run an interactive command-line interface to execute commands without writing code.
To start the interactive menu, run:
qubicon-client --interactive
All function outputs are returned in JSON format, making it easy to parse and integrate with other tools.
Features
- Authentication & Token Management
- Process Management (Create, List, Delete Processes & Groups)
- Model Management (Create, Fetch, Export Computable Models)
- Physical Quantities Handling
- Process Data Extraction & Export
- File Upload & Advanced Model Management
- Event Streaming
Installation
Install the SDK using pip:
pip install qubicon
Alternatively, install from a local package:
pip install /path/to/qubicon_package
Quick Start
1. Initialize the SDK
from qubicon.core import QubiconCore, AuthenticatedClient
# Define base URL (e.g., production or staging server)
BASE_URL = "https://qubicon-hostname"
# Create a client instance
client = AuthenticatedClient(base_url=BASE_URL, token=None)
# Initialize QubiconCore with the authenticated client
qubicon = QubiconCore(client)
2. Login to Qubicon
username = "your_username"
password = "your_password"
token = qubicon.login_user(username, password)
print("Token:", token)
3. List Processes
processes = qubicon.list_processes()
print(processes)
4. Create a Process
new_process = qubicon.create_process(
name="Test Process",
recipe_id=1822,
description="Automated process creation"
)
print(new_process)
5. Delete a Process
response = qubicon.delete_process(process_id=1234)
print(response)
API Reference
Authentication
def login_user(username: str, password: str) -> Optional[str]
- Logs in a user and retrieves an authentication token.
def refresh_token(refresh_token: str) -> Optional[str]
- Refreshes an expired authentication token.
Process Management
def list_processes()
- Lists all processes with optional filters.
def create_process(name: str, recipe_id: int, description: str = "") -> Optional[Dict[str, Any]]
- Creates a new process using a specified recipe.
def start_process(process_id: int) -> bool
- Start a process by ID.
def delete_process(process_id: int) -> Optional[Dict[str, Any]]
- Deletes a specific process by ID.
def delete_multiple_processes(process_ids: List[int]) -> Dict[int, Optional[Dict[str, Any]]]
- Deletes multiple processes in a batch operation.
def create_process_group(name: str) -> Optional[Dict[str, Any]]
- Creates a new process group.
def add_processes_to_group(group_id: int, process_ids: List[int]) -> Optional[Dict[str, Any]]
- Adds multiple processes to an existing group.
def start_processgroup(group_id: int) -> bool
- Start a process group.
def stop_processgroup(group_id: int) -> bool
- Stop a process group.
def get_process_state(process_id: int) -> Dict[str, Any]
- Fetch the current state for a specific process ID.
def get_process_list_state(
archived_or_will_be_archived: bool = False,
sort: str = "lastUsageDate,desc",
part_of_experiment: bool = False,
statuses: List[str] = ["COMPLETED", "FAILED", "READY", "RUNNING", "WARMING_UP"],
page: int = 0,
size: int = 20,
) -> List[Dict[str, Any]]:
- Fetch status data for processes with filtering options.
Computable Models
def list_computable_models()
- Lists all available computable models.
def fetch_model_details(model_id: int)
- Fetches detailed information about a computable model.
def create_computable_model(model_data: dict) -> Optional[Dict[str, Any]]
- Creates a new computable model with the given specifications.
def export_model_to_json(model_id: int, filename: str)
- Exports a computable model into an importable JSON format.
Physical Quantities
def list_physical_quantities()
- Retrieves all available physical quantities.
def create_physical_quantity(pq_dict: Dict[str, Any]) -> Optional[Dict[str, Any]]
- Creates a new physical quantity in the system.
def check_existing_physical_quantity(pq_name: str) -> Optional[dict]
- Checks if a physical quantity already exists.
Process Data & Channels
def extract_channels(process_id: int)
- Extracts available channels for a given process.
def extract_process_data(process_id: int, output_format: str = "csv", output_file: str = "process_data.csv")
- Extracts and exports process data in a file.
def extract_offline_channels(process_id: int)
- Extracts available offline channels for a given process.
def extract_offline_process_data(process_id: int, selected_channels: List[Dict[str, Any]], start_date: [int], end_date: [int])
- Extracts and exports offline process data for selected channels and a given period.
def get_process_samplings(self, process_id: int) -> List[Dict[str, Any]]
- Fetch detailed sampling data for a given process ID.
def discard_sampling_data(self, external_sampling_id: str, process_id: int) -> bool
- Discard a specific external sampling for a given process.
def get_offline_equipment_data(equipment_id: int, process_id: int,)
- Get the list of offline data for an offline equipment and a process.
def get_process_tag_values(process_id: int) -> List[Dict[str, Any]]
- Fetches process tag values and extracts TagDto with corresponding values.
def set_tag_value(self, process_id: int, tag_value_id: int, new_value: Any) -> Optional[Dict[str, Any]]:
- Updates a tag value for a specific process and tag value ID.
File Upload & Advanced Models
def upload_file(file_path: str) -> Optional[Dict[str, Any]]
- Uploads an external file (e.g., ZIP archive) to Qubicon.
def create_advanced_model(model_data: dict, file_path: str) -> Optional[Dict[str, Any]]
- Creates an advanced model that references an external file.
Sampling
def generate_and_upload_sampling_plan(process_group_id: int, number_of_samples: int, sample_prefix: str = "Day")
- Generates and uploads a sampling plan to the specified process group ID.
def generate_and_upload_sampling_plan_single_process(process_id: int, number_of_samples: int, sample_prefix: str = "Day")
- Generates and uploads a sampling plan to the specified process ID.
Event Streaming
def stream_events(event_types: List[str], nonce: str)
- Streams real-time events from the API.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file qubicon-3.5.13.tar.gz.
File metadata
- Download URL: qubicon-3.5.13.tar.gz
- Upload date:
- Size: 135.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
413898c82098f0d97fe270701e0d8263d3fd9df8fbc1387e1baf4f32a229c4a1
|
|
| MD5 |
dc4f6a05fb1e56dc300ed77addf9ee9d
|
|
| BLAKE2b-256 |
23706ea81cb1365091f7ba44a91ab51ce284b8b1e2dbedab75cb4d11f42517d7
|
File details
Details for the file qubicon-3.5.13-py3-none-any.whl.
File metadata
- Download URL: qubicon-3.5.13-py3-none-any.whl
- Upload date:
- Size: 338.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0354a9cee6404063ad4348535173b36a209ded9aecdfcdbd6f3f1624941e60d6
|
|
| MD5 |
c4875190caa4ecbd0bff1c03a5761fc8
|
|
| BLAKE2b-256 |
034d5521d65b5f29c202236824876878719d0520344739582cd4eea23139f5c5
|