Package com.antimatterstudios.esftp

Source Code of com.antimatterstudios.esftp.TransferSSHTools$ESFTPMonitor

/*******************************************************************************
* Copyright (c) {06/11/2005} {Christopher Thomas}
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
*
* Contributors:
*    {Christopher Thomas} - initial API and implementation
*    chris.alex.thomas@gmail.com
*******************************************************************************/

package com.antimatterstudios.esftp;

import com.sshtools.j2ssh.SshClient;
import com.sshtools.j2ssh.authentication.*;
import com.sshtools.j2ssh.sftp.FileAttributes;
import com.sshtools.j2ssh.sftp.SftpFile;
import com.sshtools.j2ssh.TransferCancelledException;
import com.sshtools.j2ssh.SftpClient;
import com.sshtools.j2ssh.FileTransferProgress;
import com.sshtools.j2ssh.configuration.ConfigurationLoader;
import com.sshtools.j2ssh.transport.IgnoreHostKeyVerification;

import java.io.*;
import java.util.*;

import com.antimatterstudios.esftp.directory.FileList;
import com.antimatterstudios.esftp.ui.ConsoleDisplayMgr;

public class TransferSSHTools extends Transfer
{
  private ESFTPMonitor m_monitor;
 
  /**  Transfer monitor to watch the progress of files
   *
   * @author Chris
   *
   */
  private class ESFTPMonitor implements FileTransferProgress{
    protected Transfer m_transfer;
    protected long m_count;
    protected long m_pt;
    protected boolean m_cancel;
   
    public ESFTPMonitor(Transfer t){
      //System.out.println("TRACE-> TransferMonitor::TransferMonitor()");
      m_transfer = t;
      m_cancel = false;
    }
   
    public void setCancelled(){
      m_cancel = true;
    }

      public void started(long bytesTotal, String remoteFile){
        //System.out.println("TRACE-> TransferMonitor::started("+remoteFile+", "+bytesTotal+")");
      m_count = 0;
      m_pt = System.currentTimeMillis();
      }

      public boolean isCancelled(){
        //System.out.println("TRACE-> Monitor::isCancelled()");
        return m_cancel;
      }

      public void progressed(long current){
        System.out.println("Monitor::progressed("+current+")");
        long diff = current - m_count;
        m_count = current;
     
      long ct = System.currentTimeMillis();
      long dt = ct - m_pt;
      m_pt = ct;
     
      long bytesPerSec = (long)(diff * (1000.0/(double)dt));

      m_transfer.update(bytesPerSec,diff);
      }

      public void completed(){
        //System.out.println("TRACE-> Monitor::completed()");
      }
  }
  /*************************************/
  /**  End of TransferMonitor class **/
  /*************************************/
 
  protected SshClient m_ssh;
  protected SftpClient m_sftp;
 
  protected void createRemoteDirectory(String dir) {
    System.out.println("TransferSSHTools::createRemoteDirectory("+dir+")");
   
    String status = FileList.MSG_FAILED;
   
    try{
      dir = m_details.getSiteRoot()+dir;
     
      String testDir = "";
      String tokens[] = dir.split("/");
      for(int a=0;a<tokens.length;a++){
        System.out.println("Token: "+tokens[a]);
        testDir+=tokens[a]+"/";
       
        try{
          FileAttributes attrib = m_sftp.stat(testDir);
         
          //  If these match, it's because this was the directory you TRIED to create
          //  You can't set the status of this if it was the parent directories, because you have
          //  to create the parent directories automatically for the user (because sometimes the site root doesnt exist)
          if(testDir == dir){
            status = (attrib.isDirectory() == true) ? FileList.MSG_DEXIST : FileList.MSG_FEXIST;
          }
        }catch(IOException ioe){
          //  If the item doesnt exist, create a directory with the same name
          status = FileList.MSG_OK;
          try{
            System.out.println("Attempt to create remote directory: '"+testDir+"'");
            m_sftp.mkdir(testDir);
          }catch(IOException mk){
            System.out.println(m_errorPrefix+mk.getMessage() +": "+mk.getCause());
            status = FileList.MSG_DEXIST;
          }
        }
      } 
    }catch(Exception e){
      Activator.consolePrintln("EXCEPTION: There was a problem creating the directory: "+dir, ConsoleDisplayMgr.MSG_ERROR);
      Activator.consolePrintln("EXCEPTION INFO: "+e.getMessage(),ConsoleDisplayMgr.MSG_ERROR);
    }
   
    m_fileList.setStatus(m_count, status);
  }
 
