use of org.apache.sshd.client.future.ConnectFuture in project camel by apache.
the class SshHelper method sendExecCommand.
public static SshResult sendExecCommand(String command, SshEndpoint endpoint, SshClient client) throws Exception {
SshResult result = null;
SshConfiguration configuration = endpoint.getConfiguration();
if (configuration == null) {
throw new IllegalStateException("Configuration must be set");
}
ConnectFuture connectFuture = client.connect(null, configuration.getHost(), configuration.getPort());
// Wait getTimeout milliseconds for connect operation to complete
connectFuture.await(configuration.getTimeout());
if (!connectFuture.isDone() || !connectFuture.isConnected()) {
final String msg = "Failed to connect to " + configuration.getHost() + ":" + configuration.getPort() + " within timeout " + configuration.getTimeout() + "ms";
LOG.debug(msg);
throw new RuntimeCamelException(msg);
}
LOG.debug("Connected to {}:{}", configuration.getHost(), configuration.getPort());
ClientChannel channel = null;
ClientSession session = null;
try {
AuthFuture authResult;
session = connectFuture.getSession();
KeyPairProvider keyPairProvider;
final String certResource = configuration.getCertResource();
if (certResource != null) {
LOG.debug("Attempting to authenticate using ResourceKey '{}'...", certResource);
keyPairProvider = new ResourceHelperKeyPairProvider(new String[] { certResource }, endpoint.getCamelContext().getClassResolver());
} else {
keyPairProvider = configuration.getKeyPairProvider();
}
if (keyPairProvider != null) {
LOG.debug("Attempting to authenticate username '{}' using Key...", configuration.getUsername());
KeyPair pair = keyPairProvider.loadKey(configuration.getKeyType());
authResult = session.authPublicKey(configuration.getUsername(), pair);
} else {
LOG.debug("Attempting to authenticate username '{}' using Password...", configuration.getUsername());
authResult = session.authPassword(configuration.getUsername(), configuration.getPassword());
}
authResult.await(configuration.getTimeout());
if (!authResult.isDone() || authResult.isFailure()) {
LOG.debug("Failed to authenticate");
throw new RuntimeCamelException("Failed to authenticate username " + configuration.getUsername());
}
channel = session.createChannel(ClientChannel.CHANNEL_EXEC, command);
ByteArrayInputStream in = new ByteArrayInputStream(new byte[] { 0 });
channel.setIn(in);
ByteArrayOutputStream out = new ByteArrayOutputStream();
channel.setOut(out);
ByteArrayOutputStream err = new ByteArrayOutputStream();
channel.setErr(err);
OpenFuture openFuture = channel.open();
openFuture.await(configuration.getTimeout());
if (openFuture.isOpened()) {
channel.waitFor(ClientChannel.CLOSED, 0);
result = new SshResult(command, channel.getExitStatus(), new ByteArrayInputStream(out.toByteArray()), new ByteArrayInputStream(err.toByteArray()));
}
return result;
} finally {
if (channel != null) {
channel.close(true);
}
// need to make sure the session is closed
if (session != null) {
session.close(false);
}
}
}
use of org.apache.sshd.client.future.ConnectFuture in project tesb-studio-se by Talend.
the class RuntimeClient method connectWithRetries.
private static ClientSession connectWithRetries(SshClient client, ClientConfig config) throws Exception, InterruptedException {
ClientSession session = null;
int retries = 0;
do {
try {
ConnectFuture future = client.connect(config.getUser(), config.getHost(), config.getPort());
future.await();
session = future.getSession();
} catch (RuntimeSshException ex) {
if (++retries < 10) {
TimeUnit.SECONDS.sleep(2);
} else {
throw ex;
}
}
} while (session == null);
return session;
}
use of org.apache.sshd.client.future.ConnectFuture in project karaf by apache.
the class ClientMojo method connect.
private ClientSession connect(SshClient client) throws IOException, InterruptedException {
int retries = 0;
ClientSession session = null;
do {
final ConnectFuture future = client.connect(user, host, port);
future.await();
try {
session = future.getSession();
} catch (RuntimeSshException ex) {
if (retries++ < attempts) {
Thread.sleep(TimeUnit.SECONDS.toMillis(delay));
getLog().info("retrying (attempt " + retries + ") ...");
} else {
throw ex;
}
}
} while (session == null);
return session;
}
use of org.apache.sshd.client.future.ConnectFuture in project karaf by apache.
the class SshCommandTestBase method openSshChannel.
private OutputStream openSshChannel(String username, String password, OutputStream... outputs) throws Exception {
client = SshClient.setUpDefaultClient();
client.start();
String sshPort = getSshPort();
ConnectFuture future = client.connect(username, "localhost", Integer.parseInt(sshPort));
future.await();
session = future.getSession();
Set<ClientSessionEvent> ret = EnumSet.of(ClientSessionEvent.WAIT_AUTH);
while (ret.contains(ClientSessionEvent.WAIT_AUTH)) {
session.addPasswordIdentity(password);
session.auth().verify();
ret = session.waitFor(EnumSet.of(ClientSessionEvent.WAIT_AUTH, ClientSessionEvent.CLOSED, ClientSessionEvent.AUTHED), 0);
}
if (ret.contains(ClientSessionEvent.CLOSED)) {
throw new Exception("Could not open SSH channel");
}
channel = session.createChannel("shell");
PipedOutputStream pipe = new PipedOutputStream();
channel.setIn(new PipedInputStream(pipe));
OutputStream out;
if (outputs.length >= 1) {
out = outputs[0];
} else {
out = new ByteArrayOutputStream();
}
channel.setOut(out);
OutputStream err;
if (outputs.length >= 2) {
err = outputs[1];
} else {
err = new ByteArrayOutputStream();
}
channel.setErr(err);
channel.open();
return pipe;
}
Aggregations