SDK to interact with managed services on the Kipu Quantum Hub.
Project description
Kipu Quantum Hub Service SDK
Installation
The package is published on PyPI and can be installed via pip:
pip install --upgrade qhub-service
Usage
import os
from qhub.service.client import HubServiceClient
service_endpoint = "..."
access_key_id = "..."
secret_access_key = "..."
# Create a new HubServiceClient instance
client = HubServiceClient(service_endpoint, access_key_id, secret_access_key)
# Start a new service execution
service_execution = client.run(request={"values": [2], "shots": 100})
# Wait for the service execution to finish (blocking)
service_execution.wait_for_final_state()
status = service_execution.status
ended_at = service_execution.ended_at
print(f"Service execution finished at '{ended_at}' with status '{status}'")
# Use the client to retrieve a service execution by its ID
service_execution = client.get_service_execution("0030737b-35cb-46a8-88c2-f59d4885484d")
# Get the results of the service execution
result = service_execution.result()
# Get the logs of the service execution
logs = service_execution.logs()
# List the result files
files = service_execution.result_files()
# Download a result file
service_execution.download_result_file(files[0], os.getcwd())
Data Pool Access Grants
Service executions that read from or write to data pools require a short-lived JWT grant. The client can acquire these grants automatically by calling the Hub Platform API on your behalf.
Credentials and the active organization are resolved via the standard DefaultCredentialsProvider and ContextResolver.
If you are already logged in through the qhubctl CLI, no parameters need to be supplied (the HubServiceClient constructs its HubPlatformClient automatically):
from qhub.service.client import HubServiceClient
from qhub.service.datapool import DataPoolGrant, DataPoolPermission
client = HubServiceClient(service_endpoint, access_key_id, secret_access_key)
To override the resolved credentials or organization, pass an explicit HubPlatformClient:
from qhub.service.client import HubServiceClient, HubPlatformClient
from qhub.service.datapool import DataPoolGrant, DataPoolPermission
platform_client = HubPlatformClient(api_key="...", organization_id="...")
client = HubServiceClient(service_endpoint, access_key_id, secret_access_key, platform_client=platform_client)
grants = [
DataPoolGrant(
name="input_data",
datapool_id="dp-abc123",
application_id="app-xyz789",
permission=DataPoolPermission.VIEW,
),
DataPoolGrant(
name="output_data",
datapool_id="dp-def456",
application_id="app-xyz789",
permission=DataPoolPermission.MODIFY,
),
]
service_execution = client.run(request={"shots": 100}, grants=grants)
For each grant, the client injects a DataPoolReference (with the issued JWT) into the request under the supplied name.
Grants are cached per (datapool_id, application_id, permission) until shortly before the JWT expires.
License
Apache-2.0 | Copyright 2026-now Kipu Quantum GmbH
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 qhub_service-1.5.0.tar.gz.
File metadata
- Download URL: qhub_service-1.5.0.tar.gz
- Upload date:
- Size: 21.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"12","id":"bookworm","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3f31b4f8d15f68c952ef82d043eae405b79d12f43f641adfa19c5a5659bedb67
|
|
| MD5 |
d222a985a02c693e416d99bb6c1c6ced
|
|
| BLAKE2b-256 |
8e59b1587d71c0e84e243a51a17998a1f0841955fdd476ead28bd0a3143a68a7
|
File details
Details for the file qhub_service-1.5.0-py3-none-any.whl.
File metadata
- Download URL: qhub_service-1.5.0-py3-none-any.whl
- Upload date:
- Size: 15.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"12","id":"bookworm","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
63e0e5e709b5a3c4b87a0f1ddcc6e9284b40274e9bc4262debcdeeb44c5ad35e
|
|
| MD5 |
172f4be2cc7cc1cdabb7a09bcfd0b743
|
|
| BLAKE2b-256 |
8567c36e449781e26904561cb9e6bed162e15598a09afc9bf3236c40c1d92c50
|