Skip to content

STARK is a Next-Generation Sequencing data analysis pipeline for clinical diagnosis

License

Notifications You must be signed in to change notification settings

bioinfo-chru-strasbourg/STARK

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

STARK

STARK is a Next-Generation Sequencing data analysis pipeline for clinical diagnosis

  • Stellar Tools for variants Analysis and RanKing
  • Author: Antony Le Béchec
  • Copyright: HUS/CPS
  • License: GNU GPLA V3
  • Release : 0.9.18.5
  • Date : 20230307

Getting Started

Use curl from GitHub bioinfo-chru-strasbourg to setup STARK environment by default.

$ mkdir -p ${HOME}/STARK && cd ${HOME}/STARK && curl https://raw.githubusercontent.com/bioinfo-chru-strasbourg/STARK/master/setup.sh | bash

Use STARK Command Line Interface (CLI) to execute custom analyses with data in ${HOME}/STARK/data (/STARK/data whtin the container).

$ docker exec stark-module-stark-submodule-stark-service-cli STARK --help

Complete setup


1. Download

Download STARK script from BioInfoDiag GitLab.

$ git clone https://github.com/bioinfo-chru-strasbourg/STARK.git .

2. Configuration

Edit ".env" file to configure STARK environment with ".env". Basically, change the STARK main host folder with the variable "DOCKER_STARK_MAIN_FOLDER" (default ${HOME}/STARK). All sub-folders (input, output, databases location... and create/configure them by yourself) can be configured, such as STARK variables (see ".env" file comments). The default configuration is adequate for a standard environment, but all variables in ".env" file and services in "docker-compose.yml" file can be modified to fit infrastructure specificity.


3. Build

Build all docker images needed by STARK environment.

$ docker-compose build

4. Setup

The setup step will create folders (if not exist), populate databases folder if needed, and incrementally archives tools setup sources and binaries. Use --project-name if STARK scripts are not in a folder named "STARK". Variable DOCKER_STARK_MAIN_FOLDER corresponds to variable in ".env" configuration file (default "$HOME/STARK").

$ DOCKER_STARK_MAIN_FOLDER=<STARK_main_folder>
$ mkdir -p $DOCKER_STARK_MAIN_FOLDER
$ docker-compose --project-name STARK up stark-setup
$ docker-compose --project-name STARK up stark-databases
$ docker-compose --project-name STARK up stark-sources-archives

5. Services

Services are located in the folder 'services', and are organized in separated modules (folders), containing 'STARK.docker-compose.yml' file describing services, 'STARK.env' file including all parameters, and 'STARK.module' file describing the module and all services, especially to share information and access to other modules.

To automatically start all services modules (detached):

$ services/services.sh --modules=* --command=up

Main STARK services in the folder 'services/STARK' contains a CLI (Command Line Interface), an API (Application Program Interface), a Listener and its cleaner, and a DAS service (DAta Sharing).

$ services/services.sh --modules=stark --command=up

Analysis


1. STARK Command Line Interface (CLI)

A STARK Command Line Interface (CLI) is started as a container to execute custom analyses with data and runs, available in inner main folder (default /STARK/data and /STARK/data, resp.).

Use STARK Command Line Interface with command 'docker exec stark-module-stark-submodule-stark-service-cli STARK', to execute a STARK command with data and runs (run names will be automatically found in input folder). For more information, use HELP option.

$ docker exec stark-module-stark-submodule-stark-service-cli STARK --help
$ docker exec stark-module-stark-submodule-stark-service-cli STARK --run=<my_run>
$ docker exec stark-module-stark-submodule-stark-service-cli STARK --reads=/STARK/data/<my_data>/<my_fastq> --design=/STARK/data/<my_data>/<my_design> --application=<my_application> --repository=/STARK/data/<my_data>/<my_output>

STARK Command Line Interface can be used in interactive mode ('-ti' option). All tools used by STARK can be executed as they are in the PATH environment variable (e.g. samtools, bcftools). Available tools can be found in 'STARK/tools' folder.

$ docker exec -ti stark-module-stark-submodule-stark-service-cli bash
$ docker exec stark-module-stark-submodule-stark-service-cli samtools
$ docker exec stark-module-stark-submodule-stark-service-cli bcftools
$ docker exec stark-module-stark-submodule-stark-service-cli bash -c "find /STARK/tools -mindepth 2 -maxdepth 2 -type d"

2. STARK Application Program Interface (API)

A STARK Application Program Interface (API) is available through URI http://<ip>:<port> (default http://localhost:4200, help with an internet browser). This service prodives an interface to run STARK analysis with parameters in JSON format through URI (http://<ip>:<port>/analysis), and to manage analyses queue (http://<ip>:<port>/queue)

$ curl -X POST -H 'Content-Type: application/json' -d '{"run":"MY_RUN"}' http://<ip>:<port>/analysis # STARK analysis with curl in POST method:
$ curl http://<ip>:<port>/queue?list # List of analysis running, queued and finished

3. STARK DAta Sharing (DAS)

A STARK DAta Sharing (DAS) web server provides data publically through URI http://<ip>:<port> (default http://localhost:4201/<path>). This server may be used with application able to open file through URI (such as IGV), or to share data and files between other STARK modules and services.

By default, data available are (<path>):

  • runs: inputs/Input/runs
  • repository: repositories/Repository
  • archives: repositories/Archives
  • data: data
  • databases: databases

4. STARK listener

A STARK listener service is started as a daemon, listening for new sequenced NGS run (new folder in input/runs) and well configured (RTAComplete.txt and SampleSheet.csv), and send a request to STARK API. A STARK listener clear service is checking (once at services start) STARK listener and STARK API log files to reload requests if needed (useful after a server stop/crash).