Warning

This document is for an old release 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.tools.deps.views

from galaxy.exceptions import (
    NotImplemented,
    RequestParameterMissingException
)


[docs]class DependencyResolversView(object): """ Provide a RESTfulish/JSONy interface to a galaxy.tools.deps.DependencyResolver object. This can be adapted by the Galaxy web framework or other web apps. """
[docs] def __init__(self, app): self._app = app
[docs] def index(self): return [r.to_dict() for r in self._dependency_resolvers]
[docs] def show(self, index): return self._dependency_resolver(index).to_dict()
[docs] def reload(self): self.toolbox.reload_dependency_manager()
[docs] def manager_requirements(self): requirements = [] for index, resolver in enumerate(self._dependency_resolvers): if not hasattr(resolver, "list_dependencies"): continue for requirement in resolver.list_dependencies(): requirements.append({"index": index, "requirement": requirement.to_dict()}) return requirements
[docs] def resolver_requirements(self, index): requirements = [] resolver = self._dependency_resolver(index) if not hasattr(resolver, "list_dependencies"): raise NotImplemented() for requirement in resolver.list_dependencies(): requirements.append(requirement.to_dict()) return requirements
[docs] def manager_dependency(self, **kwds): return self._dependency(**kwds)
[docs] def resolver_dependency(self, index, **kwds): return self._dependency(**kwds)
[docs] def show_dependencies(self, tool_requirements_d, installed_tool_dependencies=None): """ Resolves dependencies to build a requirements status in the admin panel/API """ kwds = {'install': False, 'return_null': True, 'installed_tool_dependencies': installed_tool_dependencies} dependencies_per_tool = {tool: self._dependency_manager.requirements_to_dependencies(requirements, **kwds) for tool, requirements in tool_requirements_d.items()} return dependencies_per_tool
[docs] def uninstall_dependencies(self, index=None, **payload): """Attempt to uninstall requirements. Returns 0 if successfull, else None.""" requirements = payload.get('requirements') if not requirements: return None if index: resolver = self._dependency_resolvers[index] if resolver.can_uninstall_dependencies: return resolver.uninstall(requirements) else: for index in self.uninstallable_resolvers: return_code = self._dependency_resolvers[index].uninstall(requirements) if return_code == 0: return return_code return None
@property def unused_dependency_paths(self): """List dependencies that are not currently installed.""" unused_dependencies = [] toolbox_requirements_status = self.toolbox_requirements_status for resolver in self._dependency_resolvers: if hasattr(resolver, 'unused_dependency_paths'): unused_dependencies.extend(resolver.unused_dependency_paths(toolbox_requirements_status)) return set(unused_dependencies)
[docs] def remove_unused_dependency_paths(self, envs): """ Remove dependencies that are not currently used. Returns a list of all environments that have been successfully removed. """ envs_to_remove = set(envs) toolbox_requirements_status = self.toolbox_requirements_status removed_environments = set() for resolver in self._dependency_resolvers: if hasattr(resolver, 'unused_dependency_paths') and hasattr(resolver, 'uninstall_environments'): unused_dependencies = resolver.unused_dependency_paths(toolbox_requirements_status) can_remove = envs_to_remove & set(unused_dependencies) exit_code = resolver.uninstall_environments(can_remove) if exit_code == 0: removed_environments = removed_environments.union(can_remove) envs_to_remove = envs_to_remove.difference(can_remove) return list(removed_environments)
[docs] def install_dependencies(self, requirements): return self._dependency_manager._requirements_to_dependencies_dict(requirements, **{'install': True})
[docs] def install_dependency(self, index=None, **payload): """ Installs dependency using highest priority resolver that supports dependency installation (Currently only the conda resolver supports this). If index is given, attempt installation directly using the corresponding resolver. Returns True on success, False on failure. payload is dictionary that must container name, version and type, e.g. {'name': 'numpy', version='1.9.1', type='package'} """ if index: return self._install_dependency(index, **payload) else: for index in self.installable_resolvers: success = self._install_dependency(index, **payload) if success: return success return False
def _install_dependency(self, index, **payload): """ Resolver install dependency should return True when installation succeeds, False if not successful """ resolver = self._dependency_resolver(index) if not hasattr(resolver, "install_dependency"): raise NotImplemented() name, version, type, extra_kwds = self._parse_dependency_info(payload) return resolver.install_dependency( name=name, version=version, type=type, **extra_kwds ) def _dependency(self, index=None, **kwds): if index is not None: index = int(index) name, version, type, extra_kwds = self._parse_dependency_info(kwds) resolve_kwds = dict( job_directory=None, index=index, **extra_kwds ) dependency = self._dependency_manager.find_dep( name, version=version, type=type, **resolve_kwds ) return dependency.to_dict() def _parse_dependency_info(self, kwds): extra_kwds = kwds.copy() name = extra_kwds.pop("name", None) if name is None: raise RequestParameterMissingException("Missing 'name' parameter required for resolution.") version = extra_kwds.pop("version", None) type = extra_kwds.pop("type", "package") return name, version, type, extra_kwds def _dependency_resolver(self, index): index = int(index) return self._dependency_resolvers[index] @property def _dependency_manager(self): return self._app.toolbox.dependency_manager @property def _dependency_resolvers(self): dependency_manager = self._dependency_manager dependency_resolvers = dependency_manager.dependency_resolvers return dependency_resolvers @property def installable_resolvers(self): """ List index for all active resolvers that have the 'install_dependency' attribute. """ return [index for index, resolver in enumerate(self._dependency_resolvers) if hasattr(resolver, "install_dependency") and not resolver.disabled] @property def uninstallable_resolvers(self): """ List index for all active resolvers that can uninstall dependencies that have been installed through this resolver. """ return [index for index, resolver in enumerate(self._dependency_resolvers) if resolver.can_uninstall_dependencies and not resolver.disabled] @property def tool_ids_by_requirements(self): """Dictionary with requirements as keys, and tool_ids as values.""" tool_ids_by_requirements = {} if not self._app.toolbox.tools_by_id: return {} for tid, tool in self._app.toolbox.tools_by_id.items(): if tool.tool_requirements not in tool_ids_by_requirements: tool_ids_by_requirements[tool.tool_requirements] = [tid] else: tool_ids_by_requirements[tool.tool_requirements].append(tid) return tool_ids_by_requirements @property def toolbox_requirements_status(self): return {r: self.get_requirements_status(tool_requirements_d={tids[0]: r}, installed_tool_dependencies=self._app.toolbox.tools_by_id[tids[0]].installed_tool_dependencies) for r, tids in self.tool_ids_by_requirements.items()}
[docs] def get_requirements_status(self, tool_requirements_d, installed_tool_dependencies=None): dependencies = self.show_dependencies(tool_requirements_d, installed_tool_dependencies) # dependencies is a dict keyed on tool_ids, value is a ToolRequirements object for that tool. # We use the union of resolvable ToolRequirements to get resolved dependencies without duplicates. requirements = [r.resolvable for r in tool_requirements_d.values()] flat_tool_requirements = set().union(*requirements) flat_dependencies = [] for requirements_odict in dependencies.values(): for requirement in requirements_odict: if requirement in flat_tool_requirements: flat_dependencies.append(requirements_odict[requirement]) flat_tool_requirements.remove(requirement) return [d.to_dict() for d in flat_dependencies]
[docs] def clean(self, index=None, **kwds): if index: resolver = self._dependency_resolver(index) if not hasattr(resolver, "clean"): raise NotImplemented() else: resolver.clean() return "OK" else: [resolver.clean(**kwds) for resolver in self._dependency_resolvers if hasattr(resolver, 'clean')] return "OK"