public class org.apache.log4j.net.SillySocketClient extends java.lang.Object
{
static org.apache.log4j.Logger LOGGER;
static java.net.InetAddress LOCAL_HOST_ADDRESS;
static java.lang.String LOCALHOST_STR;
static int PORT;
java.io.ObjectOutputStream oos;
public void <init>()
{
org.apache.log4j.net.SillySocketClient v;
v := @this: org.apache.log4j.net.SillySocketClient;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static void main(java.lang.String[]) throws java.io.IOException, java.lang.InterruptedException
{
java.lang.String[] v;
org.apache.log4j.net.BadPayload v;
java.lang.Exception v;
java.net.InetAddress v, v;
org.apache.log4j.Logger v, v;
org.apache.log4j.Level v, v;
int v, v;
org.apache.log4j.net.SillySocketClient v;
java.lang.String v, v;
v := @parameter: java.lang.String[];
staticinvoke <java.lang.System: java.util.Properties getProperties()>();
v = lengthof v;
if v != 1 goto label;
v = v[0];
staticinvoke <org.apache.log4j.net.SillySocketClient: void init(java.lang.String)>(v);
goto label;
label:
staticinvoke <org.apache.log4j.net.SillySocketClient: void usage(java.lang.String)>("Wrong number of arguments.");
return;
label:
v = <org.apache.log4j.net.SillySocketClient: java.lang.String LOCALHOST_STR>;
v = staticinvoke <org.apache.log4j.net.SillySocketClient: java.net.InetAddress getAddressByName(java.lang.String)>(v);
<org.apache.log4j.net.SillySocketClient: java.net.InetAddress LOCAL_HOST_ADDRESS> = v;
v = new org.apache.log4j.net.SillySocketClient;
specialinvoke v.<org.apache.log4j.net.SillySocketClient: void <init>()>();
v = <org.apache.log4j.net.SillySocketClient: java.net.InetAddress LOCAL_HOST_ADDRESS>;
v = <org.apache.log4j.net.SillySocketClient: int PORT>;
virtualinvoke v.<org.apache.log4j.net.SillySocketClient: void connect(java.net.InetAddress,int)>(v, v);
staticinvoke <org.apache.log4j.MDC: void put(java.lang.String,java.lang.Object)>("a", "aValue");
v = <org.apache.log4j.net.SillySocketClient: org.apache.log4j.Logger LOGGER>;
v = <org.apache.log4j.Level: org.apache.log4j.Level INFO>;
specialinvoke v.<org.apache.log4j.net.SillySocketClient: void sendThisEvent(org.apache.log4j.Logger,org.apache.log4j.Level,java.lang.Object,java.lang.Throwable)>(v, v, "hello", null);
v = new java.lang.Exception;
specialinvoke v.<java.lang.Exception: void <init>(java.lang.String)>("testing");
v = <org.apache.log4j.net.SillySocketClient: org.apache.log4j.Logger LOGGER>;
v = <org.apache.log4j.Level: org.apache.log4j.Level INFO>;
v = new org.apache.log4j.net.BadPayload;
specialinvoke v.<org.apache.log4j.net.BadPayload: void <init>(java.lang.String)>("x");
specialinvoke v.<org.apache.log4j.net.SillySocketClient: void sendThisEvent(org.apache.log4j.Logger,org.apache.log4j.Level,java.lang.Object,java.lang.Throwable)>(v, v, v, v);
staticinvoke <java.lang.Thread: void sleep(long)>(200L);
return;
}
private void sendThisEvent(org.apache.log4j.Logger, org.apache.log4j.Level, java.lang.Object, java.lang.Throwable) throws java.io.IOException
{
java.lang.Throwable v;
org.apache.log4j.Logger v;
org.apache.log4j.Level v;
org.apache.log4j.spi.LoggingEvent v;
java.lang.Object v;
org.apache.log4j.net.SillySocketClient v;
v := @this: org.apache.log4j.net.SillySocketClient;
v := @parameter: org.apache.log4j.Logger;
v := @parameter: org.apache.log4j.Level;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.Throwable;
v = staticinvoke <org.apache.log4j.net.SillySocketClient: org.apache.log4j.spi.LoggingEvent makeLoggingEvent(org.apache.log4j.Logger,org.apache.log4j.Level,java.lang.Object,java.lang.Throwable)>(v, v, v, v);
virtualinvoke v.<org.apache.log4j.net.SillySocketClient: void append(org.apache.log4j.spi.LoggingEvent)>(v);
return;
}
private static org.apache.log4j.spi.LoggingEvent makeLoggingEvent(org.apache.log4j.Logger, org.apache.log4j.Level, java.lang.Object, java.lang.Throwable)
{
java.lang.Throwable v;
org.apache.log4j.Logger v;
org.apache.log4j.Level v;
org.apache.log4j.spi.LoggingEvent v;
java.lang.Object v;
v := @parameter: org.apache.log4j.Logger;
v := @parameter: org.apache.log4j.Level;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.Throwable;
v = new org.apache.log4j.spi.LoggingEvent;
specialinvoke v.<org.apache.log4j.spi.LoggingEvent: void <init>(java.lang.String,org.apache.log4j.Category,org.apache.log4j.Priority,java.lang.Object,java.lang.Throwable)>("", v, v, v, v);
return v;
}
static void init(java.lang.String)
{
int v;
java.lang.NumberFormatException v;
java.lang.String v, v;
v := @parameter: java.lang.String;
label:
v = staticinvoke <java.lang.Integer: int parseInt(java.lang.String)>(v);
<org.apache.log4j.net.SillySocketClient: int PORT> = v;
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<java.lang.NumberFormatException: void printStackTrace()>();
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[])>("Could not interpret port number [\u].");
staticinvoke <org.apache.log4j.net.SillySocketClient: void usage(java.lang.String)>(v);
label:
return;
catch java.lang.NumberFormatException from label to label with label;
}
static void usage(java.lang.String)
{
java.io.PrintStream v, v;
java.lang.Class v;
java.lang.String v, v, v;
v := @parameter: java.lang.String;
v = <java.lang.System: java.io.PrintStream err>;
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
v = <java.lang.System: java.io.PrintStream err>;
v = class "Lorg/apache/log4j/net/SillySocketClient;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
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[])>("Usage: java \u port");
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
staticinvoke <java.lang.System: void exit(int)>(1);
return;
}
static java.net.InetAddress getAddressByName(java.lang.String) throws java.net.UnknownHostException
{
java.net.InetAddress v;
java.lang.String v;
v := @parameter: java.lang.String;
v = staticinvoke <java.net.InetAddress: java.net.InetAddress getByName(java.lang.String)>(v);
return v;
}
void connect(java.net.InetAddress, int)
{
java.io.OutputStream v;
java.net.Socket v;
java.io.IOException v;
java.net.InetAddress v;
java.lang.Thread v;
int v;
java.io.ObjectOutputStream v;
org.apache.log4j.net.SillySocketClient v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.log4j.net.SillySocketClient;
v := @parameter: java.net.InetAddress;
v := @parameter: int;
if v != null goto label;
return;
label:
v = new java.io.ObjectOutputStream;
v = new java.net.Socket;
specialinvoke v.<java.net.Socket: void <init>(java.net.InetAddress,int)>(v, v);
v = virtualinvoke v.<java.net.Socket: java.io.OutputStream getOutputStream()>();
specialinvoke v.<java.io.ObjectOutputStream: void <init>(java.io.OutputStream)>(v);
v.<org.apache.log4j.net.SillySocketClient: java.io.ObjectOutputStream oos> = v;
label:
goto label;
label:
v := @caughtexception;
v = v instanceof java.io.InterruptedIOException;
if v == 0 goto label;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void interrupt()>();
label:
v = virtualinvoke v.<java.net.InetAddress: java.lang.String getHostName()>();
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[])>("Could not connect to remote log4j server at [\u].");
staticinvoke <org.apache.log4j.helpers.LogLog: void error(java.lang.String)>(v);
label:
return;
catch java.io.IOException from label to label with label;
}
public void writeObject(java.lang.Object) throws java.io.IOException
{
java.io.ObjectOutputStream v, v;
java.lang.Object v;
org.apache.log4j.net.SillySocketClient v;
v := @this: org.apache.log4j.net.SillySocketClient;
v := @parameter: java.lang.Object;
v = v.<org.apache.log4j.net.SillySocketClient: java.io.ObjectOutputStream oos>;
virtualinvoke v.<java.io.ObjectOutputStream: void writeObject(java.lang.Object)>(v);
v = v.<org.apache.log4j.net.SillySocketClient: java.io.ObjectOutputStream oos>;
virtualinvoke v.<java.io.ObjectOutputStream: void flush()>();
return;
}
public void append(org.apache.log4j.spi.LoggingEvent) throws java.io.IOException
{
org.apache.log4j.spi.LoggingEvent v;
org.apache.log4j.net.SillySocketClient v;
v := @this: org.apache.log4j.net.SillySocketClient;
v := @parameter: org.apache.log4j.spi.LoggingEvent;
virtualinvoke v.<org.apache.log4j.spi.LoggingEvent: java.lang.String getNDC()>();
virtualinvoke v.<org.apache.log4j.spi.LoggingEvent: java.lang.String getThreadName()>();
virtualinvoke v.<org.apache.log4j.spi.LoggingEvent: void getMDCCopy()>();
virtualinvoke v.<org.apache.log4j.spi.LoggingEvent: java.lang.String getRenderedMessage()>();
virtualinvoke v.<org.apache.log4j.spi.LoggingEvent: java.lang.String[] getThrowableStrRep()>();
virtualinvoke v.<org.apache.log4j.net.SillySocketClient: void writeObject(java.lang.Object)>(v);
return;
}
static void <clinit>()
{
org.apache.log4j.Logger v;
v = staticinvoke <org.apache.log4j.LogManager: org.apache.log4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/log4j/net/SillySocketClient;");
<org.apache.log4j.net.SillySocketClient: org.apache.log4j.Logger LOGGER> = v;
return;
}
}