All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.danielflower.mavenplugins.release.SshAgentSessionFactory Maven / Gradle / Ivy

Go to download

A maven release plugin built for multi-maven-module git repositories allowing continuous deployment

The newest version!
package com.github.danielflower.mavenplugins.release;

import com.jcraft.jsch.*;
import com.jcraft.jsch.agentproxy.AgentProxyException;
import com.jcraft.jsch.agentproxy.Connector;
import com.jcraft.jsch.agentproxy.RemoteIdentityRepository;
import com.jcraft.jsch.agentproxy.USocketFactory;
import com.jcraft.jsch.agentproxy.connector.SSHAgentConnector;
import com.jcraft.jsch.agentproxy.usocket.NCUSocketFactory;
import org.apache.maven.plugin.logging.Log;
import org.eclipse.jgit.transport.JschConfigSessionFactory;
import org.eclipse.jgit.transport.OpenSshConfig;
import org.eclipse.jgit.util.FS;

import static java.lang.String.format;

/**
 * SSH-Agent enabler.
 *
 * A JschConfigSessionFactory which sets the Preferred authentication method to
 * Publickey, and tries to use a NetCat Socket Factory to reach a ssh-agent
 * process via it's Unix Socket as identified by environment var SSH_AUTH_SOCK.
 *
 * Note that this requires the 'nc' binary installed and available on PATH!
 *
 * @author Johan Ström [email protected]
 */
public class SshAgentSessionFactory extends JschConfigSessionFactory {
	private final Log log;
	private String knownHostsOrNull;
	private String identityFile;
	private String passphraseOrNull;

	public SshAgentSessionFactory(final Log log, final String knownHostsOrNull, final String identityFile,
			final String passphraseOrNull) {
		this.log = log;
		setKnownHosts(knownHostsOrNull);
		setIdentityFile(identityFile);
		setPassphrase(passphraseOrNull);
	}

	void setKnownHosts(String knownHosts) {
		this.knownHostsOrNull = knownHosts;
	}

	void setIdentityFile(String identityFile) {
		this.identityFile = identityFile;
	}

	void setPassphrase(String passphrase) {
		this.passphraseOrNull = passphrase;
	}

	String getKnownHostsOrNull() {
		return knownHostsOrNull;
	}

	String getIdentityFile() {
		return identityFile;
	}

	String getPassphraseOrNull() {
		return passphraseOrNull;
	}

	@Override
	protected void configure(final OpenSshConfig.Host host, final Session sn) {
	}

	@Override
	protected JSch createDefaultJSch(final FS fs) throws JSchException {
		Connector con = null;
		try {
			// TODO: add support for others as well, such as page-ant.
			if (SSHAgentConnector.isConnectorAvailable()) {
				final USocketFactory usf = new NCUSocketFactory();
				con = new SSHAgentConnector(usf);
			}
		} catch (final AgentProxyException e) {
			log.warn("Failed to connect to SSH-agent", e);
		}

		final JSch jsch = super.createDefaultJSch(fs);
		if (con != null) {
			JSch.setConfig("PreferredAuthentications", "publickey");

			final IdentityRepository identityRepository = new RemoteIdentityRepository(con);
			jsch.setIdentityRepository(identityRepository);

			log.debug(format("Jsch configured to use %s", con.getName()));
		}

		if (knownHostsOrNull != null) {
			jsch.setKnownHosts(knownHostsOrNull);
			log.debug(format("Jsch configured to use known hostfile %s", knownHostsOrNull));
		}

		if (identityFile != null) {
			jsch.addIdentity(identityFile, passphraseOrNull);
			log.debug(format("Jsch configured to use identity file %s", identityFile));
		}
		JSch.setLogger(new Logger() {
            @Override
            public boolean isEnabled(int level) {
                switch (level) {
                    case Logger.DEBUG:
                        return log.isDebugEnabled();
                    case Logger.INFO:
                        return log.isInfoEnabled();
                    case Logger.WARN:
                        return log.isWarnEnabled();
                    case Logger.FATAL:
                    case Logger.ERROR:
                        return log.isErrorEnabled();
                }
                return false;
            }

            @Override
            public void log(int level, String message) {
                switch (level) {
                    case Logger.WARN:
                        log.warn(message);
                        break;
                    case Logger.FATAL:
                    case Logger.ERROR:
                        log.error(message);
                        break;
                    case Logger.INFO: // send to debug as it is so verbose
                    case Logger.DEBUG:
                    default:
                        log.debug(message);
                        break;
                }
            }
        });

		return jsch;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy