nf_core.download
Downloads a nf-core pipeline to the local file system.
exceptionnf_core.download.ContainerError(container, registry, address, out_path, singularity_command, error_msg)
Bases: Exception
A class of errors related to pulling containers with Singularity/Apptainer
undefined ImageExists(error_log)
Bases: FileExistsError
Image already exists in cache/output directory.
undefined ImageNotFound(error_log)
Bases: FileNotFoundError
The image can not be found in the registry
undefined InvalidTag(error_log)
Bases: AttributeError
Image and registry are valid, but the (version) tag is not
undefined OtherError(error_log)
Bases: RuntimeError
Undefined error with the container
undefined RegistryNotFound(error_log)
Bases: ConnectionRefusedError
The specified registry does not resolve to a valid IP address
exceptionnf_core.download.DownloadError
Bases: RuntimeError
A custom exception that is raised when nf-core download encounters a problem that we already took into consideration. In this case, we do not want to print the traceback, but give the user some concise, helpful feedback instead.
classnf_core.download.DownloadProgress(*columns: str | ProgressColumn, console: Console | None = None, auto_refresh: bool = True, refresh_per_second: float = 10, speed_estimate_period: float = 30.0, transient: bool = False, redirect_stdout: bool = True, redirect_stderr: bool = True, get_time: Callable[[], float] | None = None, disable: bool = False, expand: bool = False)
Bases: Progress
Custom Progress bar class, allowing us to have two progress bars with different columns / layouts.
get_renderables()
Get a number of renderables for the progress display.
classnf_core.download.DownloadWorkflow(pipeline=None, revision=None, outdir=None, compress_type=None, force=False, tower=False, download_configuration=None, container_system=None, container_library=None, container_cache_utilisation=None, container_cache_index=None, parallel_downloads=4)
Bases: object
Downloads a nf-core workflow from GitHub to the local file system.
Can also download its Singularity container image if required.
- Parameters:
- pipeline (str) – A nf-core pipeline name.
- revision (List*[str]*) – The workflow revision to download, like 1.0. Defaults to None.
- container (bool) – Flag, if the Singularity container should be downloaded as well. Defaults to False.
- tower (bool) – Flag, to customize the download for Nextflow Tower (convert to git bare repo). Defaults to False.
- outdir (str) – Path to the local download directory. Defaults to None.
 
