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)