Source code for bioblend.galaxy.folders

"""
Contains possible interactions with the Galaxy library folders
"""
from typing import (
    Any,
    Dict,
    List,
    Optional,
    TYPE_CHECKING,
    Union,
)

from typing_extensions import Literal

from bioblend.galaxy.client import Client

if TYPE_CHECKING:
    from bioblend.galaxy import GalaxyInstance


[docs]class FoldersClient(Client): module = "folders" def __init__(self, galaxy_instance: "GalaxyInstance") -> None: super().__init__(galaxy_instance)
[docs] def create_folder(self, parent_folder_id: str, name: str, description: Optional[str] = None) -> Dict[str, Any]: """ Create a folder. :type parent_folder_id: str :param parent_folder_id: Folder's description :type name: str :param name: name of the new folder :type description: str :param description: folder's description :rtype: dict :return: details of the updated folder """ payload: Dict[str, str] = {"name": name} if description: payload["description"] = description return self._post(payload=payload, id=parent_folder_id)
[docs] def show_folder(self, folder_id: str, contents: bool = False) -> Dict[str, Any]: """ Display information about a folder. :type folder_id: str :param folder_id: the folder's encoded id, prefixed by 'F' :type contents: bool :param contents: True to get the contents of the folder, rather than just the folder details. :rtype: dict :return: dictionary including details of the folder """ return self._get(id=folder_id, contents=contents)
[docs] def delete_folder(self, folder_id: str, undelete: bool = False) -> Dict[str, Any]: """ Marks the folder with the given ``id`` as `deleted` (or removes the `deleted` mark if the `undelete` param is True). :type folder_id: str :param folder_id: the folder's encoded id, prefixed by 'F' :type undelete: bool :param undelete: If set to True, the folder will be undeleted (i.e. the `deleted` mark will be removed) :return: detailed folder information :rtype: dict """ payload = {"undelete": undelete} return self._delete(payload=payload, id=folder_id)
[docs] def update_folder(self, folder_id: str, name: str, description: Optional[str] = None) -> Dict[str, Any]: """ Update folder information. :type folder_id: str :param folder_id: the folder's encoded id, prefixed by 'F' :type name: str :param name: name of the new folder :type description: str :param description: folder's description :rtype: dict :return: details of the updated folder """ payload = {"name": name} if description: payload["description"] = description return self._put(payload=payload, id=folder_id)
[docs] def get_permissions(self, folder_id: str, scope: Literal["current", "available"] = "current") -> Dict[str, Any]: """ Get the permissions of a folder. :type folder_id: str :param folder_id: the folder's encoded id, prefixed by 'F' :type scope: str :param scope: scope of permissions, either 'current' or 'available' :rtype: dict :return: dictionary including details of the folder permissions """ url = self._make_url(folder_id) + "/permissions" return self._get(url=url)
[docs] def set_permissions( self, folder_id: str, action: Literal["set_permissions"] = "set_permissions", add_ids: Optional[List[str]] = None, manage_ids: Optional[List[str]] = None, modify_ids: Optional[List[str]] = None, ) -> Dict[str, Any]: """ Set the permissions of a folder. :type folder_id: str :param folder_id: the folder's encoded id, prefixed by 'F' :type action: str :param action: action to execute, only "set_permissions" is supported. :type add_ids: list of str :param add_ids: list of role IDs which can add datasets to the folder :type manage_ids: list of str :param manage_ids: list of role IDs which can manage datasets in the folder :type modify_ids: list of str :param modify_ids: list of role IDs which can modify datasets in the folder :rtype: dict :return: dictionary including details of the folder """ url = self._make_url(folder_id) + "/permissions" payload: Dict[str, Union[str, List[str]]] = {"action": action} if add_ids: payload["add_ids[]"] = add_ids if manage_ids: payload["manage_ids[]"] = manage_ids if modify_ids: payload["modify_ids[]"] = modify_ids return self._post(url=url, payload=payload)