compress_download()
Take the downloaded files and make a compressed .tar.gz archive.
download_configs()
Downloads the centralised config profiles from nf-core/configs to self.outdir.
download_wf_files(revision, wf_sha, download_url)
Downloads workflow files from GitHub to the self.outdir.
download_workflow()
Starts a nf-core workflow download.
download_workflow_static()
Downloads a nf-core workflow from GitHub to the local file system in a self-contained manner.
download_workflow_tower(location=None)
Create a bare-cloned git repository of the workflow, so it can be launched with tw launch as file:/ pipeline
find_container_images(workflow_directory)
Find container image names for workflow.
Starts by using nextflow config to pull out any process.container declarations. This works for DSL1. It should return a simple string with resolved logic, but not always, e.g. not for differentialabundance 1.2.0
Second, we look for DSL2 containers. These can’t be found with nextflow config at the time of writing, so we scrape the pipeline files. This returns raw matches that will likely need to be cleaned.
get_revision_hash()
Find specified revision / branch hash
get_singularity_images(current_revision='')
Loop through container names and download Singularity images
prompt_compression_type()
Ask user if we should compress the downloaded files
prompt_config_inclusion()
Prompt for inclusion of institutional configurations
prompt_container_download()
Prompt whether to download container images or not
prompt_pipeline_name()
Prompt for the pipeline name if not set with a flag
prompt_revision()
Prompt for pipeline revision / branch Prompt user for revision tag if ‘–revision’ was not set If –tower is specified, allow to select multiple revisions Also the static download allows for multiple revisions, but we do not prompt this option interactively.
prompt_singularity_cachedir_creation()
Prompt about using $NXF_SINGULARITY_CACHEDIR if not already set
prompt_singularity_cachedir_remote()
Prompt about the index of a remote $NXF_SINGULARITY_CACHEDIR
prompt_singularity_cachedir_utilization()
Ask if we should only use $NXF_SINGULARITY_CACHEDIR without copying into target
read_remote_containers()
Reads the file specified as index for the remote Singularity cache dir
rectify_raw_container_matches(raw_findings)
Helper function to rectify the raw extracted container matches into fully qualified container names. If multiple containers are found, any prefixed with http for direct download is prioritized
Example syntax:
Early DSL2:
: if (workflow.containerEngine == ‘singularity’ && !params.singularity_pull_docker_container) {
: container “https://depot.galaxyproject.org/singularity/fastqc:0.11.9–0” 
} else {
: container “quay.io/biocontainers/fastqc:0.11.9–0” 
}
Later DSL2: : container “${ workflow.containerEngine == ‘singularity’ && !task.ext.singularity_pull_docker_container ? : ‘https://depot.galaxyproject.org/singularity/fastqc:0.11.9–0’ : ‘biocontainers/fastqc:0.11.9–0’ }”
Later DSL2, variable is being used:
: container “{ workflow.containerEngine == ‘singularity’ && !task.ext.singularity\_pull\_docker\_container ?
: “<https://depot.galaxyproject.org/singularity>/{container_id}” :
“quay.io/biocontainers/${container_id}” }” 
container_id = ‘mulled-v2-1fa26d1ce03c295fe2fdcf85831a92fbcbd7e8c2
DSL1 / Special case DSL2: : container “nfcore/cellranger:6.0.2”
singularity_copy_cache_image(container, out_path, cache_path)
Copy Singularity image from NXF_SINGULARITY_CACHEDIR to target folder.
singularity_download_image(container, out_path, cache_path, progress)
Download a singularity image from the web.
Use native Python to download the file.
- Parameters:
- container (str) – A pipeline’s container name. Usually it is of similar format
to https://depot.galaxyproject.org/singularity/name:version
- out_path (str) – The final target output path
- cache_path (str*,* None) – The NXF_SINGULARITY_CACHEDIR path if set, None if not
- progress (Progress) – Rich progress bar instance to add tasks to.
 
- container (str) – A pipeline’s container name. Usually it is of similar format
to 
singularity_image_filenames(container)
Check Singularity cache for image, copy to destination folder if found.
- Parameters: container (str) – A pipeline’s container name. Can be direct download URL or a Docker Hub repository ID.
- Returns: Returns True if we have the image in the target location. : Returns a download path if not.
- Return type: results (bool, str)
singularity_pull_image(container, out_path, cache_path, library, progress)
Pull a singularity image using singularity pull
Attempt to use a local installation of singularity to pull the image.
- Parameters:
- container (str) – A pipeline’s container name. Usually it is of similar format
to nfcore/name:version.
- library (list of str) – A list of libraries to try for pulling the image.
 
- container (str) – A pipeline’s container name. Usually it is of similar format
to 
- Raises: Various exceptions possible from subprocess execution of Singularity. –
wf_use_local_configs(revision_dirname)
Edit the downloaded nextflow.config file to use the local config files
classnf_core.download.WorkflowRepo(remote_url, revision, commit, location=None, hide_progress=False, in_cache=True)
Bases: SyncedRepo
An object to store details about a locally cached workflow repository.
Important Attributes:
: fullname: The full name of the repository, nf-core/{self.pipelinename}.
local_repo_dir (str): The local directory, where the workflow is cloned into. Defaults to $HOME/.cache/nf-core/nf-core/{self.pipeline}.
access()
bare_clone(destination)
checkout(commit)
Checks out the repository at the requested commit
- Parameters: commit (str) – Git SHA of the commit
get_remote_branches(remote_url)
Get all branches from a remote repository
- Parameters: remote_url (str) – The git url to the remote repository
- Returns: All branches found in the remote
- Return type: (set[str])
retry_setup_local_repo(skip_confirm=False)
setup_local_repo(remote, location=None, in_cache=True)
Sets up the local git repository. If the repository has been cloned previously, it returns a git.Repo object of that clone. Otherwise it tries to clone the repository from the provided remote URL and returns a git.Repo of the new clone.
- Parameters:
- remote (str) – git url of remote
- location (Path) – location where the clone should be created/cached.
- in_cache (bool*,* optional) – Whether to clone the repository from the cache. Defaults to False.
 
Sets self.repo
tidy_tags_and_branches()
Function to delete all tags and branches that are not of interest to the downloader. This allows a clutter-free experience in Tower. The untagged commits are evidently still available.
However, due to local caching, the downloader might also want access to revisions that had been deleted before. In that case, don’t bother with re-adding the tags and rather download anew from Github.