From 4fc262d90edec465e0cf2a1e715c41c88d2d7d76 Mon Sep 17 00:00:00 2001 From: Josh Borrow Date: Wed, 28 Feb 2024 19:09:08 -0500 Subject: [PATCH] Add new featuers to client interface --- hera_librarian/client.py | 28 +++++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) diff --git a/hera_librarian/client.py b/hera_librarian/client.py index 9670d55..ab29adb 100644 --- a/hera_librarian/client.py +++ b/hera_librarian/client.py @@ -847,6 +847,10 @@ def set_store_state( def get_store_manifest( self, store_name: str, + create_outgoing_transfers: bool = False, + destination_librarian: str | None = None, + disable_store: bool = False, + mark_local_instances_as_unavailable: bool = False, ) -> AdminStoreManifestResponse: """ Get the manifest of a store on this librarian. @@ -855,6 +859,18 @@ def get_store_manifest( ---------- store_name : str The name of the store to get the manifest for. + create_outgoing_transfers : bool, optional + Whether to create outgoing transfers for the files in the + manifest, by default False + destination_librarian : str, optional + The name of the librarian to send the files to, if + create_outgoing_transfers is true, by default None + disable_store : bool, optional + Whether to disable the store after creating the outgoing + transfers, by default False + mark_local_instances_as_unavailable : bool, optional + Mark the local instances as unavailable after creating the + outgoing transfers, by default False Returns ------- @@ -865,7 +881,17 @@ def get_store_manifest( try: response: AdminStoreManifestResponse = self.post( endpoint="admin/stores/manifest", - request=AdminStoreManifestRequest(store_name=store_name), + request=AdminStoreManifestRequest( + store_name=store_name, + create_outgoing_transfers=create_outgoing_transfers, + destination_librarian=( + destination_librarian + if destination_librarian is not None + else "" + ), + disable_store=disable_store, + mark_local_instances_as_unavailable=mark_local_instances_as_unavailable, + ), response=AdminStoreManifestResponse, ) except LibrarianHTTPError as e: