public class org.apache.logging.log4j.core.script.ScriptManager extends java.lang.Object implements org.apache.logging.log4j.core.util.FileWatcher
{
private static final java.lang.String KEY_THREADING;
private static final org.apache.logging.log4j.Logger logger;
private final org.apache.logging.log4j.core.config.Configuration configuration;
private final javax.script.ScriptEngineManager manager;
private final java.util.concurrent.ConcurrentMap scriptRunners;
private final java.lang.String languages;
private final java.util.Set allowedLanguages;
private final org.apache.logging.log4j.core.util.WatchManager watchManager;
public void <init>(org.apache.logging.log4j.core.config.Configuration, org.apache.logging.log4j.core.util.WatchManager, java.lang.String)
{
java.lang.Integer v;
org.apache.logging.log4j.core.config.Configuration v;
java.util.stream.Collector v;
boolean v, v, v, v, v, v, v, v;
java.util.concurrent.ConcurrentHashMap v;
java.util.Set v, v;
java.util.List v, v, v;
java.util.stream.Stream v, v;
org.apache.logging.log4j.Logger v, v, v;
java.lang.StringBuilder v, v, v;
java.lang.String[] v;
java.util.function.Function v;
org.apache.logging.log4j.core.script.ScriptManager v;
int v, v, v, v, v;
java.lang.Boolean v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v;
java.util.Iterator v, v, v, v;
org.apache.logging.log4j.core.util.WatchManager v;
javax.script.ScriptEngineManager v, v;
javax.script.ScriptEngine v;
java.lang.Class v;
java.lang.Object v, v, v, v, v, v;
v := @this: org.apache.logging.log4j.core.script.ScriptManager;
v := @parameter: org.apache.logging.log4j.core.config.Configuration;
v := @parameter: org.apache.logging.log4j.core.util.WatchManager;
v := @parameter: java.lang.String;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new javax.script.ScriptEngineManager;
specialinvoke v.<javax.script.ScriptEngineManager: void <init>()>();
v.<org.apache.logging.log4j.core.script.ScriptManager: javax.script.ScriptEngineManager manager> = v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.concurrent.ConcurrentMap scriptRunners> = v;
v.<org.apache.logging.log4j.core.script.ScriptManager: org.apache.logging.log4j.core.config.Configuration configuration> = v;
v.<org.apache.logging.log4j.core.script.ScriptManager: org.apache.logging.log4j.core.util.WatchManager watchManager> = v;
v = v.<org.apache.logging.log4j.core.script.ScriptManager: javax.script.ScriptEngineManager manager>;
v = virtualinvoke v.<javax.script.ScriptEngineManager: java.util.List getEngineFactories()>();
v = staticinvoke <org.apache.logging.log4j.util.Strings: java.lang.String[] splitList(java.lang.String)>(v);
v = staticinvoke <java.util.Arrays: java.util.stream.Stream stream(java.lang.Object[])>(v);
v = staticinvoke <org.apache.logging.log4j.core.script.ScriptManager$toRootLowerCase__1270: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream map(java.util.function.Function)>(v);
v = staticinvoke <java.util.stream.Collectors: java.util.stream.Collector toSet()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.lang.Object collect(java.util.stream.Collector)>(v);
v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.Set allowedLanguages> = v;
v = <org.apache.logging.log4j.core.script.ScriptManager: org.apache.logging.log4j.Logger logger>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = interfaceinvoke v.<java.util.List: int size()>();
v = <org.apache.logging.log4j.core.script.ScriptManager: org.apache.logging.log4j.Logger logger>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
if v == 1 goto label;
v = "s";
goto label;
label:
v = "";
label:
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Installed {} script engine{}", v, v);
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()>();
v = interfaceinvoke v.<javax.script.ScriptEngineFactory: java.lang.Object getParameter(java.lang.String)>("THREADING");
v = staticinvoke <java.util.Objects: java.lang.String toString(java.lang.Object,java.lang.String)>(v, null);
if v != null goto label;
v = "Not Thread Safe";
label:
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = interfaceinvoke v.<javax.script.ScriptEngineFactory: java.util.List getNames()>();
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()>();
v = v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.Set allowedLanguages>;
v = staticinvoke <org.apache.logging.log4j.util.Strings: java.lang.String toRootLowerCase(java.lang.String)>(v);
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = virtualinvoke v.<java.lang.StringBuilder: int length()>();
if v <= 0 goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", ");
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
goto label;
label:
v = virtualinvoke v.<java.lang.StringBuilder: int length()>();
if v <= 0 goto label;
v = virtualinvoke v.<java.lang.StringBuilder: int length()>();
if v <= 0 goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", ");
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.CharSequence)>(v);
v = interfaceinvoke v.<javax.script.ScriptEngineFactory: javax.script.ScriptEngine getScriptEngine()>();
v = v instanceof javax.script.Compilable;
v = <org.apache.logging.log4j.core.script.ScriptManager: org.apache.logging.log4j.Logger logger>;
v = interfaceinvoke v.<javax.script.ScriptEngineFactory: java.lang.String getEngineName()>();
v = interfaceinvoke v.<javax.script.ScriptEngineFactory: java.lang.String getEngineVersion()>();
v = interfaceinvoke v.<javax.script.ScriptEngineFactory: java.lang.String getLanguageName()>();
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object,java.lang.Object,java.lang.Object,java.lang.Object,java.lang.Object,java.lang.Object)>("{} version: {}, language: {}, threading: {}, compile: {}, names: {}, factory class: {}", v, v, v, v, v, v, v);
goto label;
label:
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
v.<org.apache.logging.log4j.core.script.ScriptManager: java.lang.String languages> = v;
goto label;
label:
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()>();
v = interfaceinvoke v.<javax.script.ScriptEngineFactory: java.util.List getNames()>();
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()>();
v = v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.Set allowedLanguages>;
v = staticinvoke <org.apache.logging.log4j.util.Strings: java.lang.String toRootLowerCase(java.lang.String)>(v);
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = virtualinvoke v.<java.lang.StringBuilder: int length()>();
if v <= 0 goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", ");
label:
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()>();
v.<org.apache.logging.log4j.core.script.ScriptManager: java.lang.String languages> = v;
label:
return;
}
public java.util.Set getAllowedLanguages()
{
java.util.Set v;
org.apache.logging.log4j.core.script.ScriptManager v;
v := @this: org.apache.logging.log4j.core.script.ScriptManager;
v = v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.Set allowedLanguages>;
return v;
}
public boolean addScript(org.apache.logging.log4j.core.script.AbstractScript)
{
org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner v;
java.util.concurrent.ConcurrentMap v, v;
org.apache.logging.log4j.core.script.ScriptManager v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
java.nio.file.Path v;
boolean v, v, v;
org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner v;
org.apache.logging.log4j.core.script.AbstractScript v;
org.apache.logging.log4j.core.util.WatchManager v;
java.util.Set v;
javax.script.ScriptEngineManager v;
javax.script.ScriptEngineFactory v;
java.io.File v;
org.apache.logging.log4j.Logger v, v;
javax.script.ScriptEngine v;
java.lang.Object v;
v := @this: org.apache.logging.log4j.core.script.ScriptManager;
v := @parameter: org.apache.logging.log4j.core.script.AbstractScript;
v = v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.Set allowedLanguages>;
v = virtualinvoke v.<org.apache.logging.log4j.core.script.AbstractScript: java.lang.String getLanguage()>();
v = staticinvoke <org.apache.logging.log4j.util.Strings: java.lang.String toRootLowerCase(java.lang.String)>(v);
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = v.<org.apache.logging.log4j.core.script.ScriptManager: javax.script.ScriptEngineManager manager>;
v = virtualinvoke v.<org.apache.logging.log4j.core.script.AbstractScript: java.lang.String getLanguage()>();
v = virtualinvoke v.<javax.script.ScriptEngineManager: javax.script.ScriptEngine getEngineByName(java.lang.String)>(v);
if v != null goto label;
v = <org.apache.logging.log4j.core.script.ScriptManager: org.apache.logging.log4j.Logger logger>;
v = virtualinvoke v.<org.apache.logging.log4j.core.script.AbstractScript: java.lang.String getLanguage()>();
v = v.<org.apache.logging.log4j.core.script.ScriptManager: java.lang.String languages>;
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[])>("No ScriptEngine found for language \u. Available languages are: \u0001");
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String)>(v);
return 0;
label:
v = interfaceinvoke v.<javax.script.ScriptEngine: javax.script.ScriptEngineFactory getFactory()>();
v = interfaceinvoke v.<javax.script.ScriptEngineFactory: java.lang.Object getParameter(java.lang.String)>("THREADING");
if v != null goto label;
v = v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.concurrent.ConcurrentMap scriptRunners>;
v = virtualinvoke v.<org.apache.logging.log4j.core.script.AbstractScript: java.lang.String getName()>();
v = new org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner;
specialinvoke v.<org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner: void <init>(org.apache.logging.log4j.core.script.ScriptManager,org.apache.logging.log4j.core.script.AbstractScript)>(v, v);
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.concurrent.ConcurrentMap scriptRunners>;
v = virtualinvoke v.<org.apache.logging.log4j.core.script.AbstractScript: java.lang.String getName()>();
v = new org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner;
specialinvoke v.<org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner: void <init>(org.apache.logging.log4j.core.script.ScriptManager,javax.script.ScriptEngine,org.apache.logging.log4j.core.script.AbstractScript)>(v, v, v);
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
v = v instanceof org.apache.logging.log4j.core.script.ScriptFile;
if v == 0 goto label;
v = virtualinvoke v.<org.apache.logging.log4j.core.script.ScriptFile: java.nio.file.Path getPath()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.script.ScriptFile: boolean isWatched()>();
if v == 0 goto label;
if v == null goto label;
v = v.<org.apache.logging.log4j.core.script.ScriptManager: org.apache.logging.log4j.core.util.WatchManager watchManager>;
v = interfaceinvoke v.<java.nio.file.Path: java.io.File toFile()>();
virtualinvoke v.<org.apache.logging.log4j.core.util.WatchManager: void watchFile(java.io.File,org.apache.logging.log4j.core.util.FileWatcher)>(v, v);
goto label;
label:
v = <org.apache.logging.log4j.core.script.ScriptManager: org.apache.logging.log4j.Logger logger>;
v = virtualinvoke v.<org.apache.logging.log4j.core.script.AbstractScript: java.lang.String getName()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.script.AbstractScript: java.lang.String getLanguage()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String,java.lang.Object,java.lang.Object)>("Unable to add script {}, {} has not been configured as an allowed language", v, v);
return 0;
label:
return 1;
}
public javax.script.Bindings createBindings(org.apache.logging.log4j.core.script.AbstractScript)
{
javax.script.Bindings v;
org.apache.logging.log4j.core.script.ScriptManager v;
org.apache.logging.log4j.core.script.AbstractScript v;
org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner v;
v := @this: org.apache.logging.log4j.core.script.ScriptManager;
v := @parameter: org.apache.logging.log4j.core.script.AbstractScript;
v = specialinvoke v.<org.apache.logging.log4j.core.script.ScriptManager: org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner getScriptRunner(org.apache.logging.log4j.core.script.AbstractScript)>(v);
v = interfaceinvoke v.<org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner: javax.script.Bindings createBindings()>();
return v;
}
public org.apache.logging.log4j.core.script.AbstractScript getScript(java.lang.String)
{
org.apache.logging.log4j.core.script.ScriptManager v;
org.apache.logging.log4j.core.script.AbstractScript v;
java.lang.Object v;
java.lang.String v;
java.util.concurrent.ConcurrentMap v;
v := @this: org.apache.logging.log4j.core.script.ScriptManager;
v := @parameter: java.lang.String;
v = v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.concurrent.ConcurrentMap scriptRunners>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = interfaceinvoke v.<org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner: org.apache.logging.log4j.core.script.AbstractScript getScript()>();
goto label;
label:
v = null;
label:
return v;
}
public void fileModified(java.io.File)
{
org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner v;
java.util.concurrent.ConcurrentMap v, v, v;
org.apache.logging.log4j.core.script.ScriptManager v;
java.lang.String v, v, v, v;
org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner v;
org.apache.logging.log4j.core.script.AbstractScript v;
javax.script.ScriptEngineFactory v;
java.io.File v;
org.apache.logging.log4j.Logger v;
javax.script.ScriptEngine v;
java.lang.Object v, v;
v := @this: org.apache.logging.log4j.core.script.ScriptManager;
v := @parameter: java.io.File;
v = v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.concurrent.ConcurrentMap scriptRunners>;
v = virtualinvoke v.<java.io.File: java.lang.String toString()>();
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = <org.apache.logging.log4j.core.script.ScriptManager: org.apache.logging.log4j.Logger logger>;
v = virtualinvoke v.<java.io.File: java.lang.String getName()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void info(java.lang.String,java.lang.Object)>("{} is not a running script", v);
return;
label:
v = interfaceinvoke v.<org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner: javax.script.ScriptEngine getScriptEngine()>();
v = interfaceinvoke v.<org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner: org.apache.logging.log4j.core.script.AbstractScript getScript()>();
v = interfaceinvoke v.<javax.script.ScriptEngine: javax.script.ScriptEngineFactory getFactory()>();
v = interfaceinvoke v.<javax.script.ScriptEngineFactory: java.lang.Object getParameter(java.lang.String)>("THREADING");
if v != null goto label;
v = v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.concurrent.ConcurrentMap scriptRunners>;
v = virtualinvoke v.<org.apache.logging.log4j.core.script.AbstractScript: java.lang.String getName()>();
v = new org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner;
specialinvoke v.<org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner: void <init>(org.apache.logging.log4j.core.script.ScriptManager,org.apache.logging.log4j.core.script.AbstractScript)>(v, v);
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.concurrent.ConcurrentMap scriptRunners>;
v = virtualinvoke v.<org.apache.logging.log4j.core.script.AbstractScript: java.lang.String getName()>();
v = new org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner;
specialinvoke v.<org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner: void <init>(org.apache.logging.log4j.core.script.ScriptManager,javax.script.ScriptEngine,org.apache.logging.log4j.core.script.AbstractScript)>(v, v, v);
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
return;
}
public java.lang.Object execute(java.lang.String, javax.script.Bindings)
{
javax.script.Bindings v;
java.security.PrivilegedAction v;
java.util.concurrent.ConcurrentMap v;
org.apache.logging.log4j.Logger v;
org.apache.logging.log4j.core.script.ScriptManager v;
java.lang.Object v, v;
java.lang.String v;
v := @this: org.apache.logging.log4j.core.script.ScriptManager;
v := @parameter: java.lang.String;
v := @parameter: javax.script.Bindings;
v = v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.concurrent.ConcurrentMap scriptRunners>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = <org.apache.logging.log4j.core.script.ScriptManager: org.apache.logging.log4j.Logger logger>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Object)>("No script named {} could be found", v);
return null;
label:
v = staticinvoke <org.apache.logging.log4j.core.script.ScriptManager$lambda_execute_0__1271: java.security.PrivilegedAction bootstrap$(org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner,javax.script.Bindings)>(v, v);
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedAction)>(v);
return v;
}
private org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner getScriptRunner(org.apache.logging.log4j.core.script.AbstractScript)
{
org.apache.logging.log4j.core.script.ScriptManager v;
org.apache.logging.log4j.core.script.AbstractScript v;
java.lang.Object v;
java.lang.String v;
java.util.concurrent.ConcurrentMap v;
v := @this: org.apache.logging.log4j.core.script.ScriptManager;
v := @parameter: org.apache.logging.log4j.core.script.AbstractScript;
v = v.<org.apache.logging.log4j.core.script.ScriptManager: java.util.concurrent.ConcurrentMap scriptRunners>;
v = virtualinvoke v.<org.apache.logging.log4j.core.script.AbstractScript: java.lang.String getName()>();
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
return v;
}
static void <clinit>()
{
org.apache.logging.log4j.status.StatusLogger v;
v = staticinvoke <org.apache.logging.log4j.status.StatusLogger: org.apache.logging.log4j.status.StatusLogger getLogger()>();
<org.apache.logging.log4j.core.script.ScriptManager: org.apache.logging.log4j.Logger logger> = v;
return;
}
}