NAME
Bio::CIPRES - interface to the CIPRES REST API
SYNOPSIS
use Bio::CIPRES;
my $ua = Bio::CIPRES->new(
user => $username,
pass => $password,
app_id => $id,
timeout => 60,
);
my $job = $ua->submit_job( %job_params );
while (! $job->is_finished) {
sleep $job->poll_interval;
$job->refresh;
}
print STDOUT $job->stdout;
print STDERR $job->stderr;
if ($job->exit_code == 0) {
for my $file ($job->outputs) {
$file->download( out => $file->name );
}
}
DESCRIPTION
Bio::CIPRES
is an interface to the CIPRES REST API for running phylogenetic analyses. Currently it provides general classes and methods for job submission and handling - determination of the correct parameters to submit is up to the user (check "SEE ALSO" for links to tool documentation).
METHODS
- new
-
my $ua = Bio::CIPRES->new( user => $username, pass => $password, app_id => $id, timeout => 60, ); # or read configuration from file my $ua = Bio::CIPRES->new( conf => "$ENV{HOME}/.cipres" );
Create a new
Bio::CIPRES
object. There are a number of required and optional parameters which can be specified in the constructor or read from a configuration file. The configuration file should contain key=value pairs, one pair per line, as in:user=foo pass=bar app_id=foo_bar-12345
Required parameters:
user - the username of your registered CIPRES REST account
pass - the password of your registered CIPRES REST account
The passphrase must be stored in plaintext, so the usual precautions apply (e.g. the file should not be world-readable). If possible, find another way to retrieve the passphrase within your code and pass it in directly as a method argument.
Optional parameters:
app_id - override the application ID assigned to Bio::CIPRES
url - override the default base REST url (don't change this unless you know what you're doing).
timeout - set the network timeout for HTTP requests
UMBRELLA parameters:
These parameters are only for use with UMBRELLA applications (you will need you register your own UMBRELLA application to use this functionality). They are not needed for non-UMBRELLA applications, but if
eu
is defined then UMBRELLA is assumed andeu_email
andapp_name
must be defined as well.eu - end user name
eu_email - end user email address
app_name - UMBRELLA application name as registered with CIPRES
eu_institution - end user institution (currently optional)
eu_country - end user two-letter country code (currently optional)
- submit_job
-
my $job = $ua->submit_job( %params );
Submit a new job to the CIPRES service. Params are set based on the tool documentation (not covered here). Returns a Bio::CIPRES::Job object.
Most params are passed as simple key => value pairs of strings based on the CIPRES tool documentation. One important nuance, however, is in the handling of input files. If the contents of a input file are to be passed in as a scalar, they should be provided directly as the scalar value to the appropriate key:
my $job = $ua->submit_job( 'input.infile_' => $in_contents );
However, if the input file is to be uploaded by filename, it should be passed as an array reference:
my $job = $ua->submit_job( 'input.infile_' => [$in_filename] );
Failure to understand the difference will result in errors either during job submission or during the job run.
- list_jobs
-
for my $job ( $ua->list_jobs ) { # do something }
Returns an array of Bio::CIPRES::Job objects representing jobs in the user's workspace.
- get_job
-
my $job = $ua->get_job( $job_handle );
Takes a single argument (string containing the job handle/ID) and returns a Bio::CIPRES::Job object representing the appropriate job, or undef if not found.
CAVEATS AND BUGS
This is code is in alpha testing stage and the API is not guaranteed to be stable.
Currently the use of UMBRELLA authentication is not implemented.
Please report bugs to the author.
SEE ALSO
https://www.phylo.org/restusers/documentation.action
AUTHOR
Jeremy Volkening <jdv@base2bio.com>
COPYRIGHT AND LICENSE
Copyright 2016 Jeremy Volkening
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>.