You need to sign in or sign up before continuing.
Newer
Older
/* ExternalProgram.java
*
* created: Aug 2005
*
* This file is part of Artemis
*
* Copyright(C) 2005 Genome Research Limited
*
* 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 2
* 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, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*
**/
package uk.ac.sanger.artemis.j2ssh;
import uk.ac.sanger.artemis.components.MessageDialog;
import javax.swing.JOptionPane;
import javax.swing.JFileChooser;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JTextField;
import javax.swing.JPasswordField;
import javax.swing.SwingConstants;
import java.awt.GridLayout;
import java.io.File;
import java.io.FileReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.BufferedReader;
import java.io.IOException;
import java.util.Vector;
import java.util.Properties;
import com.sshtools.j2ssh.SshClient;
import com.sshtools.j2ssh.session.SessionChannelClient;
import com.sshtools.j2ssh.sftp.SftpFile;
import com.sshtools.j2ssh.SftpClient;
import com.sshtools.j2ssh.configuration.ConfigurationLoader;
/**
*
* Client to use ssh connection to server to run blast/fasta
* remotely.
*
*/
private String listfilepath = null;
private String cmd = null;
private String bsub = null;
private String logfile = null;
private String db = null;
//
private SshClient ssh;
private String user;
public SshPSUClient(String args[])
{
// process arguments
if(args != null && args.length > 0)
{
for(int i=0; i<args.length; i++)
{
listfilepath = args[i+1];
else if(args[i].equals("-cmd") && i < args.length-1)
cmd = args[i+1];
else if(args[i].equals("-bsub") && i < args.length-1)
bsub = args[i+1];
else if(args[i].equals("-l") && i < args.length-1)
logfile = args[i+1];
else if(args[i].equals("-d") && i < args.length-1)
db = args[i+1];
else if(args[i].equals("-wdir") && i < args.length-1)
wdir = args[i+1];
SshLogin sshLogin = new SshLogin();
ssh = sshLogin.getSshClient();
user = sshLogin.getUser();
try
{
ssh.disconnect();
SshLogin sshLogin = new SshLogin();
ssh = sshLogin.getSshClient();
}
catch(Exception exp)
{
System.out.println("SshPSUClient.rescue()");
exp.printStackTrace();
}
if(System.getProperty("debug") != null)
System.out.println("RUN "+program);
new MessageDialog(null,
"Finished \n" + program,
/**
*
* Read the sequence filenames in a list file
* @param String file list filename
* @return the sequence filename collection
*
*/
private Vector readListFile(String file)
{
Vector seqfiles = new Vector();
try
{
String line;
BufferedReader in = new BufferedReader(new FileReader(file));
while((line = in.readLine()) != null )
{
File seq = new File(line);
if(seq.exists())
{
seqfiles.add(seq.getAbsolutePath());
}
}
}
catch (IOException e)
{
System.out.println("Problem reading list file");
}
return seqfiles;
}
/**
*
* Wait until a file appears on the server.
*
*/
if(System.getProperty("debug") != null)
{
System.out.println("waitUntilFileAppears()");
sshe.printStackTrace();
}
sftp = getSftpClient();
try
{
if(fileExists(sftp, file))
return true;
} catch(SshException sshe2) {}
private boolean fileExists(SftpClient sftp, String file)
throws SshException, IOException
{
Object list[] = sftp.ls(wdir).toArray();
for(int j=0; j<list.length;j++)
{
if( ((SftpFile)list[j]).getFilename().equals(file) )
return true;
}
return false;
}
/**
*
* Get the properties from the j2ssh.properties file.
*
*/
private Properties getProperties()
{
Properties settings = new Properties();
ClassLoader cl = this.getClass().getClassLoader();
// try out of the classpath
try
{
settings.load(cl.getResourceAsStream("j2ssh.properties"));
}
catch (Exception e)
{
}
if(bsub == null && settings.getProperty("bsub") != null)
bsub = settings.getProperty("bsub");
if(db == null)
{
if(settings.getProperty("default_db") != null)
db = settings.getProperty("default_db");
else
db = "%uniprot";
}
if(wdir == null && settings.getProperty("wdir") != null)
if(cmd != null)
{
if(cmd.equals("blastp") && settings.getProperty("blastp") != null)
cmd = settings.getProperty("blastp");
else if(cmd.equals("blastn") && settings.getProperty("blastn") != null)
cmd = settings.getProperty("blastn");
else if(cmd.equals("blastx") && settings.getProperty("blastx") != null)
cmd = settings.getProperty("blastx");
else if(cmd.equals("tblastx") && settings.getProperty("tblastx") != null)
cmd = settings.getProperty("tblastx");
else if(cmd.equals("fasta") && settings.getProperty("fasta") != null)
cmd = settings.getProperty("fasta");
else if(cmd.equals("fastx") && settings.getProperty("fastx") != null)
cmd = settings.getProperty("fastx");
}
/**
*
* Run fasta or blast on the server ssh'ed into
*
*/
// prompt for local listfile
if(listfilepath == null)
{
JFileChooser chooser = new JFileChooser();
int returnVal = chooser.showOpenDialog(null);
if(returnVal == JFileChooser.APPROVE_OPTION)
listfilepath = chooser.getSelectedFile().getAbsolutePath();
else
return false;
}
// loop over sequence files in the listfile
Vector seqfile = readListFile(listfilepath);
for(int i=0; i<seqfile.size();i++)
{
String filepath = (String)seqfile.get(i);
int index = filepath.lastIndexOf(System.getProperty("file.separator"));
String filename = filepath;
if(index > -1)
filename = filename.substring(index+1);
try
{
// sftp.put(filepath, wdir+filename);
}
catch(SshException sshe)
{
if(System.getProperty("debug") != null)
{
System.out.println("runBlastOrFasta()");
sshe.printStackTrace();
}
if(!wdir.endsWith(program+"/"))
wdir = wdir+"/"+program+"/";
try
{
sftp.put(filepath, wdir+filename);
if(System.getProperty("debug") != null)
System.out.println("PUT SUCCESS "+wdir+filename);
}
catch(SshException ioe)
{
if(System.getProperty("debug") != null)
{
System.out.println("runBlastOrFasta() - 2");
ioe.printStackTrace();
}
sftp.put(filepath, wdir+filename);
}
if(System.getProperty("debug") != null)
System.out.println("STARTING session");
SessionChannelClient session = null;
try
{
if(!ssh.isConnected())
rescue();
session = ssh.openSessionChannel();
}
catch(IOException exp)
{
if(System.getProperty("debug") != null)
{
System.out.println("runBlastOrFasta() - 3");
exp.printStackTrace();
}
rescue();
}
if(System.getProperty("debug") != null)
System.out.println("STARTED session");
String outputfile = wdir+filename+".out";
final String actualCMD;
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
if( (cmd.indexOf("fasta33") > -1) ||
(cmd.indexOf("fastx33") > -1) )
{
if(settings.getProperty(db) != null)
db = settings.getProperty(db);
actualCMD = bsub+" -o "+ outputfile +" -e "+ outputfile + ".err " +
cmd+" "+wdir+filename+" "+db;
}
else
actualCMD = bsub+" -o "+ outputfile +" -e "+ outputfile + ".err " +
cmd+" "+db+" "+wdir+filename;
// run the application
if(System.getProperty("debug") != null)
System.out.println(actualCMD);
session.executeCommand(actualCMD);
// Reading from the session InputStream
StdoutStdErrHandler stdouth = new StdoutStdErrHandler(session, true);
StdoutStdErrHandler stderrh = new StdoutStdErrHandler(session, false);
stdouth.start();
stderrh.start();
boolean isFile = false;
try
{
// make sure we hang around for stdout
while(stdouth.isAlive() || stderrh.isAlive())
Thread.currentThread().sleep(10);
}
catch(InterruptedException ie)
{
ie.printStackTrace();
}
if(System.getProperty("debug") != null)
{
// stdout & stderr
System.out.println(stdouth.getOutput());
System.out.println(stderrh.getOutput());
}
// ByteArrayOutputStream os = new ByteArrayOutputStream();
// sftp.get(outputfile, os);
// System.out.println(os.toString());
try
{
sftp.get(outputfile, filepath+".out");
if(System.getProperty("debug") != null)
System.out.println("GET SUCCESS "+filepath+".out");
}
catch(Exception ioe)
{
if(System.getProperty("debug") != null)
{
System.out.println("runBlastOrFasta() - 3");
ioe.printStackTrace();
}
rescue();
sftp.get(outputfile, filepath+".out");
}
if(!keep)
{
sftp.rm(outputfile);
sftp.rm(wdir+filename);
session.close();
}
sftp.quit();
return true;
}
/**
*
* Return an active SftpClient object
*
*/
private SftpClient getSftpClient()
throws IOException
{
SftpClient sftp;
try
{
sftp = ssh.getActiveSftpClient();
return sftp;
}
if(System.getProperty("debug") != null)
{
System.out.println("getSftpClient()");
ioe.printStackTrace();
}
/**
*
* Thread to handle stdout/stderr reading without blocking.
*
*/
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
class StdoutStdErrHandler extends Thread
{
private SessionChannelClient session;
private boolean isStdout;
private StringBuffer buff = new StringBuffer();
protected StdoutStdErrHandler(SessionChannelClient session,
boolean isStdout)
{
this.session = session;
this.isStdout = isStdout;
}
public void run()
{
try
{
final InputStream in;
if(isStdout)
in = session.getInputStream();
else
in = session.getStderrInputStream();
byte buffer[] = new byte[100];
int read;
while((read = in.read(buffer)) > 0)
buff.append(new String(buffer, 0, read));
}
catch(IOException ioe){}
}
public String getOutput()
{
return buff.toString();
}
}
/**
* The main program for the PasswordConnect class
*
* @param args The command line arguments
*/
public static void main(String args[])
{
new SshPSUClient(args);
}
}