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}