summaryrefslogtreecommitdiffstats
path: root/src/main/java/org/openslx/taskmanager/tasks/RemoteExec.java
diff options
context:
space:
mode:
authorUdo Walter2021-03-10 00:22:27 +0100
committerUdo Walter2021-03-10 00:22:27 +0100
commit4c01065a751030d078b802934bca3b16c1d7441c (patch)
treeee34ed57c3551636488a3b12c2d7133fd61ddbed /src/main/java/org/openslx/taskmanager/tasks/RemoteExec.java
parent[MountVmStore] Better handling of concurrent invocations (diff)
downloadtmlite-bwlp-4c01065a751030d078b802934bca3b16c1d7441c.tar.gz
tmlite-bwlp-4c01065a751030d078b802934bca3b16c1d7441c.tar.xz
tmlite-bwlp-4c01065a751030d078b802934bca3b16c1d7441c.zip
[RemoteExec/RemoteReboot] convert ssh key to a format supported by JSch
Diffstat (limited to 'src/main/java/org/openslx/taskmanager/tasks/RemoteExec.java')
-rw-r--r--src/main/java/org/openslx/taskmanager/tasks/RemoteExec.java13
1 files changed, 13 insertions, 0 deletions
diff --git a/src/main/java/org/openslx/taskmanager/tasks/RemoteExec.java b/src/main/java/org/openslx/taskmanager/tasks/RemoteExec.java
index 3bd0954..8e88599 100644
--- a/src/main/java/org/openslx/taskmanager/tasks/RemoteExec.java
+++ b/src/main/java/org/openslx/taskmanager/tasks/RemoteExec.java
@@ -9,6 +9,10 @@ import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
+import com.sshtools.common.publickey.InvalidPassphraseException;
+import com.sshtools.common.publickey.SshKeyUtils;
+import com.sshtools.common.publickey.bc.OpenSSHPrivateKeyFileBC;
+import com.sshtools.common.ssh.components.SshKeyPair;
import org.openslx.satserver.util.Util;
import org.openslx.taskmanager.api.AbstractTask;
@@ -77,6 +81,15 @@ public class RemoteExec extends AbstractTask
if ( status.error != null )
return false;
+ // Convert ssh key to old rsa format supported by JSch
+ try {
+ SshKeyPair key = SshKeyUtils.getPrivateKey(sshkey, "");
+ sshkey = new String(new OpenSSHPrivateKeyFileBC(key, "").getFormattedKey(),
+ StandardCharsets.UTF_8);
+ } catch (IOException | InvalidPassphraseException e) {
+ e.printStackTrace();
+ }
+
JSch.setConfig( "StrictHostKeyChecking", "no" );
sshClient = new JSch();
try {