Add software to Neurodocker#
Neurodocker defines the instructions to install and configure software using YAML files. These files are known as templates. This page explains how to add a new template to Neurodocker.
The env
and instructions
values can use
Jinja2 template language.
Example specification#
This example installs jq
, a
command-line JSON processor.
# The name of the software. This becomes the name in the template registry.
# The CLI option would be rendered as `--jq`.
name: jq
url: https://jqlang.github.io/jq/
# An alert that is printed when using this template in the CLI.
alert: Please be advised that this software uses
# How to install this software from pre-compiled binaries.
binaries:
# The available versions and their corresponding urls.
urls:
"1.6": https://github.com/stedolan/jq/releases/download/jq-1.6/jq-linux64
"1.5": https://github.com/stedolan/jq/releases/download/jq-1.5/jq-linux64
# Arguments that the user can provide when using this template. These arguments
# should be referenced in the `env` and/or `instructions`.
arguments:
required:
- version
optional:
install_path: /opt/jq-{{ self.version }}
# Environment variables to set in the container. Keys and values must be strings.
env:
PATH: {{ self.install_path }}:$PATH
# System packages that this software depends on.
dependencies:
apt:
- ca-certificates
- curl
yum:
- curl
# The installation instructions. Think of this like a shell scripts that installs
# the software.
instructions: |
{{ self.install_dependencies() }}
mkdir -p {{ self.install_path }}
curl -fsSL --output {{ self.install_path }}/jq {{ self.urls[self.version]}}
chmod +x {{ self.install_path }}/jq