public class org.glassfish.cluster.ssh.connect.NodeRunnerSsh extends java.lang.Object
{
private static final java.lang.String NL;
private org.glassfish.hk.api.ServiceLocator habitat;
private java.util.logging.Logger logger;
private java.lang.String lastCommandRun;
private int commandStatus;
private org.glassfish.cluster.ssh.launcher.SSHLauncher sshL;
public void <init>(org.glassfish.hk.api.ServiceLocator, java.util.logging.Logger)
{
org.glassfish.hk.api.ServiceLocator v;
java.util.logging.Logger v;
org.glassfish.cluster.ssh.connect.NodeRunnerSsh v;
v := @this: org.glassfish.cluster.ssh.connect.NodeRunnerSsh;
v := @parameter: org.glassfish.hk.api.ServiceLocator;
v := @parameter: java.util.logging.Logger;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.lang.String lastCommandRun> = null;
v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: org.glassfish.cluster.ssh.launcher.SSHLauncher sshL> = null;
v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.util.logging.Logger logger> = v;
v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: org.glassfish.hk.api.ServiceLocator habitat> = v;
return;
}
public boolean isSshNode(com.sun.enterprise.config.serverbeans.Node)
{
java.lang.String v, v;
java.lang.IllegalArgumentException v;
com.sun.enterprise.config.serverbeans.Node v;
boolean v;
org.glassfish.cluster.ssh.connect.NodeRunnerSsh v;
v := @this: org.glassfish.cluster.ssh.connect.NodeRunnerSsh;
v := @parameter: com.sun.enterprise.config.serverbeans.Node;
if v != null goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Node is null");
throw v;
label:
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Node: java.lang.String getType()>();
if v != null goto label;
return 0;
label:
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Node: java.lang.String getType()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("SSH");
return v;
}
java.lang.String getLastCommandRun()
{
java.lang.String v;
org.glassfish.cluster.ssh.connect.NodeRunnerSsh v;
v := @this: org.glassfish.cluster.ssh.connect.NodeRunnerSsh;
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.lang.String lastCommandRun>;
return v;
}
public int runAdminCommandOnRemoteNode(com.sun.enterprise.config.serverbeans.Node, java.lang.StringBuilder, java.util.List, java.util.List) throws org.glassfish.api.admin.SSHCommandExecutionException, java.lang.IllegalArgumentException, java.lang.UnsupportedOperationException
{
com.sun.enterprise.config.serverbeans.Node v;
boolean v, v;
java.util.logging.Logger v, v, v;
java.util.List v, v;
java.lang.StringBuilder v;
org.glassfish.hk.api.ServiceLocator v;
java.lang.Throwable v, v, v;
java.io.ByteArrayOutputStream v;
java.lang.String[] v, v;
java.lang.'annotation'.Annotation[] v;
java.util.ArrayList v;
int v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.glassfish.cluster.ssh.connect.NodeRunnerSsh v;
java.lang.UnsupportedOperationException v;
java.lang.IllegalArgumentException v;
org.glassfish.api.admin.SSHCommandExecutionException v, v;
java.lang.InterruptedException v;
org.glassfish.cluster.ssh.launcher.SSHLauncher v, v, v, v;
java.lang.Object v;
v := @this: org.glassfish.cluster.ssh.connect.NodeRunnerSsh;
v := @parameter: com.sun.enterprise.config.serverbeans.Node;
v := @parameter: java.lang.StringBuilder;
v := @parameter: java.util.List;
v := @parameter: java.util.List;
interfaceinvoke v.<java.util.List: void add(int,java.lang.Object)>(0, "--_auxinput");
interfaceinvoke v.<java.util.List: void add(int,java.lang.Object)>(1, "-");
v = virtualinvoke v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: boolean isSshNode(com.sun.enterprise.config.serverbeans.Node)>(v);
if v != 0 goto label;
v = new java.lang.UnsupportedOperationException;
specialinvoke v.<java.lang.UnsupportedOperationException: void <init>(java.lang.String)>("Node is not of type SSH");
throw v;
label:
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Node: java.lang.String getInstallDirUnixStyle()>();
v = staticinvoke <com.sun.enterprise.util.SystemPropertyConstants: java.lang.String getComponentName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u0001/\u0001");
v = staticinvoke <com.sun.enterprise.util.StringUtils: boolean ok(java.lang.String)>(v);
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Node does not have an installDir");
throw v;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u0001/lib/nadmin");
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
interfaceinvoke v.<java.util.List: boolean addAll(java.util.Collection)>(v);
label:
v = specialinvoke v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.lang.String commandListToString(java.util.List)>(v);
v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.lang.String lastCommandRun> = v;
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Node: java.lang.String getNodeHost()>();
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.lang.String lastCommandRun>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Running command on \u0001: \u0001");
specialinvoke v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: void trace(java.lang.String)>(v);
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: org.glassfish.hk.api.ServiceLocator habitat>;
v = newarray (java.lang.'annotation'.Annotation)[0];
v = interfaceinvoke v.<org.glassfish.hk.api.ServiceLocator: java.lang.Object getService(java.lang.Class,java.lang.'annotation'.Annotation[])>(class "Lorg/glassfish/cluster/ssh/launcher/SSHLauncher;", v);
v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: org.glassfish.cluster.ssh.launcher.SSHLauncher sshL> = v;
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: org.glassfish.cluster.ssh.launcher.SSHLauncher sshL>;
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.util.logging.Logger logger>;
virtualinvoke v.<org.glassfish.cluster.ssh.launcher.SSHLauncher: void init(com.sun.enterprise.config.serverbeans.Node,java.util.logging.Logger)>(v, v);
v = new java.io.ByteArrayOutputStream;
specialinvoke v.<java.io.ByteArrayOutputStream: void <init>()>();
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: org.glassfish.cluster.ssh.launcher.SSHLauncher sshL>;
v = virtualinvoke v.<org.glassfish.cluster.ssh.launcher.SSHLauncher: int runCommand(java.util.List,java.io.OutputStream,java.util.List)>(v, v, v);
v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: int commandStatus> = v;
v = virtualinvoke v.<java.io.ByteArrayOutputStream: java.lang.String toString()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: int commandStatus>;
label:
return v;
label:
v := @caughtexception;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>(" Command execution failed. \u0001");
v = "";
v = virtualinvoke v.<java.lang.Exception: java.lang.Throwable getCause()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
label:
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.util.logging.Logger logger>;
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.lang.String lastCommandRun>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Command execution failed for \u0001");
virtualinvoke v.<java.util.logging.Logger: void severe(java.lang.String)>(v);
v = new org.glassfish.api.admin.SSHCommandExecutionException;
v = newarray (java.lang.String)[2];
v[0] = v;
v[1] = v;
v = staticinvoke <com.sun.enterprise.util.StringUtils: java.lang.String cat(java.lang.String,java.lang.String[])>(":", v);
specialinvoke v.<org.glassfish.api.admin.SSHCommandExecutionException: void <init>(java.lang.String)>(v);
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: org.glassfish.cluster.ssh.launcher.SSHLauncher sshL>;
v = virtualinvoke v.<org.glassfish.cluster.ssh.launcher.SSHLauncher: java.lang.String toString()>();
virtualinvoke v.<org.glassfish.api.admin.SSHCommandExecutionException: void setSSHSettings(java.lang.String)>(v);
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.lang.String lastCommandRun>;
virtualinvoke v.<org.glassfish.api.admin.SSHCommandExecutionException: void setCommandRun(java.lang.String)>(v);
throw v;
label:
v := @caughtexception;
virtualinvoke v.<java.lang.InterruptedException: void printStackTrace()>();
v = virtualinvoke v.<java.lang.InterruptedException: java.lang.String getMessage()>();
v = "";
v = virtualinvoke v.<java.lang.InterruptedException: java.lang.Throwable getCause()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
label:
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.util.logging.Logger logger>;
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.lang.String lastCommandRun>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Command interrupted \u0001");
virtualinvoke v.<java.util.logging.Logger: void severe(java.lang.String)>(v);
v = new org.glassfish.api.admin.SSHCommandExecutionException;
v = newarray (java.lang.String)[2];
v[0] = v;
v[1] = v;
v = staticinvoke <com.sun.enterprise.util.StringUtils: java.lang.String cat(java.lang.String,java.lang.String[])>(":", v);
specialinvoke v.<org.glassfish.api.admin.SSHCommandExecutionException: void <init>(java.lang.String)>(v);
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: org.glassfish.cluster.ssh.launcher.SSHLauncher sshL>;
v = virtualinvoke v.<org.glassfish.cluster.ssh.launcher.SSHLauncher: java.lang.String toString()>();
virtualinvoke v.<org.glassfish.api.admin.SSHCommandExecutionException: void setSSHSettings(java.lang.String)>(v);
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.lang.String lastCommandRun>;
virtualinvoke v.<org.glassfish.api.admin.SSHCommandExecutionException: void setCommandRun(java.lang.String)>(v);
throw v;
catch com.jcraft.jsch.JSchException from label to label with label;
catch java.io.IOException from label to label with label;
catch java.lang.InterruptedException from label to label with label;
}
private void trace(java.lang.String)
{
java.lang.Object[] v;
java.lang.Class v;
java.lang.String v, v, v;
java.util.logging.Logger v;
org.glassfish.cluster.ssh.connect.NodeRunnerSsh v;
v := @this: org.glassfish.cluster.ssh.connect.NodeRunnerSsh;
v := @parameter: java.lang.String;
v = v.<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.util.logging.Logger logger>;
v = newarray (java.lang.Object)[2];
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("%s: %s", v);
virtualinvoke v.<java.util.logging.Logger: void fine(java.lang.String)>(v);
return;
}
private java.lang.String commandListToString(java.util.List)
{
java.util.List v;
java.util.Iterator v;
java.lang.Object v;
java.lang.StringBuilder v;
java.lang.String v;
boolean v;
org.glassfish.cluster.ssh.connect.NodeRunnerSsh v;
v := @this: org.glassfish.cluster.ssh.connect.NodeRunnerSsh;
v := @parameter: java.util.List;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(" ");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
goto label;
label:
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
return v;
}
static void <clinit>()
{
java.lang.String v;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("line.separator");
<org.glassfish.cluster.ssh.connect.NodeRunnerSsh: java.lang.String NL> = v;
return;
}
}