[ http://issues.apache.org/jira/browse/VFS-93?page=all ]
Mario Ivankovits resolved VFS-93.
---------------------------------
Resolution: Fixed
Fixed!
Thanks for pointint it out.
Next time please send a "svn diff", this makes it much easier for me to handle.
Thanks!
> Problem with default password field null when SFTPClientFactory creates a
> connection
> ------------------------------------------------------------------------------------
>
> Key: VFS-93
> URL: http://issues.apache.org/jira/browse/VFS-93
> Project: Commons VFS
> Issue Type: Bug
> Environment: /commons-vfs-1.0-RC8-SNAPSHOT
> Reporter: nitin
> Priority: Minor
> Attachments: SftpClientFactory.java
>
>
> While creating a connection it fails as null pointer exception as password is
> not set.
> I have changed the file SFTPClientFactory and attached here with for patch.
> See comment beginning with "FIX".
> /*
> * Copyright 2002-2005 The Apache Software Foundation.
> *
> * Licensed under the Apache License, Version 2.0 (the "License");
> * you may not use this file except in compliance with the License.
> * You may obtain a copy of the License at
> *
> * http://www.apache.org/licenses/LICENSE-2.0
> *
> * Unless required by applicable law or agreed to in writing, software
> * distributed under the License is distributed on an "AS IS" BASIS,
> * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
> * See the License for the specific language governing permissions and
> * limitations under the License.
> */
> package org.apache.commons.vfs.provider.sftp;
> import com.jcraft.jsch.JSch;
> import com.jcraft.jsch.JSchException;
> import com.jcraft.jsch.Session;
> import com.jcraft.jsch.UserInfo;
> import com.jcraft.jsch.Proxy;
> import com.jcraft.jsch.ProxyHTTP;
> import com.jcraft.jsch.ProxySOCKS5;
> import org.apache.commons.vfs.FileSystemException;
> import org.apache.commons.vfs.FileSystemOptions;
> import org.apache.commons.vfs.util.Os;
> import java.io.File;
> import java.util.Properties;
> /**
> * Create a HttpClient instance
> *
> * @author <a href="mailto:[EMAIL PROTECTED]">Mario Ivankovits</a>
> * @version $Revision: 452591 $ $Date: 2006-10-04 04:25:24 +1000 (Wed, 04 Oct
> 2006) $
> */
> public class SftpClientFactory
> {
> private static final String SSH_DIR_NAME = ".ssh";
> private SftpClientFactory()
> {
> }
> /**
> * Creates a new connection to the server.
> */
> public static Session createConnection(String hostname, int port, char[]
> username, char[] password, FileSystemOptions fileSystemOptions) throws
> FileSystemException
> {
> JSch jsch = new JSch();
> File sshDir = null;
> // new style - user passed
> File knownHostsFile =
> SftpFileSystemConfigBuilder.getInstance().getKnownHosts(fileSystemOptions);
> File[] identities =
> SftpFileSystemConfigBuilder.getInstance().getIdentities(fileSystemOptions);
> if (knownHostsFile != null)
> {
> try
> {
> jsch.setKnownHosts(knownHostsFile.getAbsolutePath());
> }
> catch (JSchException e)
> {
> throw new
> FileSystemException("vfs.provider.sftp/known-hosts.error",
> knownHostsFile.getAbsolutePath(), e);
> }
> }
> else
> {
> if (sshDir == null)
> {
> sshDir = findSshDir();
> }
> // Load the known hosts file
> knownHostsFile = new File(sshDir, "known_hosts");
> if (knownHostsFile.isFile() && knownHostsFile.canRead())
> {
> try
> {
> jsch.setKnownHosts(knownHostsFile.getAbsolutePath());
> }
> catch (JSchException e)
> {
> throw new
> FileSystemException("vfs.provider.sftp/known-hosts.error",
> knownHostsFile.getAbsolutePath(), e);
> }
> }
> }
> if (identities != null)
> {
> for (int iterIdentities = 0; iterIdentities < identities.length;
> iterIdentities++)
> {
> final File privateKeyFile = identities[iterIdentities];
> try
> {
> jsch.addIdentity(privateKeyFile.getAbsolutePath());
> }
> catch (final JSchException e)
> {
> throw new
> FileSystemException("vfs.provider.sftp/load-private-key.error",
> privateKeyFile, e);
> }
> }
> }
> else
> {
> if (sshDir == null)
> {
> sshDir = findSshDir();
> }
> // Load the private key (rsa-key only)
> final File privateKeyFile = new File(sshDir, "id_rsa");
> if (privateKeyFile.isFile() && privateKeyFile.canRead())
> {
> try
> {
> jsch.addIdentity(privateKeyFile.getAbsolutePath());
> }
> catch (final JSchException e)
> {
> throw new
> FileSystemException("vfs.provider.sftp/load-private-key.error",
> privateKeyFile, e);
> }
> }
> }
> Session session;
> try
> {
> session = jsch.getSession(new String(username),
> hostname,
> port);
> //FIX: to check for password.
> if(password != null){
> session.setPassword(new String(password));
> }
> Integer timeout =
> SftpFileSystemConfigBuilder.getInstance().getTimeout(fileSystemOptions);
> if (timeout != null)
> {
> session.setTimeout(timeout.intValue());
> }
>
> UserInfo userInfo =
> SftpFileSystemConfigBuilder.getInstance().getUserInfo(fileSystemOptions);
> if (userInfo != null)
> {
> session.setUserInfo(userInfo);
> }
> Properties config = new Properties();
> //set StrictHostKeyChecking property
> String strictHostKeyChecking =
> SftpFileSystemConfigBuilder.getInstance().getStrictHostKeyChecking(fileSystemOptions);
> if (strictHostKeyChecking != null)
> {
> config.setProperty("StrictHostKeyChecking",
> strictHostKeyChecking);
> }
> //set compression property
> String compression =
> SftpFileSystemConfigBuilder.getInstance().getCompression(fileSystemOptions);
> if (compression != null)
> {
> config.setProperty("compression.s2c", compression);
> config.setProperty("compression.c2s", compression);
> }
> String proxyHost =
> SftpFileSystemConfigBuilder.getInstance().getProxyHost(fileSystemOptions);
> if (proxyHost != null)
> {
> int proxyPort =
> SftpFileSystemConfigBuilder.getInstance().getProxyPort(fileSystemOptions);
> SftpFileSystemConfigBuilder.ProxyType proxyType =
> SftpFileSystemConfigBuilder.getInstance().getProxyType(fileSystemOptions);
> Proxy proxy = null;
> if (SftpFileSystemConfigBuilder.PROXY_HTTP.equals(proxyType))
> {
> if (proxyPort != 0)
> {
> proxy = new ProxyHTTP(proxyHost, proxyPort);
> }
> else
> {
> proxy = new ProxyHTTP(proxyHost);
> }
> }
> else if
> (SftpFileSystemConfigBuilder.PROXY_SOCKS5.equals(proxyType))
> {
> if (proxyPort != 0)
> {
> proxy = new ProxySOCKS5(proxyHost, proxyPort);
> }
> else
> {
> proxy = new ProxySOCKS5(proxyHost);
> }
> }
> if (proxy != null)
> {
> session.setProxy(proxy);
> }
> }
> //set properties for the session
> if (config.size() > 0)
> {
> session.setConfig(config);
> }
> session.connect();
> }
> catch (final Exception exc)
> {
> throw new FileSystemException("vfs.provider.sftp/connect.error",
> new Object[]{hostname}, exc);
> }
> return session;
> }
> /**
> * Finds the .ssh directory.
> * <p>The lookup order is:</p>
> * <ol>
> * <li>The system property <code>vfs.sftp.sshdir</code> (the override
> * mechanism)</li>
> * <li><code>{user.home}/.ssh</code></li>
> * <li>On Windows only: C:\cygwin\home\{user.name}\.ssh</li>
> * <li>The current directory, as a last resort.</li>
> * <ol>
> * <p/>
> * Windows Notes:
> * The default installation directory for Cygwin is
> <code>C:\cygwin</code>.
> * On my set up (Gary here), I have Cygwin in C:\bin\cygwin, not the
> default.
> * Also, my .ssh directory was created in the {user.home} directory.
> * </p>
> *
> * @return The .ssh directory
> */
> private static File findSshDir()
> {
> String sshDirPath;
> sshDirPath = System.getProperty("vfs.sftp.sshdir");
> if (sshDirPath != null)
> {
> File sshDir = new File(sshDirPath);
> if (sshDir.exists())
> {
> return sshDir;
> }
> }
> File sshDir = new File(System.getProperty("user.home"), SSH_DIR_NAME);
> if (sshDir.exists())
> {
> return sshDir;
> }
> if (Os.isFamily(Os.OS_FAMILY_WINDOWS))
> {
> // TODO - this may not be true
> final String userName = System.getProperty("user.name");
> sshDir = new File("C:\\cygwin\\home\\" + userName + "\\" +
> SSH_DIR_NAME);
> if (sshDir.exists())
> {
> return sshDir;
> }
> }
> return new File("");
> }
> }
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
http://issues.apache.org/jira/secure/Administrators.jspa
-
For more information on JIRA, see: http://www.atlassian.com/software/jira
---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]