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

"""
API for searching Galaxy Datasets
"""
import logging

from galaxy import web
from galaxy.exceptions import ItemAccessibilityException
from galaxy.model.search import GalaxySearchEngine
from galaxy.util import unicodify
from galaxy.webapps.base.controller import (
    BaseAPIController,
    SharableItemSecurityMixin
)

log = logging.getLogger(__name__)


[docs]class SearchController(BaseAPIController, SharableItemSecurityMixin):
[docs] @web.legacy_expose_api def create(self, trans, payload, **kwd): """ POST /api/search Do a search of the various elements of Galaxy. """ query_txt = payload.get("query", None) out = [] if query_txt is not None: se = GalaxySearchEngine() try: query = se.query(query_txt) except Exception as e: return {'error': unicodify(e)} if query is not None: query.decode_query_ids(trans) current_user_roles = trans.get_current_user_roles() try: results = query.process(trans) except Exception as e: return {'error': unicodify(e)} for item in results: append = False if trans.user_is_admin: append = True if not append: if type(item) in [trans.app.model.LibraryFolder, trans.app.model.LibraryDatasetDatasetAssociation, trans.app.model.LibraryDataset]: if (trans.app.security_agent.can_access_library_item(trans.get_current_user_roles(), item, trans.user)): append = True elif type(item) in [trans.app.model.Job]: if item.used_id == trans.user or trans.user_is_admin: append = True elif type(item) in [trans.app.model.Page, trans.app.model.StoredWorkflow]: try: if self.security_check(trans, item, False, True): append = True except ItemAccessibilityException: append = False elif type(item) in [trans.app.model.PageRevision]: try: if self.security_check(trans, item.page, False, True): append = True except ItemAccessibilityException: append = False elif hasattr(item, 'dataset'): if trans.app.security_agent.can_access_dataset(current_user_roles, item.dataset): append = True if append: row = query.item_to_api_value(item) out.append(self.encode_all_ids(trans, row, True)) return {'results': out}