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.item_tags

"""
API operations related to tagging items.
"""
import logging

from galaxy import exceptions
from galaxy.web import expose_api
from galaxy.web.base.controller import (
    BaseAPIController,
    UsesTagsMixin
)

log = logging.getLogger(__name__)


[docs]class BaseItemTagsController(BaseAPIController, UsesTagsMixin): """ """
[docs] @expose_api def index(self, trans, **kwd): """ """ tags = self._get_user_tags(trans, self.tagged_item_class, kwd[self.tagged_item_id]) return [self._api_value(tag, trans, view='collection') for tag in tags]
[docs] @expose_api def show(self, trans, tag_name, **kwd): """ """ tag = self._get_item_tag_assoc(trans, self.tagged_item_class, kwd[self.tagged_item_id], tag_name) if not tag: raise exceptions.ObjectNotFound("Failed to retrieve specified tag.") return self._api_value(tag, trans)
[docs] @expose_api def create(self, trans, tag_name, payload=None, **kwd): """ """ payload = payload or {} value = payload.get("value", None) tag = self._apply_item_tag(trans, self.tagged_item_class, kwd[self.tagged_item_id], tag_name, value) return self._api_value(tag, trans)
# Not handling these differently at this time update = create
[docs] @expose_api def delete(self, trans, tag_name, **kwd): """ """ deleted = self._remove_items_tag(trans, self.tagged_item_class, kwd[self.tagged_item_id], tag_name) if not deleted: raise exceptions.RequestParameterInvalidException("Failed to delete specified tag.") # TODO: ugh - 204 would be better return 'OK'
def _api_value(self, tag, trans, view='element'): return tag.to_dict(view=view, value_mapper={'id': trans.security.encode_id})
[docs]class HistoryContentTagsController(BaseItemTagsController): controller_name = "history_content_tags" tagged_item_class = "HistoryDatasetAssociation" tagged_item_id = "history_content_id"
[docs]class HistoryTagsController(BaseItemTagsController): controller_name = "history_tags" tagged_item_class = "History" tagged_item_id = "history_id"
[docs]class WorkflowTagsController(BaseItemTagsController): controller_name = "workflow_tags" tagged_item_class = "StoredWorkflow" tagged_item_id = "workflow_id"
# TODO: Visualization and Pages once APIs for those are available