public class org.apache.logging.log4j.core.net.JndiManager extends org.apache.logging.log4j.core.appender.AbstractManager
{
private static final org.apache.logging.log4j.core.net.JndiManager$JndiManagerFactory FACTORY;
private static final java.lang.String PREFIX;
private static final java.lang.String JAVA_SCHEME;
private final javax.naming.InitialContext context;
private static boolean isJndiEnabled(java.lang.String)
{
java.lang.String v, v;
org.apache.logging.log4j.util.PropertiesUtil v;
boolean v;
v := @parameter: java.lang.String;
v = staticinvoke <org.apache.logging.log4j.util.PropertiesUtil: org.apache.logging.log4j.util.PropertiesUtil getProperties()>();
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.enableJndi\u0001");
v = virtualinvoke v.<org.apache.logging.log4j.util.PropertiesUtil: boolean getBooleanProperty(java.lang.String,boolean)>(v, 0);
return v;
}
public static boolean isJndiEnabled()
{
boolean v, v, v, v, v;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: boolean isJndiContextSelectorEnabled()>();
if v != 0 goto label;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: boolean isJndiJdbcEnabled()>();
if v != 0 goto label;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: boolean isJndiJmsEnabled()>();
if v != 0 goto label;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: boolean isJndiLookupEnabled()>();
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public static boolean isJndiContextSelectorEnabled()
{
boolean v;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: boolean isJndiEnabled(java.lang.String)>("ContextSelector");
return v;
}
public static boolean isJndiJdbcEnabled()
{
boolean v;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: boolean isJndiEnabled(java.lang.String)>("Jdbc");
return v;
}
public static boolean isJndiJmsEnabled()
{
boolean v;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: boolean isJndiEnabled(java.lang.String)>("Jms");
return v;
}
public static boolean isJndiLookupEnabled()
{
boolean v;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: boolean isJndiEnabled(java.lang.String)>("Lookup");
return v;
}
private void <init>(java.lang.String, javax.naming.InitialContext)
{
javax.naming.InitialContext v;
java.lang.String v;
org.apache.logging.log4j.core.net.JndiManager v;
v := @this: org.apache.logging.log4j.core.net.JndiManager;
v := @parameter: java.lang.String;
v := @parameter: javax.naming.InitialContext;
specialinvoke v.<org.apache.logging.log4j.core.appender.AbstractManager: void <init>(org.apache.logging.log4j.core.LoggerContext,java.lang.String)>(null, v);
v.<org.apache.logging.log4j.core.net.JndiManager: javax.naming.InitialContext context> = v;
return;
}
public static org.apache.logging.log4j.core.net.JndiManager getDefaultManager()
{
org.apache.logging.log4j.core.appender.AbstractManager v;
java.lang.Class v;
java.lang.String v;
org.apache.logging.log4j.core.net.JndiManager$JndiManagerFactory v;
v = class "Lorg/apache/logging/log4j/core/net/JndiManager;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = <org.apache.logging.log4j.core.net.JndiManager: org.apache.logging.log4j.core.net.JndiManager$JndiManagerFactory FACTORY>;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: org.apache.logging.log4j.core.appender.AbstractManager getManager(java.lang.String,org.apache.logging.log4j.core.appender.ManagerFactory,java.lang.Object)>(v, v, null);
return v;
}
public static org.apache.logging.log4j.core.net.JndiManager getDefaultManager(java.lang.String)
{
java.lang.String v;
org.apache.logging.log4j.core.appender.AbstractManager v;
org.apache.logging.log4j.core.net.JndiManager$JndiManagerFactory v;
v := @parameter: java.lang.String;
v = <org.apache.logging.log4j.core.net.JndiManager: org.apache.logging.log4j.core.net.JndiManager$JndiManagerFactory FACTORY>;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: org.apache.logging.log4j.core.appender.AbstractManager getManager(java.lang.String,org.apache.logging.log4j.core.appender.ManagerFactory,java.lang.Object)>(v, v, null);
return v;
}
public static org.apache.logging.log4j.core.net.JndiManager getJndiManager(java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.util.Properties)
{
java.util.Properties v, v;
org.apache.logging.log4j.core.appender.AbstractManager v;
java.lang.String v, v, v, v, v, v;
org.apache.logging.log4j.core.net.JndiManager$JndiManagerFactory v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.util.Properties;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: java.util.Properties createProperties(java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.util.Properties)>(v, v, v, v, v, v);
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: java.lang.String createManagerName()>();
v = <org.apache.logging.log4j.core.net.JndiManager: org.apache.logging.log4j.core.net.JndiManager$JndiManagerFactory FACTORY>;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: org.apache.logging.log4j.core.appender.AbstractManager getManager(java.lang.String,org.apache.logging.log4j.core.appender.ManagerFactory,java.lang.Object)>(v, v, v);
return v;
}
public static org.apache.logging.log4j.core.net.JndiManager getJndiManager(java.util.Properties)
{
java.util.Properties v;
org.apache.logging.log4j.core.appender.AbstractManager v;
java.lang.String v;
org.apache.logging.log4j.core.net.JndiManager$JndiManagerFactory v;
v := @parameter: java.util.Properties;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: java.lang.String createManagerName()>();
v = <org.apache.logging.log4j.core.net.JndiManager: org.apache.logging.log4j.core.net.JndiManager$JndiManagerFactory FACTORY>;
v = staticinvoke <org.apache.logging.log4j.core.net.JndiManager: org.apache.logging.log4j.core.appender.AbstractManager getManager(java.lang.String,org.apache.logging.log4j.core.appender.ManagerFactory,java.lang.Object)>(v, v, v);
return v;
}
private static java.lang.String createManagerName()
{
int v;
java.lang.Class v, v;
java.lang.String v, v;
v = class "Lorg/apache/logging/log4j/core/net/JndiManager;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = class "Lorg/apache/logging/log4j/core/net/JndiManager;";
v = virtualinvoke v.<java.lang.Object: int hashCode()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(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");
return v;
}
public static java.util.Properties createProperties(java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.util.Properties)
{
java.util.Properties v, v;
org.apache.logging.log4j.Logger v, v;
java.lang.String v, v, v, v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.util.Properties;
if v != null goto label;
return null;
label:
v = new java.util.Properties;
specialinvoke v.<java.util.Properties: void <init>()>();
virtualinvoke v.<java.util.Properties: java.lang.Object setProperty(java.lang.String,java.lang.String)>("java.naming.factory.initial", v);
if v == null goto label;
virtualinvoke v.<java.util.Properties: java.lang.Object setProperty(java.lang.String,java.lang.String)>("java.naming.provider.url", v);
goto label;
label:
v = <org.apache.logging.log4j.core.net.JndiManager: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Object)>("The JNDI InitialContextFactory class name [{}] was provided, but there was no associated provider URL. This is likely to cause problems.", v);
label:
if v == null goto label;
virtualinvoke v.<java.util.Properties: java.lang.Object setProperty(java.lang.String,java.lang.String)>("java.naming.factory.url.pkgs", v);
label:
if v == null goto label;
virtualinvoke v.<java.util.Properties: java.lang.Object setProperty(java.lang.String,java.lang.String)>("java.naming.security.principal", v);
if v == null goto label;
virtualinvoke v.<java.util.Properties: java.lang.Object setProperty(java.lang.String,java.lang.String)>("java.naming.security.credentials", v);
goto label;
label:
v = <org.apache.logging.log4j.core.net.JndiManager: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Object)>("A security principal [{}] was provided, but with no corresponding security credentials.", v);
label:
if v == null goto label;
virtualinvoke v.<java.util.Properties: void putAll(java.util.Map)>(v);
label:
return v;
}
protected boolean releaseSub(long, java.util.concurrent.TimeUnit)
{
java.util.concurrent.TimeUnit v;
javax.naming.InitialContext v;
org.apache.logging.log4j.core.net.JndiManager v;
long v;
boolean v;
v := @this: org.apache.logging.log4j.core.net.JndiManager;
v := @parameter: long;
v := @parameter: java.util.concurrent.TimeUnit;
v = v.<org.apache.logging.log4j.core.net.JndiManager: javax.naming.InitialContext context>;
v = staticinvoke <org.apache.logging.log4j.core.util.JndiCloser: boolean closeSilently(javax.naming.Context)>(v);
return v;
}
public java.lang.Object lookup(java.lang.String) throws javax.naming.NamingException
{
javax.naming.InitialContext v, v;
java.net.URISyntaxException v;
org.apache.logging.log4j.Logger v, v;
org.apache.logging.log4j.core.net.JndiManager v;
java.lang.Object v;
java.lang.String v, v, v;
java.net.URI v;
boolean v;
v := @this: org.apache.logging.log4j.core.net.JndiManager;
v := @parameter: java.lang.String;
v = v.<org.apache.logging.log4j.core.net.JndiManager: javax.naming.InitialContext context>;
if v != null goto label;
return null;
label:
v = new java.net.URI;
specialinvoke v.<java.net.URI: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<java.net.URI: java.lang.String getScheme()>();
if v == null goto label;
v = virtualinvoke v.<java.net.URI: java.lang.String getScheme()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("java");
if v == 0 goto label;
label:
v = v.<org.apache.logging.log4j.core.net.JndiManager: javax.naming.InitialContext context>;
v = virtualinvoke v.<javax.naming.InitialContext: java.lang.Object lookup(java.lang.String)>(v);
label:
return v;
label:
v = <org.apache.logging.log4j.core.net.JndiManager: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Object)>("Unsupported JNDI URI - {}", v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.net.JndiManager: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Object)>("Invalid JNDI URI - {}", v);
label:
return null;
catch java.net.URISyntaxException from label to label with label;
catch java.net.URISyntaxException from label to label with label;
}
public java.lang.String toString()
{
javax.naming.InitialContext v;
org.apache.logging.log4j.core.net.JndiManager v;
int v;
java.lang.String v;
v := @this: org.apache.logging.log4j.core.net.JndiManager;
v = v.<org.apache.logging.log4j.core.net.JndiManager: javax.naming.InitialContext context>;
v = v.<org.apache.logging.log4j.core.net.JndiManager: int count>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (javax.naming.InitialContext,int)>(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[])>("JndiManager [context=\u, count=\u]");
return v;
}
static void <clinit>()
{
org.apache.logging.log4j.core.net.JndiManager$JndiManagerFactory v;
v = new org.apache.logging.log4j.core.net.JndiManager$JndiManagerFactory;
specialinvoke v.<org.apache.logging.log4j.core.net.JndiManager$JndiManagerFactory: void <init>()>();
<org.apache.logging.log4j.core.net.JndiManager: org.apache.logging.log4j.core.net.JndiManager$JndiManagerFactory FACTORY> = v;
return;
}
}