public final class org.apache.logging.log4j.util.internal.SerializationUtil extends java.lang.Object
{
private static final java.lang.String DEFAULT_FILTER_CLASS;
private static final java.lang.reflect.Method setObjectInputFilter;
private static final java.lang.reflect.Method getObjectInputFilter;
private static final java.lang.reflect.Method newObjectInputFilter;
public static final java.util.List REQUIRED_JAVA_CLASSES;
public static final java.util.List REQUIRED_JAVA_PACKAGES;
public static void writeWrappedObject(java.io.Serializable, java.io.ObjectOutputStream) throws java.io.IOException
{
java.lang.Throwable v;
byte[] v;
java.io.ByteArrayOutputStream v;
java.io.ObjectOutputStream v, v;
java.io.Serializable v;
v := @parameter: java.io.Serializable;
v := @parameter: java.io.ObjectOutputStream;
v = new java.io.ByteArrayOutputStream;
specialinvoke v.<java.io.ByteArrayOutputStream: void <init>()>();
v = new java.io.ObjectOutputStream;
specialinvoke v.<java.io.ObjectOutputStream: void <init>(java.io.OutputStream)>(v);
label:
virtualinvoke v.<java.io.ObjectOutputStream: void writeObject(java.lang.Object)>(v);
virtualinvoke v.<java.io.ObjectOutputStream: void flush()>();
v = virtualinvoke v.<java.io.ByteArrayOutputStream: byte[] toByteArray()>();
virtualinvoke v.<java.io.ObjectOutputStream: void writeObject(java.lang.Object)>(v);
label:
virtualinvoke v.<java.io.ObjectOutputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public static java.lang.Object readWrappedObject(java.io.ObjectInputStream) throws java.io.IOException, java.lang.ClassNotFoundException
{
java.lang.Throwable v, v;
java.lang.Object[] v, v, v;
java.io.ObjectInputStream v, v, v;
java.lang.ReflectiveOperationException v;
java.io.ByteArrayInputStream v;
java.lang.String v;
java.lang.reflect.Method v, v, v;
boolean v;
java.io.StreamCorruptedException v;
java.util.Collection v;
org.apache.logging.log4j.util.FilteredObjectInputStream v;
org.apache.logging.log4j.status.StatusLogger v;
java.lang.Object v, v, v, v;
v := @parameter: java.io.ObjectInputStream;
staticinvoke <org.apache.logging.log4j.util.internal.SerializationUtil: void assertFiltered(java.io.ObjectInputStream)>(v);
v = virtualinvoke v.<java.io.ObjectInputStream: java.lang.Object readObject()>();
v = new java.io.ByteArrayInputStream;
specialinvoke v.<java.io.ByteArrayInputStream: void <init>(byte[])>(v);
v = v instanceof org.apache.logging.log4j.util.FilteredObjectInputStream;
if v == 0 goto label;
v = new org.apache.logging.log4j.util.FilteredObjectInputStream;
v = virtualinvoke v.<org.apache.logging.log4j.util.FilteredObjectInputStream: java.util.Collection getAllowedClasses()>();
specialinvoke v.<org.apache.logging.log4j.util.FilteredObjectInputStream: void <init>(java.io.InputStream,java.util.Collection)>(v, v);
v = v;
goto label;
label:
v = <org.apache.logging.log4j.util.internal.SerializationUtil: java.lang.reflect.Method getObjectInputFilter>;
v = newarray (java.lang.Object)[0];
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = <org.apache.logging.log4j.util.internal.SerializationUtil: java.lang.reflect.Method newObjectInputFilter>;
v = newarray (java.lang.Object)[1];
v[0] = v;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(null, v);
v = new java.io.ObjectInputStream;
specialinvoke v.<java.io.ObjectInputStream: void <init>(java.io.InputStream)>(v);
v = v;
v = <org.apache.logging.log4j.util.internal.SerializationUtil: java.lang.reflect.Method setObjectInputFilter>;
v = newarray (java.lang.Object)[1];
v[0] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = new java.io.StreamCorruptedException;
specialinvoke v.<java.io.StreamCorruptedException: void <init>(java.lang.String)>("Unable to set ObjectInputFilter on stream");
throw v;
label:
v = virtualinvoke v.<java.io.ObjectInputStream: java.lang.Object readObject()>();
label:
virtualinvoke v.<java.io.ObjectInputStream: void close()>();
return v;
label:
v := @caughtexception;
v = staticinvoke <org.apache.logging.log4j.status.StatusLogger: org.apache.logging.log4j.status.StatusLogger getLogger()>();
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
virtualinvoke v.<org.apache.logging.log4j.status.StatusLogger: void warn(java.lang.String,java.lang.Object)>("Ignoring {} during deserialization", v);
label:
virtualinvoke v.<java.io.ObjectInputStream: void close()>();
return null;
label:
v := @caughtexception;
virtualinvoke v.<java.io.ObjectInputStream: void close()>();
throw v;
catch java.lang.IllegalAccessException from label to label with label;
catch java.lang.reflect.InvocationTargetException from label to label with label;
catch java.lang.Exception from label to label with label;
catch java.lang.LinkageError from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public static void assertFiltered(java.io.ObjectInputStream)
{
java.io.ObjectInputStream v;
java.lang.IllegalArgumentException v;
java.lang.reflect.Method v;
boolean v;
v := @parameter: java.io.ObjectInputStream;
v = v instanceof org.apache.logging.log4j.util.FilteredObjectInputStream;
if v != 0 goto label;
v = <org.apache.logging.log4j.util.internal.SerializationUtil: java.lang.reflect.Method setObjectInputFilter>;
if v != null goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("readObject requires a FilteredObjectInputStream or an ObjectInputStream that accepts an ObjectInputFilter");
throw v;
label:
return;
}
public static java.lang.String stripArray(java.lang.Class)
{
java.lang.Class v, v;
java.lang.String v;
boolean v;
v := @parameter: java.lang.Class;
v = v;
label:
v = virtualinvoke v.<java.lang.Class: boolean isArray()>();
if v == 0 goto label;
v = virtualinvoke v.<java.lang.Class: java.lang.Class getComponentType()>();
goto label;
label:
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
return v;
}
public static java.lang.String stripArray(java.lang.String)
{
byte v;
int v, v, v, v, v, v;
java.lang.String v, v, v, v;
boolean v, v, v, v, v, v, v, v;
char v;
java.lang.IllegalArgumentException v;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: int lastIndexOf(int)>(91);
v = v + 1;
if v != 0 goto label;
return v;
label:
v = virtualinvoke v.<java.lang.String: char charAt(int)>(v);
if v != 76 goto label;
v = v + 1;
v = virtualinvoke v.<java.lang.String: int length()>();
v = v - 1;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(v, v);
return v;
label:
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = -1;
v = virtualinvoke v.<java.lang.String: int hashCode()>();
tableswitch(v)
{
case 66: goto label;
case 67: goto label;
case 68: goto label;
case 69: goto label;
case 70: goto label;
case 71: goto label;
case 72: goto label;
case 73: goto label;
case 74: goto label;
case 75: goto label;
case 76: goto label;
case 77: goto label;
case 78: goto label;
case 79: goto label;
case 80: goto label;
case 81: goto label;
case 82: goto label;
case 83: goto label;
case 84: goto label;
case 85: goto label;
case 86: goto label;
case 87: goto label;
case 88: goto label;
case 89: goto label;
case 90: goto label;
default: goto label;
};
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("Z");
if v == 0 goto label;
v = 0;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("B");
if v == 0 goto label;
v = 1;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("C");
if v == 0 goto label;
v = 2;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("D");
if v == 0 goto label;
v = 3;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("F");
if v == 0 goto label;
v = 4;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("I");
if v == 0 goto label;
v = 5;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("J");
if v == 0 goto label;
v = 6;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("S");
if v == 0 goto label;
v = 7;
label:
tableswitch(v)
{
case 0: goto label;
case 1: goto label;
case 2: goto label;
case 3: goto label;
case 4: goto label;
case 5: goto label;
case 6: goto label;
case 7: goto label;
default: goto label;
};
label:
return "boolean";
label:
return "byte";
label:
return "char";
label:
return "double";
label:
return "float";
label:
return "int";
label:
return "long";
label:
return "short";
label:
v = new java.lang.IllegalArgumentException;
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[])>("Unsupported array class signature \'\u0001\'");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
}
private void <init>()
{
org.apache.logging.log4j.util.internal.SerializationUtil v;
v := @this: org.apache.logging.log4j.util.internal.SerializationUtil;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
static void <clinit>()
{
java.lang.String[] v, v;
java.lang.reflect.Method[] v, v;
int v, v, v, v, v;
java.lang.String v, v, v;
java.lang.reflect.Method v, v, v, v, v;
boolean v, v, v, v;
java.util.List v, v;
java.lang.Class v, v;
java.lang.ClassNotFoundException v;
v = class "Ljava/io/ObjectInputStream;";
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method[] getMethods()>();
v = null;
v = null;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("setObjectInputFilter");
if v == 0 goto label;
v = v;
goto label;
label:
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("getObjectInputFilter");
if v == 0 goto label;
v = v;
label:
v = v + 1;
goto label;
label:
v = null;
label:
if v == null goto label;
v = staticinvoke <java.lang.Class: java.lang.Class forName(java.lang.String)>("org.apache.logging.log4j.util.internal.DefaultObjectInputFilter");
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method[] getMethods()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("newInstance");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.reflect.Method: int getModifiers()>();
v = staticinvoke <java.lang.reflect.Modifier: boolean isStatic(int)>(v);
if v == 0 goto label;
v = v;
goto label;
label:
v = v + 1;
goto label;
label:
v := @caughtexception;
label:
<org.apache.logging.log4j.util.internal.SerializationUtil: java.lang.reflect.Method newObjectInputFilter> = v;
<org.apache.logging.log4j.util.internal.SerializationUtil: java.lang.reflect.Method setObjectInputFilter> = v;
<org.apache.logging.log4j.util.internal.SerializationUtil: java.lang.reflect.Method getObjectInputFilter> = v;
v = newarray (java.lang.String)[11];
v[0] = "java.math.BigDecimal";
v[1] = "java.math.BigInteger";
v[2] = "java.rmi.MarshalledObject";
v[3] = "boolean";
v[4] = "byte";
v[5] = "char";
v[6] = "double";
v[7] = "float";
v[8] = "int";
v[9] = "long";
v[10] = "short";
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
<org.apache.logging.log4j.util.internal.SerializationUtil: java.util.List REQUIRED_JAVA_CLASSES> = v;
v = newarray (java.lang.String)[4];
v[0] = "java.lang.";
v[1] = "java.time.";
v[2] = "java.util.";
v[3] = "org.apache.logging.log4j.";
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
<org.apache.logging.log4j.util.internal.SerializationUtil: java.util.List REQUIRED_JAVA_PACKAGES> = v;
return;
catch java.lang.ClassNotFoundException from label to label with label;
}
}