A hypermedia-based client for the DataCybernetics PinexQ platform.
Project description
Pine-x-Q Python Client
A hypermedia-based client for the DataCybernetics PinexQ platform.
This module contains the submodules:
-
core
: A generic hypermedia client (HC) to work with siren hypermedia APIs Siren on GitHub -
job_management
: Specialized HC-object (HCO) implementations for the PinexQ Job-Management API (JMA).
Installation
Install from PyPI by running
pip install pinexq-client
Setup the Client
The hypermedia client uses HTTPX as a backend. To access the API you need to provide a pre-configured HTTPX-client with a valid API key for authentication. From The API key the user and permissions are derived so do not share the API key and store it securely.
To initialize the client parts must be supplied:
- The API key (as header)
- The API host as URL with port if required
from httpx import Client
from pinexq_client.job_management.enterjma import enter_jma
from pinexq_client.job_management.hcos.entrypoint_hco import EntryPointHco
client = Client(
base_url="https://myapihost.com:80",
headers={'x-api-key': '<SECRET_PAT>'}
)
# the client is now ready to be passed to function entering the API
entrypoint: EntryPointHco = enter_jma(client)
Using the API
Job-Management Interface
There is a convenience layer wrapping job-management-specific objects in interface classes for ease of use.
from pinexq_client.job_management.tool import Job
from pinexq_client.job_management.model import JobStates
job = (
Job(client)
.create(name="JobName")
.select_processing(processing_step="step_function_name")
.configure_parameters(param_name="value")
.start()
.wait_for_state(JobStates.completed)
)
result = job.get_result()
Raw Hypermedia API
In the spirit of a hypermedia API you can also use low level calls to navigate the API, e.g. when features are not yet exposed in the convenience wrapper.
from pinexq_client.job_management.enterjma import enter_jma
from pinexq_client.job_management.hcos.entrypoint_hco import EntryPointHco
from pinexq_client.job_management.model import CreateJobParameters, SetJobTagsParameters
entrypoint: EntryPointHco = enter_jma(client)
# Get to jobs root
job_root = entrypoint.job_root_link.navigate()
# Create a new job
parameters = CreateJobParameters(name="Test Job")
job = job_root.create_job_action.execute(parameters).navigate()
# Edit the job's tags
job.edit_tags_action.execute(SetJobTagsParameters(tags=["test", ]))
...
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 Distributions
Built Distribution
File details
Details for the file pinexq_client-0.3.0.2024.607.9-py3-none-any.whl
.
File metadata
- Download URL: pinexq_client-0.3.0.2024.607.9-py3-none-any.whl
- Upload date:
- Size: 3.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | dc3fa62e303d910f35155fca36e0de4be2cddfd1bd8f258096812de09bc38bc9 |
|
MD5 | d031e38484b84305a6e55d04890fe1f0 |
|
BLAKE2b-256 | e299fd7ef6b232b780e68d73a5c2c7ced92862f55e96bc4215ea5914dfeb48bf |