Warning
This document is for an in-development version of Galaxy. You can alternatively view this page in the latest release if it exists or view the top of the latest release's documentation.
Source code for galaxy.webapps.galaxy.api.dataset_collections
from logging import getLogger
from typing import Optional
from fastapi import (
Body,
Path,
Query,
)
from galaxy.managers.context import ProvidesHistoryContext
from galaxy.schema.fields import DecodedDatabaseIdField
from galaxy.schema.schema import (
AnyHDCA,
CreateNewCollectionPayload,
DatasetCollectionInstanceType,
DCESummary,
HDCADetailed,
)
from galaxy.webapps.galaxy.api import (
depends,
DependsOnTrans,
Router,
)
from galaxy.webapps.galaxy.services.dataset_collections import (
DatasetCollectionAttributesResult,
DatasetCollectionContentElements,
DatasetCollectionsService,
SuitableConverters,
UpdateCollectionAttributePayload,
)
log = getLogger(__name__)
router = Router(tags=["dataset collections"])
DatasetCollectionIdPathParam: DecodedDatabaseIdField = Path(
..., description="The encoded identifier of the dataset collection."
)
DatasetCollectionElementIdPathParam: DecodedDatabaseIdField = Path(
..., description="The encoded identifier of the dataset collection element."
)
InstanceTypeQueryParam: DatasetCollectionInstanceType = Query(
default="history",
description="The type of collection instance. Either `history` (default) or `library`.",
)
[docs]@router.cbv
class FastAPIDatasetCollections:
service: DatasetCollectionsService = depends(DatasetCollectionsService)
[docs] @router.post(
"/api/dataset_collections",
summary="Create a new dataset collection instance.",
)
def create(
self,
trans: ProvidesHistoryContext = DependsOnTrans,
payload: CreateNewCollectionPayload = Body(...),
) -> HDCADetailed:
return self.service.create(trans, payload)
[docs] @router.post(
"/api/dataset_collections/{id}/copy",
summary="Copy the given collection datasets to a new collection using a new `dbkey` attribute.",
)
def copy(
self,
trans: ProvidesHistoryContext = DependsOnTrans,
id: DecodedDatabaseIdField = Path(..., description="The ID of the dataset collection to copy."),
payload: UpdateCollectionAttributePayload = Body(...),
):
self.service.copy(trans, id, payload)
[docs] @router.get(
"/api/dataset_collections/{id}/attributes",
summary="Returns `dbkey`/`extension` attributes for all the collection elements.",
)
def attributes(
self,
trans: ProvidesHistoryContext = DependsOnTrans,
id: DecodedDatabaseIdField = DatasetCollectionIdPathParam,
instance_type: DatasetCollectionInstanceType = InstanceTypeQueryParam,
) -> DatasetCollectionAttributesResult:
return self.service.attributes(trans, id, instance_type)
[docs] @router.get(
"/api/dataset_collections/{id}/suitable_converters",
summary="Returns a list of applicable converters for all datatypes in the given collection.",
)
def suitable_converters(
self,
trans: ProvidesHistoryContext = DependsOnTrans,
id: DecodedDatabaseIdField = DatasetCollectionIdPathParam,
instance_type: DatasetCollectionInstanceType = InstanceTypeQueryParam,
) -> SuitableConverters:
return self.service.suitable_converters(trans, id, instance_type)
[docs] @router.get(
"/api/dataset_collections/{id}",
summary="Returns detailed information about the given collection.",
)
def show(
self,
trans: ProvidesHistoryContext = DependsOnTrans,
id: DecodedDatabaseIdField = DatasetCollectionIdPathParam,
instance_type: DatasetCollectionInstanceType = InstanceTypeQueryParam,
) -> AnyHDCA:
return self.service.show(trans, id, instance_type)
[docs] @router.get(
"/api/dataset_collections/{hdca_id}/contents/{parent_id}",
name="contents_dataset_collection",
summary="Returns direct child contents of indicated dataset collection parent ID.",
)
def contents(
self,
trans: ProvidesHistoryContext = DependsOnTrans,
hdca_id: DecodedDatabaseIdField = DatasetCollectionIdPathParam,
parent_id: DecodedDatabaseIdField = Path(
...,
description="Parent collection ID describing what collection the contents belongs to.",
),
instance_type: DatasetCollectionInstanceType = InstanceTypeQueryParam,
limit: Optional[int] = Query(
default=None,
description="The maximum number of content elements to return.",
),
offset: Optional[int] = Query(
default=None,
description="The number of content elements that will be skipped before returning.",
),
) -> DatasetCollectionContentElements:
return self.service.contents(trans, hdca_id, parent_id, instance_type, limit, offset)
[docs] @router.get("/api/dataset_collection_element/{dce_id}")
def content(
self,
trans: ProvidesHistoryContext = DependsOnTrans,
dce_id: DecodedDatabaseIdField = DatasetCollectionElementIdPathParam,
) -> DCESummary:
return self.service.dce_content(trans, dce_id)