  protected boolean attemptPasswordAuthentication(String username, String password)
  {
    int result = 0;
    Activator.consolePrintln("Attempting Password Authentication",ConsoleDisplayMgr.MSG_INFORMATION);
   
    // Create a password authentication instance
    PasswordAuthenticationClient pwd = new PasswordAuthenticationClient();
    // Set the users name
    pwd.setUsername(m_details.getUsername());
    // Set the password
    pwd.setPassword(m_details.getPassword());

    // Try the authentication
    result = AuthenticationProtocolState.FAILED;
    try{
      System.out.println("Authenticating now");
      result = m_ssh.authenticate(pwd);
    }catch(IOException e){
      Activator.consolePrintln("FAILED TO AUTHENTICATE",ConsoleDisplayMgr.MSG_INFORMATION);
      setTask(TASK_ERROR,new String[]{m_errorPrefix+"auth: "+e.getMessage() });
    }

    if (result == AuthenticationProtocolState.COMPLETE) return true;
   
    System.out.println("Failed to login using PasswordAuthentication");
    return false;
  }
 
  protected boolean attemptKeyboardAuthentication(String username, String password)
  {
    int result = 0;
    Activator.consolePrintln("Attempting Keyboard Authentication",ConsoleDisplayMgr.MSG_INFORMATION);
   
    KBIAuthenticationClient kbi = new KBIAuthenticationClient();
        kbi.setUsername(username);
       
        final String PASSWORD = password;

        // callback interface
    kbi.setKBIRequestHandler(new KBIRequestHandler() {
      public void showPrompts(String name, String instructions, KBIPrompt[] prompts) {
        System.out.println(name);
        System.out.println(instructions);
        String response = PASSWORD;

        if(prompts!=null) {
          for(int i=0;i<prompts.length;i++) {
            String p = prompts[i].getPrompt().toLowerCase();
            if(p.startsWith("password:")){
              response = PASSWORD;
            }else{
              response = "KBI_TEST_VALUE_ESFTP_SETS_THIS_TO_FAIL";
            }
            System.out.println(p + response);           
            prompts[i].setResponse(response);           
          }
        }else Activator.consolePrintln("THERE ARE NO KBI PROMPTS",ConsoleDisplayMgr.MSG_INFORMATION);
      }
    });
 
        try{
      result = m_ssh.authenticate(kbi);
    }catch(IOException e){
      setTask(TASK_ERROR,new String[]{m_errorPrefix+"auth: "+e.getMessage() });
      System.out.println("Caught exception whilst authenticating");
    }

    if (result == AuthenticationProtocolState.COMPLETE) return true;
   
    System.out.println("Failed to login using KeyboardAuthentication");     
    return false;
  }
 
  protected boolean attemptHostAuthentication()
  {
    System.out.println("Failed to login using HostAuthentication");
    return false;
  }
 
  protected boolean attemptPublicKeyAuthentication()
  {
    System.out.println("Failed to login using PublicKeyAuthentication");
    return false;
  }
 
  public TransferSSHTools(){
    m_errorPrefix = "ERROR: SSHTools: ";
  }

