.. DO NOT EDIT. .. THIS FILE WAS AUTOMATICALLY GENERATED BY SPHINX-GALLERY. .. TO MAKE CHANGES, EDIT THE SOURCE PYTHON FILE: .. "examples/basic/async_data_transfer_client.py" .. LINE NUMBERS ARE GIVEN BELOW. .. only:: html .. note:: :class: sphx-glr-download-link-note :ref:`Go to the end ` to download the full example code. .. rst-class:: sphx-glr-example-title .. _sphx_glr_examples_basic_async_data_transfer_client.py: .. _ref_async: ========= Run Async ========= This script is intended to be run from the command line, where it will authenticate with the specified HPS service and set up an asynchronous client for data transfer operations, transfer files to and from remote backends using the data transfer service. Example usage: ``python examples/async_data_transfer_client.py --url "https://example.com/hps" --username "user" --password "pass"`` .. GENERATED FROM PYTHON SOURCE LINES 38-139 .. code-block:: Python import asyncio import glob import logging import os import typer from typing_extensions import Annotated from ansys.hps.data_transfer.client import AsyncClient, AsyncDataTransferApi from ansys.hps.data_transfer.client.authenticate import authenticate from ansys.hps.data_transfer.client.models.msg import SrcDst, StoragePath log = logging.getLogger(__name__) logger = logging.getLogger() logging.basicConfig(format="%(asctime)s %(levelname)8s > %(message)s", level=logging.DEBUG) async def main( debug: Annotated[bool, typer.Option(help="Enable debug logging")] = False, url: Annotated[str, typer.Option(help="HPS URL to connect to")] = "https://localhost:8443/hps", username: Annotated[str, typer.Option(help="Username to authenticate with")] = "repadmin", password: Annotated[ str, typer.Option(prompt=True, hide_input=True, help="Password to authenticate with") ] = "repadmin", ): dt_url = f"{url}/dt/api/v1" auth_url = f"{url}/auth/realms/rep" token = authenticate(username=username, password=password, verify=False, url=auth_url) token = token.get("access_token", None) assert token is not None log.info("Connecting to the data transfer service client..") client = AsyncClient(clean=True) client.binary_config.update( verbosity=3, debug=debug, insecure=True, token=token, data_transfer_url=dt_url, ) await client.start() ######################################## # Create a AsyncDataTransferApi instance # ====================================== api = AsyncDataTransferApi(client) await api.status(wait=True) log.info("Query storages ...") storages = await api.storages() storage_names = [f"{storage['name']}({storage['type']})" for storage in storages] log.info(f"Available storages: {storage_names}") log.info("Creating a directory ...") base_dir = "basic-example" mkdir_op = await api.mkdir([StoragePath(path=f"{base_dir}")]) await api.wait_for([mkdir_op.id]) log.info("Copying files ...") files = glob.glob(os.path.join(os.path.dirname(__file__), "files", "*.txt")) srcs = [StoragePath(path=file, remote="local") for file in files] dsts = [StoragePath(path=f"{base_dir}/{os.path.basename(file)}") for file in files] op = await api.copy([SrcDst(src=src, dst=dst) for src, dst in zip(srcs, dsts)]) op = await api.wait_for([op.id]) log.info(f"Operation {op[0].state}") files = glob.glob(os.path.join(os.path.dirname(__file__), "*.txt")) srcs = [StoragePath(path=file, remote="local") for file in files] dsts = [StoragePath(path=f"{os.path.basename(file)}") for file in files] op = await api.copy([SrcDst(src=src, dst=dst) for src, dst in zip(srcs, dsts)]) op = await api.wait_for([op.id]) log.info(f"Operation {op[0].state}") log.info("Listing files ...") op = await api.list([StoragePath(path=base_dir)]) op = await api.wait_for([op.id]) log.info(f"Operation {op[0].state}") log.info(f"Files in {base_dir}: {op[0].result}") log.info("Getting metadata ...") op = await api.get_metadata([StoragePath(path=f"{base_dir}/2.txt")]) op = await api.wait_for(op.id) md = op[0].result[f"{base_dir}/2.txt"] log.info(f"Metadata for {base_dir}/2.txt: {md}") log.info("Removing files ...") op = await api.rmdir([StoragePath(path=base_dir)]) op = await api.wait_for([op.id]) log.info(f"Operation {op[0].state}") await client.stop() if __name__ == "__main__": asyncio.run(main()) .. _sphx_glr_download_examples_basic_async_data_transfer_client.py: .. only:: html .. container:: sphx-glr-footer sphx-glr-footer-example .. container:: sphx-glr-download sphx-glr-download-jupyter :download:`Download Jupyter notebook: async_data_transfer_client.ipynb ` .. container:: sphx-glr-download sphx-glr-download-python :download:`Download Python source code: async_data_transfer_client.py ` .. container:: sphx-glr-download sphx-glr-download-zip :download:`Download zipped: async_data_transfer_client.zip `