Dynamic visualization of softwares managed by a Bioinformatics Core Facility
Project description
ToolDirectory
Introduction
ToolDirectory provides a convenient tool to display list of softwares in a webpage along with dynamic data filtering capabilities.
You can test our public demo
Direct use of ToolDirectory Viewer
ToolDirectory is a Python 3.x program. It also requires the following package:
- requests >=2.25.1
- rich-click >=1.5.2
- loguru >=0.6.0
conda create -p tooldir -c anaconda requests=2.25.1 rich-click=1.5.2 loguru=0.6.0
Web rendering relies on the open-source version of Keshif data visualisation. We provided Katalog, a lightweight version specifically designed for ToolDirectory and DataDirectory.
Basic usage
$ tooldir -h
Usage: tooldir [OPTIONS] COMMAND [ARGS]...
ToolDirectory: A dynamic visualization of pieces of software managed by
a Bioinformatics Core Facility
╭─ Options ─────────────────────────────────────────────────────────────╮
│ --version Show the version and exit. │
│ --help -h Show this message and exit. │
╰───────────────────────────────────────────────────────────────────────╯
╭─ Main usage ──────────────────────────────────────────────────────────╮
│ create Create tool properties or add a new version │
│ update Update metadata of a tool │
│ status Set installation status of a tool's version │
╰───────────────────────────────────────────────────────────────────────╯
╭─ Visualization ───────────────────────────────────────────────────────╮
│ kcsv Create csv for Keshif visualisation │
╰───────────────────────────────────────────────────────────────────────╯
Data structure
ToolDirectory expects a directory structure with the following constraints:
- /path/to/tools/tool-name/tool-version/
Or, with modules architecture:
- /path/to/tools/tool-name/modulefile
Or, with modules architecture:
- <install-dir>/<tool>/
Here is an example:
/path/to/tools/
├── blast
│ ├── 2.2.31 #Folder or modulefile
│ └── 2.6.0
├── plast
│ └── 2.3.2
├── beedeem
│ └── 4.3.0
.../...
Usage
Creation a tool description
tooldir create -n <tool-name> -v <tool-version> -o <username> -p /path/to/tools/
Sometimes the processus fails: it happens when the tool is not referenced yet in Bio.tools. You can manually fill the missing fields but we strongly encourage you to create the tool description on Bio.tools and recreate or update the json.
In the case of the installation of an addition of a new version, the json is modified to add the associated information without changing the metadata of the tool.
Update tool metadata
tooldir update -j /appli/bioinfo/spades/properties.json
Force metadata search based on Bio.tools ID
It may happen that the name you gave for the tool differs from the identifier given in Bio.tools. In this case, it is possible to force the search to retrieve the metadata.
tooldir create -n interproscan -v 5.48-83.0 -o acormier -b interproscan_ebi
tooldir update -j /appli/bioinfo/interproscan/properties.json -b interproscan_ebi
Setup visualisation
You will need Katalog, a lightweight version of Keshif specifically designed for ToolDirectory and DataDirectory.
git clone https://gitlab.ifremer.fr/bioinfo/katalog.git /foo/bar/www/tooldirectory
Then, generate the software list:
tooldir kcsv -p /path/to/tools/ -c /foo/bar/www/tooldirectory/Softwares.csv
You can use a crontab to automatically update the software listing.
Licenses
Tool Directory is released under the terms of the Apache 2 license.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file tooldirectory-5.1.1.tar.gz
.
File metadata
- Download URL: tooldirectory-5.1.1.tar.gz
- Upload date:
- Size: 13.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 89286253a67b4aa975919891331e9f8c59d54689549153a2515eb4767ef0a551 |
|
MD5 | 2b9a479fb95648345e60bee4ccd8348e |
|
BLAKE2b-256 | 4168e2118aedd0cc7f1eae300a4381c5c8684138386155a6ca561fe6fb779787 |