public class org.apache.logging.log4j.core.net.MulticastDnsAdvertiser extends java.lang.Object implements org.apache.logging.log4j.core.net.Advertiser
{
protected static final org.apache.logging.log4j.Logger LOGGER;
private static final int MAX_LENGTH;
private static final int DEFAULT_PORT;
private static java.lang.Object jmDNS;
private static java.lang.Class jmDNSClass;
private static java.lang.Class serviceInfoClass;
public void <init>()
{
org.apache.logging.log4j.core.net.MulticastDnsAdvertiser v;
v := @this: org.apache.logging.log4j.core.net.MulticastDnsAdvertiser;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public java.lang.Object advertise(java.util.Map)
{
java.lang.NoSuchMethodException v, v;
java.util.Map v;
java.lang.reflect.Method v;
boolean v, v;
java.util.Set v;
org.apache.logging.log4j.Logger v, v, v;
java.lang.Object[] v;
java.util.HashMap v;
java.lang.ReflectiveOperationException v;
int v, v, v;
java.lang.String v, v;
java.util.Iterator v;
java.lang.Class[] v, v;
org.apache.logging.log4j.core.net.MulticastDnsAdvertiser v;
java.lang.Class v, v, v;
java.lang.Object v, v, v, v, v, v, v, v, v, v, v;
v := @this: org.apache.logging.log4j.core.net.MulticastDnsAdvertiser;
v := @parameter: java.util.Map;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = interfaceinvoke v.<java.util.Map: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: 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()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = virtualinvoke v.<java.lang.String: int length()>();
if v > 255 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<java.lang.String: int length()>();
if v > 255 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("protocol");
if v == null goto label;
v = v;
goto label;
label:
v = "tcp";
label:
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[])>("._log4j._\u.local.");
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("port");
v = staticinvoke <org.apache.logging.log4j.core.util.Integers: int parseInt(java.lang.String,int)>(v, 4555);
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("name");
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Object jmDNS>;
if v == null goto label;
v = 0;
label:
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Class jmDNSClass>;
v = newarray (java.lang.Class)[0];
virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getMethod(java.lang.String,java.lang.Class[])>("create", v);
v = 1;
label:
goto label;
label:
v := @caughtexception;
label:
if v == 0 goto label;
v = staticinvoke <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Object buildServiceInfoVersion3(java.lang.String,int,java.lang.String,java.util.Map)>(v, v, v, v);
goto label;
label:
v = staticinvoke <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Object buildServiceInfoVersion1(java.lang.String,int,java.lang.String,java.util.Map)>(v, v, v, v);
label:
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Class jmDNSClass>;
v = newarray (java.lang.Class)[1];
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Class serviceInfoClass>;
v[0] = v;
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getMethod(java.lang.String,java.lang.Class[])>("registerService", v);
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Object jmDNS>;
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 = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Unable to invoke registerService method", v);
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("No registerService method", v);
label:
return v;
label:
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String)>("JMDNS not available - will not advertise ZeroConf support");
return null;
catch java.lang.NoSuchMethodException from label to label with label;
catch java.lang.IllegalAccessException from label to label with label;
catch java.lang.reflect.InvocationTargetException from label to label with label;
catch java.lang.NoSuchMethodException from label to label with label;
}
public void unadvertise(java.lang.Object)
{
java.lang.Object[] v;
java.lang.NoSuchMethodException v;
java.lang.Class[] v;
java.lang.ReflectiveOperationException v;
org.apache.logging.log4j.core.net.MulticastDnsAdvertiser v;
org.apache.logging.log4j.Logger v, v;
java.lang.Class v, v;
java.lang.Object v, v, v;
java.lang.reflect.Method v;
v := @this: org.apache.logging.log4j.core.net.MulticastDnsAdvertiser;
v := @parameter: java.lang.Object;
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Object jmDNS>;
if v == null goto label;
label:
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Class jmDNSClass>;
v = newarray (java.lang.Class)[1];
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Class serviceInfoClass>;
v[0] = v;
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getMethod(java.lang.String,java.lang.Class[])>("unregisterService", v);
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Object jmDNS>;
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 = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Unable to invoke unregisterService method", v);
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("No unregisterService method", v);
label:
return;
catch java.lang.IllegalAccessException from label to label with label;
catch java.lang.reflect.InvocationTargetException from label to label with label;
catch java.lang.NoSuchMethodException from label to label with label;
}
private static java.lang.Object createJmDnsVersion1()
{
org.apache.logging.log4j.Logger v;
java.lang.Class v;
java.lang.Object v;
java.lang.ReflectiveOperationException v;
label:
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Class jmDNSClass>;
v = staticinvoke <org.apache.logging.log4j.util.LoaderUtil: java.lang.Object newInstanceOf(java.lang.Class)>(v);
label:
return v;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Unable to instantiate JMDNS", v);
return null;
catch java.lang.InstantiationException from label to label with label;
catch java.lang.IllegalAccessException from label to label with label;
catch java.lang.NoSuchMethodException from label to label with label;
catch java.lang.reflect.InvocationTargetException from label to label with label;
}
private static java.lang.Object createJmDnsVersion3()
{
java.lang.Object[] v;
java.lang.NoSuchMethodException v;
java.lang.Class[] v;
java.lang.ReflectiveOperationException v;
org.apache.logging.log4j.Logger v, v;
java.lang.Class v;
java.lang.Object v;
java.lang.reflect.Method v;
label:
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Class jmDNSClass>;
v = newarray (java.lang.Class)[0];
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getMethod(java.lang.String,java.lang.Class[])>("create", v);
v = (java.lang.Object[]) null;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(null, v);
label:
return v;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Unable to invoke create method", v);
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Unable to get create method", v);
label:
return null;
catch java.lang.IllegalAccessException from label to label with label;
catch java.lang.reflect.InvocationTargetException from label to label with label;
catch java.lang.NoSuchMethodException from label to label with label;
}
private static java.lang.Object buildServiceInfoVersion1(java.lang.String, int, java.lang.String, java.util.Map)
{
java.lang.Object[] v;
java.lang.NoSuchMethodException v;
java.lang.ReflectiveOperationException v;
java.lang.Integer v, v, v;
java.lang.reflect.Constructor v;
java.util.Map v;
int v;
java.lang.String v, v;
java.util.Hashtable v;
java.lang.Class[] v;
org.apache.logging.log4j.Logger v, v;
java.lang.Class v, v, v, v;
java.lang.Object v;
v := @parameter: java.lang.String;
v := @parameter: int;
v := @parameter: java.lang.String;
v := @parameter: java.util.Map;
v = new java.util.Hashtable;
specialinvoke v.<java.util.Hashtable: void <init>(java.util.Map)>(v);
label:
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Class serviceInfoClass>;
v = newarray (java.lang.Class)[6];
v[0] = class "Ljava/lang/String;";
v[1] = class "Ljava/lang/String;";
v = <java.lang.Integer: java.lang.Class TYPE>;
v[2] = v;
v = <java.lang.Integer: java.lang.Class TYPE>;
v[3] = v;
v = <java.lang.Integer: java.lang.Class TYPE>;
v[4] = v;
v[5] = class "Ljava/util/Hashtable;";
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Constructor getConstructor(java.lang.Class[])>(v);
v = newarray (java.lang.Object)[6];
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[2] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(0);
v[3] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(0);
v[4] = v;
v[5] = v;
v = virtualinvoke v.<java.lang.reflect.Constructor: java.lang.Object newInstance(java.lang.Object[])>(v);
label:
return v;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Unable to construct ServiceInfo instance", v);
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Unable to get ServiceInfo constructor", v);
label:
return null;
catch java.lang.IllegalAccessException from label to label with label;
catch java.lang.InstantiationException from label to label with label;
catch java.lang.reflect.InvocationTargetException from label to label with label;
catch java.lang.NoSuchMethodException from label to label with label;
}
private static java.lang.Object buildServiceInfoVersion3(java.lang.String, int, java.lang.String, java.util.Map)
{
java.lang.Object[] v;
java.lang.NoSuchMethodException v;
java.lang.ReflectiveOperationException v;
java.lang.Integer v, v, v;
java.util.Map v;
int v;
java.lang.String v, v;
java.lang.reflect.Method v;
java.lang.Class[] v;
org.apache.logging.log4j.Logger v, v;
java.lang.Class v, v, v, v;
java.lang.Object v;
v := @parameter: java.lang.String;
v := @parameter: int;
v := @parameter: java.lang.String;
v := @parameter: java.util.Map;
label:
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Class serviceInfoClass>;
v = newarray (java.lang.Class)[6];
v[0] = class "Ljava/lang/String;";
v[1] = class "Ljava/lang/String;";
v = <java.lang.Integer: java.lang.Class TYPE>;
v[2] = v;
v = <java.lang.Integer: java.lang.Class TYPE>;
v[3] = v;
v = <java.lang.Integer: java.lang.Class TYPE>;
v[4] = v;
v[5] = class "Ljava/util/Map;";
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getMethod(java.lang.String,java.lang.Class[])>("create", v);
v = newarray (java.lang.Object)[6];
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[2] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(0);
v[3] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(0);
v[4] = v;
v[5] = v;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(null, v);
label:
return v;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Unable to invoke create method", v);
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Unable to find create method", v);
label:
return null;
catch java.lang.IllegalAccessException from label to label with label;
catch java.lang.reflect.InvocationTargetException from label to label with label;
catch java.lang.NoSuchMethodException from label to label with label;
}
private static java.lang.Object initializeJmDns()
{
java.lang.Throwable v;
java.lang.NoSuchMethodException v;
java.lang.Class[] v;
org.apache.logging.log4j.Logger v;
java.lang.Class v, v, v;
java.lang.Object v, v;
boolean v;
label:
v = staticinvoke <org.apache.logging.log4j.util.LoaderUtil: java.lang.Class loadClass(java.lang.String)>("javax.jmdns.JmDNS");
<org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Class jmDNSClass> = v;
v = staticinvoke <org.apache.logging.log4j.util.LoaderUtil: java.lang.Class loadClass(java.lang.String)>("javax.jmdns.ServiceInfo");
<org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Class serviceInfoClass> = v;
v = 0;
label:
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Class jmDNSClass>;
v = newarray (java.lang.Class)[0];
virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getMethod(java.lang.String,java.lang.Class[])>("create", v);
v = 1;
label:
goto label;
label:
v := @caughtexception;
label:
if v == 0 goto label;
v = staticinvoke <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Object createJmDnsVersion3()>();
label:
return v;
label:
v = staticinvoke <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Object createJmDnsVersion1()>();
label:
return v;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("JmDNS or serviceInfo class not found", v);
return null;
catch java.lang.NoSuchMethodException from label to label with label;
catch java.lang.ClassNotFoundException from label to label with label;
catch java.lang.ExceptionInInitializerError from label to label with label;
catch java.lang.ClassNotFoundException from label to label with label;
catch java.lang.ExceptionInInitializerError from label to label with label;
}
static void <clinit>()
{
org.apache.logging.log4j.status.StatusLogger v;
java.lang.Object v;
v = staticinvoke <org.apache.logging.log4j.status.StatusLogger: org.apache.logging.log4j.status.StatusLogger getLogger()>();
<org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: org.apache.logging.log4j.Logger LOGGER> = v;
v = staticinvoke <org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Object initializeJmDns()>();
<org.apache.logging.log4j.core.net.MulticastDnsAdvertiser: java.lang.Object jmDNS> = v;
return;
}
}