Source code for dds_cloudapi_sdk.client
"""
Client is the main entry point for users to interact with the DDS Cloud API.
After initializing it with a :class:`Config <dds_cloudapi_sdk.config.Config>` class, users can use it to upload files,
trigger tasks, and check for the results.
A simple example illustrating the major interface::
from dds_cloudapi_sdk import Config
from dds_cloudapi_sdk import Client
token = "Your API Token Here"
config = Config(token)
client = Client(config)
# upload local file with client
url = client.upload_file("/path/to/local_file.jpg")
# run a task with client
client.run(task)
print(task.result)
"""
import os.path
import requests
from dds_cloudapi_sdk.config import Config
from dds_cloudapi_sdk.tasks.base import BaseTask
__all__ = [
"Client"
]
[docs]
class Client:
"""
| This is the SDK client for dds cloud APIs.
| It is initialized with the API token, and talks to the server to:
- 1. upload files to get the visible url
- 2. run tasks and wait for the results
:param config: The :class:`Config <dds_cloudapi_sdk.config.Config>` object.
"""
def __init__(self, config: Config):
self.config = config
[docs]
def upload_file(self, local_path: str, timeout: int=10) -> str:
"""
| Upload local file to dds server, return a visible url ready for calling dds cloud API.
| Although users can trigger tasks with any publicly visible url, uploading file to dds server and use the dds
hosted url as task parameter is necessary to conform the network security policy of the DDS server.
:param local_path: The local file path.
"""
# request our server API to upload the image file
sign_url = f"https://{self.config.endpoint}/upload_signature"
headers = {"Token": self.config.token}
file_name = os.path.basename(local_path)
data = {"file_name": file_name}
rsp = requests.post(sign_url, json=data, headers=headers, timeout=timeout)
assert rsp.status_code == 200
rsp_json = rsp.json()
# parse the urls from API result
upload_url = rsp_json["data"]["upload_url"]
download_url = rsp_json["data"]["download_url"]
# upload the image to our server by the upload_url
with open(local_path, "rb") as fp:
rsp = requests.put(upload_url, fp.read())
assert rsp.status_code == 200
return download_url
[docs]
def trigger_task(self, task: BaseTask):
"""
Trigger a task and return immediately without waiting for the result.
:param task: The task to trigger.
"""
return task.trigger(self.config)
[docs]
def check_task(self, task: BaseTask):
"""
Check the task's :class:`status <dds_cloudapi_sdk.tasks.base.TaskStatus>`.
:param task: The task to check.
"""
return task.check()
[docs]
def wait_task(self, task: BaseTask):
"""
| Wait for the task to complete.
| This blocks the current thread until the task is done.
:param task: The task to wait.
"""
return task.wait()
[docs]
def run_task(self, task: BaseTask):
"""
| Trigger a task and wait for it to complete.
| This blocks the current thread until the task is done.
:param task: The task to run.
"""
return task.run(self.config)