No Description

E.Cannon a09c30124f minor word changes 7 years ago
api 989190ff3c Added warning to blastdb node pages when cvitjs is enabled but there is no config. 7 years ago
includes a09c30124f minor word changes 7 years ago
theme 7a8f1b79f3 Switch to embedded CViTjs mode to fix themeing issues + minor adjustments to results page for better flow. 7 years ago
.gitignore 911e1de8cd Added git-ignore file so I don't accidentally commit cvitjs into blast. 7 years ago
README.md 527a7157d8 Switched to github markdown for README 9 years ago
blast_ui.info 0ca91becb2 Added help & configure links to module 11 years ago
blast_ui.install 734d301968 Removes all nodes of type 'Blast Database' when module is uninstalled 7 years ago
blast_ui.module 0b2634c085 Added db storage of blast job details and cleaned up different implementations previously storing data (edit & resubmit used drupal variables and recent jobs used session) to use the new database saved details. 10 years ago

README.md

INTRODUCTION

This module provides a basic interface to allow your users to utilize your server's NCBI BLAST+.

Specifically it provides two forms, one for nucleotide queries and another for protein queries. Currently only blastn and blastp are supported but in the future you will be able to select either a nucleotide or a protein database to BLAST against regardless of the type of query and this module will decide which BLAST program to use based on the combination of query/database type (ie: if you selected a protein database on the nucleotide BLAST form then blastx would be used).

BLAST submissions result in the creation of Tripal jobs which then need to run from the command-line. This ensures that long running BLASTS will not cause page time-outs but does add some management overhead and might result in longer waits for users depending on how often you have cron set to run Tripal jobs. A Tripal Jobs Daemon is under development to allow these jobs to be run almost as soon as they are submitted.

The BLAST results page is an expandable summary table with each hit being listed as a row in the table with query/hit/e-value information. The row can then be expanded to include additional information including the alignment. Download formats are under development to allow users to download these results in the familiar tabular or HTML NCBI formats.

Highlighted Functionality

  • Supports blastn and blastp with separate forms depending upon the query type.
  • Simple interface allowing users to paste or upload a query sequence and then select from available databases. Additionally, a FASTA file can be uploaded for use as a database to BLAST against.
  • Tabular Results listing with alignment information available.
  • Completely integrated with Tripal Jobs providing administrators with a way to track BLAST jobs and ensuring long running BLASTs will not cause page time-outs
  • BLAST databases are made available to the module by creating Drupal Pages describing them. This allows administrators to use the Drupal Field API to add any information they want to these pages.

Installation

  1. Install NCBI BLAST+ on your server (Tested with 2.2.26+). There is a package available for Ubuntu to ease installation.
  2. Install this module as you would any Drupal module (ie: download, unpack in sites/all/modules and enable through http://[your site]/admin/modules)
  3. Create "Blast Database" nodes for each dataset you want to make available for your users to BLAST against. BLAST databases should first be created using the command-line makeblastdb program with the -parse_seqids flag.

Customization

The BLAST module forms can be styled using CSS stylesheets in your own theme. By default it will use the default form themeing provided by your particular Drupal site allowing it to feel consistent with the look-and-feel of your Tripal site without customization being needed.

Additionally, the results page, waiting pages and the alignment section of the results page have their own template files (blast_report.tpl.php, blast_report_pending.tpl.php, and blast_report_alignment_row.tpl.php, respectively) which can easily be overridden in your own theme providing complete control over the look of the BLAST results.