idmtools_platform_local.infrastructure.docker_io module#
idmtools docker input/output operations.
Copyright 2021, Bill & Melinda Gates Foundation. All rights reserved.
- class idmtools_platform_local.infrastructure.docker_io.DockerIO(host_data_directory: str = '/home/docs/.local_data')[source]#
Bases:
object
Provides most of our file operations for our docker containers/local platform.
- delete_files_below_level(directory, target_level=1, current_level=1)[source]#
Delete files below a certain depth in a target directory.
- Parameters:
directory – Target directory
target_level – Depth to begin deleting. Default to 1
current_level – Current level. We call recursively so this should be 1 on initial call.
- Returns:
None
- Raises:
PermissionError - Raised if there are issues deleting a file. –
- cleanup(delete_data: bool = True, shallow_delete: bool = False) NoReturn [source]#
Stops the running services, removes local data, and removes network.
You can optionally disable the deleting of local data.
- copy_to_container(container: Container, destination_path: str, file: str | bytes | None = None, content: str | bytes = None, dest_name: str | None = None) bool [source]#
Copies a physical file or content in memory to a container.
You can also choose a different name for the destination file by using the dest_name option.
- Parameters:
container – Container to copy the file to
file – Path to the file to copy
content – Content to copy
destination_path – Path within the container to copy the file to(should be a directory)
dest_name – Optional parameter for destination filename. By default, the source filename is used
- Returns:
(bool) True if the copy succeeds, False otherwise
- sync_copy(futures)[source]#
Sync the copy operations queue in the io_queue.
This allows us to take advantage of multi-threaded copying while also making it convenient to have sync points, such as uploading the assets in parallel but pausing just before sync point.
- Parameters:
futures – Futures to wait on.
- Returns:
Final results of copy operations.
- copy_multiple_to_container(container: Container, files: Dict[str, Dict[str, Any]], join_on_copy: bool = True)[source]#
Copy multiple items to a container.
- Parameters:
container – Target container
files – Files to copy in form target directory -> filename -> data
join_on_copy – Should we join the threading on copy(treat as an atomic unit)
- Returns:
True if copy succeeded, false otherwise
- static create_archive_from_bytes(content: bytes | BytesIO | BinaryIO, name: str) BytesIO [source]#
Create a tar archive from bytes. Used to copy to docker.
- Parameters:
content – Content to copy into tar
name – Name for file in archive
- Returns:
(BytesIO) Return bytesIO object