  public boolean open() {
    m_open = false;
   
    // Immediately lock the Transfer object
    if (m_locked == false) {
      m_locked = true;

      // Debug information
      m_details.debug();

      // TODO: Find out what this does before re-enabling it
      try{
        ConfigurationLoader.initialize(false);
      }catch(IOException e){
        setTask(TASK_ERROR,new String[] {m_errorPrefix+"configuration: "+e.getMessage() });
      }
      m_ssh = new SshClient();

      try{
        m_ssh.setSocketTimeout(m_details.getTimeout()*1000);
        m_ssh.connect(
            m_details.getServer(),
            m_details.getPort(),
            new IgnoreHostKeyVerification());
       
        Activator.consolePrintln("Connected to the remote server", ConsoleDisplayMgr.MSG_INFORMATION);
      }catch(IOException e){
        Activator.consolePrintln(m_errorPrefix+"Connection Error", ConsoleDisplayMgr.MSG_ERROR);
        setTask(TASK_ERROR,new String[]{m_errorPrefix+"connect: "+e.getMessage() });
        m_locked = false;
        return m_open;
      }
     
      boolean attempt = false;
     
      //  Try all these methods of authentication
      if(!attemptattempt =  attemptPasswordAuthentication(m_details.getUsername(),m_details.getPassword());
      if(!attemptattempt =  attemptKeyboardAuthentication(m_details.getUsername(),m_details.getPassword());
      if(!attemptattempt =  attemptHostAuthentication();
      if(!attemptattempt =  attemptPublicKeyAuthentication();
     
      if(!attempt){
        setTask(TASK_ERROR,new String[] {
            m_errorPrefix+"Failed to open SFTP Site",
            "Authentication error: Check username and password" });
      }else{
        try{
          m_sftp = m_ssh.openSftpClient();
          m_open = true;
        }catch(IOException e){
          setTask(TASK_ERROR,new String[]{m_errorPrefix+"openSftpClient: "+e.getMessage() });
        }
      }
    }
   
    return m_open;
  }
 
  public void close() {
    if(m_ssh != null && m_sftp != null){
      try{
        m_sftp.quit();
        m_sftp = null;
       
        m_ssh.disconnect();
        m_ssh = null;
      }catch(IOException e){
        setTask(TASK_ERROR, new String[]{m_errorPrefix+"Failed to disconnect properly"});
      }
    }
  }

  public void createMonitor() {
    m_monitor = new ESFTPMonitor(this);
  }

  public void transfer(String dir, String item) throws Exception {
    //  Transfer the item according to the mode
   
    String src,dst;
   
    try{
      if(m_fileList.getMode() == TransferDetails.GET){
        src = m_details.getLocalRoot()+dir+item;
        dst = m_details.getSiteRoot()+dir+item;
       
        m_sftp.get(src,dst, m_monitor);
      }else{
        src = m_details.getLocalRoot()+dir+item;
        dst = m_details.getSiteRoot()+dir+item;
       
        m_sftp.put(src,dst,m_monitor);
      }
    }catch(TransferCancelledException e){
      //System.out.println("transfer cancelled: file doesnt exist to transfer");
      m_fileList.setStatus(m_count, FileList.MSG_FNOTEXIST);
      Activator.consolePrintln("EXCEPTION: File does not exist: "+dir+item, ConsoleDisplayMgr.MSG_ERROR);
    }
  }
 
  public void cancelTransfer(){
    m_monitor.setCancelled();
  }
/*
  public boolean setDirectories() {
    boolean success = false;
    try{
      m_sftp.lcd(m_details.getLocalRoot());
     
      //  Make sure the site root exists, if not, try to create it
      try{
        /*  We don't use the return FileAttributes since all we want to know, is whether
         * the item exists, if it does, try to cd to it, if it's a file, it'll except and we'll
         * return false anyway, if it succeeds, it'll return true.
         *
         *  if this excepts, it's cause the item doesnt exist, try to create it.
         *  if creation excepts itself, it'll get caught by the outside hanlder
         *  and false will return anyway
         *
        m_sftp.stat(m_details.getSiteRoot());
      }catch(IOException nodir){
        //  If this fails, it'll all fail, so return false so the transfer can't complete
        m_sftp.mkdir(m_details.getSiteRoot());
      }
     
      m_sftp.cd(m_details.getSiteRoot());
      success = true;
    }catch(IOException e){
      System.out.println(m_errorPrefix+e.getMessage());
    }catch(NullPointerException e){
      System.out.println(m_errorPrefix+": NullPointerException");
    }
   
    return success;
  }*/
 
  public boolean list(String directory, Vector files, Vector folders){
    //m_output.println("TransferSSHTools::getDirectoryList(): "+directory);
   
    //  Is the connection open?
    if(m_open == true){
      try{       
        //  Grab the contents of this directory
        List contents = m_sftp.ls(directory);
       
        //  Loop through all the returned values
        Iterator i = contents.iterator();
       
        while(i.hasNext()){
          SftpFile entry = (SftpFile)i.next();
         
          //  Ignores anything with a . or .. in it
          if(entry.getFilename().endsWith(".")) continue;

          //  Get the attributes for this directory item
          FileAttributes attrib = entry.getAttributes();
         
          //  Is it a directory or file? add it to the appropriate array
          if(attrib.isDirectory() == true && m_details.getRecurse() == true){
            folders.add(directory+entry.getFilename()+"/");
          }else{
            files.add(directory+entry.getFilename());
          }
        }
       
        return true;
      }catch(IOException e){
        //  There was an exception scanning this directory
        //  TODO; This could possibly mean that the remote directory doesnt exist
        System.out.println(m_errorPrefix+e.getMessage()+": "+e.getCause());
      }
    }
   
    return false;
 
 
  public boolean isDirectory(String dir) throws Exception{
    System.out.println("TransferSSHTools::isDirectory(String dir)");
    try{
      //  Stat the requested site root
      FileAttributes attrib = m_sftp.stat(dir);
     
      //  If directory, great, otherwise, show warning
      if(attrib.isDirectory()) return true;
    }catch(IOException e){
      throw new Exception();
    }
   
    return false;
 
 
  public long isFile(String file) throws Exception{
    System.out.println("TransferSSHTools::isFile(String file)");
    long size = -1;
    try{
      //  Stat the requested site root
      FileAttributes attrib = m_sftp.stat(file);
     
      //  If file, great, return it's filesize, otherwise return -1
      //  If doesnt exist, throw exception
      if(attrib.isFile()) size = attrib.getSize().longValue();
    }catch(IOException e){
      throw new Exception();
    }
   
    return size;
  }
 
  protected String getServerId(){
    return m_ssh.getServerId();
  }
}
TOP

Related Classes of com.antimatterstudios.esftp.TransferSSHTools$ESFTPMonitor

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.