public final class org.apache.logging.log4j.core.appender.FailoverAppender extends org.apache.logging.log4j.core.appender.AbstractAppender
{
private static final int DEFAULT_INTERVAL_SECONDS;
private final java.lang.String primaryRef;
private final java.lang.String[] failovers;
private final org.apache.logging.log4j.core.config.Configuration config;
private org.apache.logging.log4j.core.config.AppenderControl primary;
private final java.util.List failoverAppenders;
private final long intervalNanos;
private volatile long nextCheckNanos;
private void <init>(java.lang.String, org.apache.logging.log4j.core.Filter, java.lang.String, java.lang.String[], int, org.apache.logging.log4j.core.config.Configuration, boolean, org.apache.logging.log4j.core.config.Property[])
{
org.apache.logging.log4j.core.Filter v;
org.apache.logging.log4j.core.config.Property[] v;
java.lang.String[] v;
long v;
java.util.ArrayList v;
org.apache.logging.log4j.core.config.Configuration v;
java.util.concurrent.TimeUnit v;
int v;
org.apache.logging.log4j.core.appender.FailoverAppender v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.FailoverAppender;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.Filter;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String[];
v := @parameter: int;
v := @parameter: org.apache.logging.log4j.core.config.Configuration;
v := @parameter: boolean;
v := @parameter: org.apache.logging.log4j.core.config.Property[];
specialinvoke v.<org.apache.logging.log4j.core.appender.AbstractAppender: void <init>(java.lang.String,org.apache.logging.log4j.core.Filter,org.apache.logging.log4j.core.Layout,boolean,org.apache.logging.log4j.core.config.Property[])>(v, v, null, v, v);
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.apache.logging.log4j.core.appender.FailoverAppender: java.util.List failoverAppenders> = v;
v.<org.apache.logging.log4j.core.appender.FailoverAppender: java.lang.String primaryRef> = v;
v.<org.apache.logging.log4j.core.appender.FailoverAppender: java.lang.String[] failovers> = v;
v.<org.apache.logging.log4j.core.appender.FailoverAppender: org.apache.logging.log4j.core.config.Configuration config> = v;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = virtualinvoke v.<java.util.concurrent.TimeUnit: long toNanos(long)>(v);
v.<org.apache.logging.log4j.core.appender.FailoverAppender: long intervalNanos> = v;
return;
}
public void start()
{
java.lang.String[] v;
org.apache.logging.log4j.core.config.Configuration v;
java.util.Map v;
int v, v, v;
org.apache.logging.log4j.core.appender.FailoverAppender v;
java.lang.String v, v, v, v, v;
boolean v;
org.apache.logging.log4j.core.config.AppenderControl v, v;
java.util.List v, v;
org.apache.logging.log4j.Logger v, v, v;
java.lang.Object v, v;
v := @this: org.apache.logging.log4j.core.appender.FailoverAppender;
v = v.<org.apache.logging.log4j.core.appender.FailoverAppender: org.apache.logging.log4j.core.config.Configuration config>;
v = interfaceinvoke v.<org.apache.logging.log4j.core.config.Configuration: java.util.Map getAppenders()>();
v = 0;
v = v.<org.apache.logging.log4j.core.appender.FailoverAppender: java.lang.String primaryRef>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = new org.apache.logging.log4j.core.config.AppenderControl;
specialinvoke v.<org.apache.logging.log4j.core.config.AppenderControl: void <init>(org.apache.logging.log4j.core.Appender,org.apache.logging.log4j.Level,org.apache.logging.log4j.core.Filter)>(v, null, null);
v.<org.apache.logging.log4j.core.appender.FailoverAppender: org.apache.logging.log4j.core.config.AppenderControl primary> = v;
goto label;
label:
v = <org.apache.logging.log4j.core.appender.FailoverAppender: org.apache.logging.log4j.Logger LOGGER>;
v = v.<org.apache.logging.log4j.core.appender.FailoverAppender: java.lang.String primaryRef>;
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[])>("Unable to locate primary Appender \u0001");
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String)>(v);
v = 1;
label:
v = v.<org.apache.logging.log4j.core.appender.FailoverAppender: java.lang.String[] failovers>;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = v.<org.apache.logging.log4j.core.appender.FailoverAppender: java.util.List failoverAppenders>;
v = new org.apache.logging.log4j.core.config.AppenderControl;
specialinvoke v.<org.apache.logging.log4j.core.config.AppenderControl: void <init>(org.apache.logging.log4j.core.Appender,org.apache.logging.log4j.Level,org.apache.logging.log4j.core.Filter)>(v, null, null);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = <org.apache.logging.log4j.core.appender.FailoverAppender: org.apache.logging.log4j.Logger LOGGER>;
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[])>("Failover appender \u is not configured");
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String)>(v);
label:
v = v + 1;
goto label;
label:
v = v.<org.apache.logging.log4j.core.appender.FailoverAppender: java.util.List failoverAppenders>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
v = <org.apache.logging.log4j.core.appender.FailoverAppender: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String)>("No failover appenders are available");
v = v + 1;
label:
if v != 0 goto label;
specialinvoke v.<org.apache.logging.log4j.core.appender.AbstractAppender: void start()>();
label:
return;
}
public void append(org.apache.logging.log4j.core.LogEvent)
{
long v, v, v;
org.apache.logging.log4j.core.LogEvent v;
byte v, v;
org.apache.logging.log4j.core.appender.FailoverAppender v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.FailoverAppender;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.FailoverAppender: boolean isStarted()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.FailoverAppender: 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[])>("FailoverAppender \u did not start successfully");
virtualinvoke v.<org.apache.logging.log4j.core.appender.FailoverAppender: void error(java.lang.String)>(v);
return;
label:
v = v.<org.apache.logging.log4j.core.appender.FailoverAppender: long nextCheckNanos>;
v = v cmp 0L;
if v == 0 goto label;
v = staticinvoke <java.lang.System: long nanoTime()>();
v = v - v;
v = v cmp 0L;
if v <= 0 goto label;
label:
specialinvoke v.<org.apache.logging.log4j.core.appender.FailoverAppender: void callAppender(org.apache.logging.log4j.core.LogEvent)>(v);
goto label;
label:
specialinvoke v.<org.apache.logging.log4j.core.appender.FailoverAppender: void failover(org.apache.logging.log4j.core.LogEvent,java.lang.Exception)>(v, null);
label:
return;
}
private void callAppender(org.apache.logging.log4j.core.LogEvent)
{
org.apache.logging.log4j.core.config.AppenderControl v;
long v, v, v;
org.apache.logging.log4j.core.appender.FailoverAppender v;
org.apache.logging.log4j.core.LogEvent v;
java.lang.Exception v;
v := @this: org.apache.logging.log4j.core.appender.FailoverAppender;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
label:
v = v.<org.apache.logging.log4j.core.appender.FailoverAppender: org.apache.logging.log4j.core.config.AppenderControl primary>;
virtualinvoke v.<org.apache.logging.log4j.core.config.AppenderControl: void callAppender(org.apache.logging.log4j.core.LogEvent)>(v);
v.<org.apache.logging.log4j.core.appender.FailoverAppender: long nextCheckNanos> = 0L;
label:
goto label;
label:
v := @caughtexception;
v = staticinvoke <java.lang.System: long nanoTime()>();
v = v.<org.apache.logging.log4j.core.appender.FailoverAppender: long intervalNanos>;
v = v + v;
v.<org.apache.logging.log4j.core.appender.FailoverAppender: long nextCheckNanos> = v;
specialinvoke v.<org.apache.logging.log4j.core.appender.FailoverAppender: void failover(org.apache.logging.log4j.core.LogEvent,java.lang.Exception)>(v, v);
label:
return;
catch java.lang.Exception from label to label with label;
}
private void failover(org.apache.logging.log4j.core.LogEvent, java.lang.Exception)
{
org.apache.logging.log4j.LoggingException v, v;
java.util.Iterator v;
org.apache.logging.log4j.core.LogEvent v;
java.lang.Exception v, v, v;
java.util.List v;
java.lang.Object v;
org.apache.logging.log4j.core.appender.FailoverAppender v;
boolean v, v, v, v;
v := @this: org.apache.logging.log4j.core.appender.FailoverAppender;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
v := @parameter: java.lang.Exception;
if v == null goto label;
v = v instanceof org.apache.logging.log4j.LoggingException;
if v != 0 goto label;
v = new org.apache.logging.log4j.LoggingException;
specialinvoke v.<org.apache.logging.log4j.LoggingException: void <init>(java.lang.Throwable)>(v);
goto label;
label:
v = null;
label:
v = v;
v = 0;
v = null;
v = v.<org.apache.logging.log4j.core.appender.FailoverAppender: java.util.List failoverAppenders>;
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()>();
label:
virtualinvoke v.<org.apache.logging.log4j.core.config.AppenderControl: void callAppender(org.apache.logging.log4j.core.LogEvent)>(v);
v = 1;
label:
goto label;
label:
v := @caughtexception;
if v != null goto label;
v = v;
goto label;
label:
if v != 0 goto label;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.FailoverAppender: boolean ignoreExceptions()>();
if v != 0 goto label;
if v == null goto label;
throw v;
label:
v = new org.apache.logging.log4j.LoggingException;
specialinvoke v.<org.apache.logging.log4j.LoggingException: void <init>(java.lang.String,java.lang.Throwable)>("Unable to write to failover appenders", v);
throw v;
label:
return;
catch java.lang.Exception from label to label with label;
}
public java.lang.String toString()
{
org.apache.logging.log4j.core.config.AppenderControl v;
java.lang.String[] v;
int v, v;
java.lang.StringBuilder v, v, v;
org.apache.logging.log4j.core.appender.FailoverAppender v;
java.lang.String v, v, v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.FailoverAppender;
v = new java.lang.StringBuilder;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.FailoverAppender: java.lang.String getName()>();
specialinvoke v.<java.lang.StringBuilder: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(" primary=");
v = v.<org.apache.logging.log4j.core.appender.FailoverAppender: org.apache.logging.log4j.core.config.AppenderControl primary>;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.Object)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", failover={");
v = 1;
v = v.<org.apache.logging.log4j.core.appender.FailoverAppender: java.lang.String[] failovers>;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
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);
v = 0;
v = v + 1;
goto label;
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(125);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
return v;
}
public static org.apache.logging.log4j.core.appender.FailoverAppender createAppender(java.lang.String, java.lang.String, java.lang.String[], java.lang.String, org.apache.logging.log4j.core.config.Configuration, org.apache.logging.log4j.core.Filter, java.lang.String)
{
java.lang.String[] v;
org.apache.logging.log4j.core.config.Configuration v;
int v, v, v, v;
org.apache.logging.log4j.core.appender.FailoverAppender v;
java.lang.String v, v, v, v, v;
boolean v;
org.apache.logging.log4j.core.Filter v;
org.apache.logging.log4j.Logger 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: org.apache.logging.log4j.core.config.Configuration;
v := @parameter: org.apache.logging.log4j.core.Filter;
v := @parameter: java.lang.String;
if v != null goto label;
v = <org.apache.logging.log4j.core.appender.FailoverAppender: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String)>("A name for the Appender must be specified");
return null;
label:
if v != null goto label;
v = <org.apache.logging.log4j.core.appender.FailoverAppender: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String)>("A primary Appender must be specified");
return null;
label:
if v == null goto label;
v = lengthof v;
if v != 0 goto label;
label:
v = <org.apache.logging.log4j.core.appender.FailoverAppender: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String)>("At least one failover Appender must be specified");
return null;
label:
v = staticinvoke <org.apache.logging.log4j.core.appender.FailoverAppender: int parseInt(java.lang.String,int)>(v, 60);
if v < 0 goto label;
v = v * 1000;
goto label;
label:
v = <org.apache.logging.log4j.core.appender.FailoverAppender: org.apache.logging.log4j.Logger LOGGER>;
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[])>("Interval \u is less than zero. Using default");
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String)>(v);
v = (int) 60000;
v = v;
label:
v = staticinvoke <org.apache.logging.log4j.core.util.Booleans: boolean parseBoolean(java.lang.String,boolean)>(v, 1);
v = new org.apache.logging.log4j.core.appender.FailoverAppender;
specialinvoke v.<org.apache.logging.log4j.core.appender.FailoverAppender: void <init>(java.lang.String,org.apache.logging.log4j.core.Filter,java.lang.String,java.lang.String[],int,org.apache.logging.log4j.core.config.Configuration,boolean,org.apache.logging.log4j.core.config.Property[])>(v, v, v, v, v, v, v, null);
return v;
}
}