public final class org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender extends org.apache.logging.log4j.core.appender.AbstractAppender
{
private static final java.lang.String[] KAFKA_CLIENT_PACKAGES;
private final java.lang.Integer retryCount;
private final org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager manager;
public static org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender createAppender(org.apache.logging.log4j.core.Layout, org.apache.logging.log4j.core.Filter, java.lang.String, boolean, java.lang.String, org.apache.logging.log4j.core.config.Property[], org.apache.logging.log4j.core.config.Configuration, java.lang.String)
{
org.apache.logging.log4j.core.Filter v;
org.apache.logging.log4j.core.LoggerContext v;
org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender v;
org.apache.logging.log4j.core.config.Property[] v;
org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager v;
org.apache.logging.log4j.core.config.Configuration v;
org.apache.logging.log4j.Logger v;
java.lang.String v, v, v;
org.apache.logging.log4j.core.Layout v;
boolean v;
v := @parameter: org.apache.logging.log4j.core.Layout;
v := @parameter: org.apache.logging.log4j.core.Filter;
v := @parameter: java.lang.String;
v := @parameter: boolean;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.config.Property[];
v := @parameter: org.apache.logging.log4j.core.config.Configuration;
v := @parameter: java.lang.String;
if v != null goto label;
v = <org.apache.logging.log4j.core.AbstractLifeCycle: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String)>("No layout provided for KafkaAppender");
return null;
label:
v = interfaceinvoke v.<org.apache.logging.log4j.core.config.Configuration: org.apache.logging.log4j.core.LoggerContext getLoggerContext()>();
v = staticinvoke <org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager: org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager getManager(org.apache.logging.log4j.core.LoggerContext,java.lang.String,java.lang.String,boolean,org.apache.logging.log4j.core.config.Property[],java.lang.String)>(v, v, v, 1, v, v);
v = new org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender;
specialinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: void <init>(java.lang.String,org.apache.logging.log4j.core.Layout,org.apache.logging.log4j.core.Filter,boolean,org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager,org.apache.logging.log4j.core.config.Property[],int)>(v, v, v, v, v, null, 0);
return v;
}
private static boolean isRecursive(org.apache.logging.log4j.core.LogEvent)
{
java.util.stream.Stream v;
java.util.function.Predicate v;
java.lang.String[] v;
org.apache.logging.log4j.core.LogEvent v;
boolean v;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
v = <org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: java.lang.String[] KAFKA_CLIENT_PACKAGES>;
v = staticinvoke <java.util.stream.Stream: java.util.stream.Stream of(java.lang.Object[])>(v);
v = staticinvoke <org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender$lambda_isRecursive_0__1106: java.util.function.Predicate bootstrap$(org.apache.logging.log4j.core.LogEvent)>(v);
v = interfaceinvoke v.<java.util.stream.Stream: boolean anyMatch(java.util.function.Predicate)>(v);
return v;
}
public static org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender$Builder newBuilder()
{
org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender$Builder v;
org.apache.logging.log4j.core.filter.AbstractFilterable$Builder v;
v = new org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender$Builder;
specialinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender$Builder: void <init>()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender$Builder: org.apache.logging.log4j.core.filter.AbstractFilterable$Builder asBuilder()>();
return v;
}
private void <init>(java.lang.String, org.apache.logging.log4j.core.Layout, org.apache.logging.log4j.core.Filter, boolean, org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager, org.apache.logging.log4j.core.config.Property[], int)
{
org.apache.logging.log4j.core.Filter v;
org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender v;
org.apache.logging.log4j.core.config.Property[] v;
org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager v;
java.lang.Integer v;
int v;
java.lang.Object v;
java.lang.String v;
org.apache.logging.log4j.core.Layout v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.Layout;
v := @parameter: org.apache.logging.log4j.core.Filter;
v := @parameter: boolean;
v := @parameter: org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager;
v := @parameter: org.apache.logging.log4j.core.config.Property[];
v := @parameter: int;
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, v, v, v);
v = staticinvoke <java.util.Objects: java.lang.Object requireNonNull(java.lang.Object,java.lang.String)>(v, "manager");
v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager manager> = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: java.lang.Integer retryCount> = v;
return;
}
public void append(org.apache.logging.log4j.core.LogEvent)
{
org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender v;
java.lang.Integer v, v;
org.apache.logging.log4j.core.LogEvent v;
java.lang.Exception v, v;
org.apache.logging.log4j.Logger v;
int v, v;
java.lang.String v, v, v, v, v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: java.lang.String getLoggerName()>();
if v == null goto label;
v = staticinvoke <org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: boolean isRecursive(org.apache.logging.log4j.core.LogEvent)>(v);
if v == 0 goto label;
v = <org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: java.lang.String getLoggerName()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: java.lang.String getName()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("Recursive logging from [{}] for appender [{}].", v, v);
goto label;
label:
specialinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: void tryAppend(org.apache.logging.log4j.core.LogEvent)>(v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: java.lang.Integer retryCount>;
if v == null goto label;
v = 0;
label:
v = v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: java.lang.Integer retryCount>;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
if v >= v goto label;
v = v + 1;
label:
specialinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: void tryAppend(org.apache.logging.log4j.core.LogEvent)>(v);
label:
goto label;
label:
v := @caughtexception;
goto label;
label:
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: 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[])>("Unable to write to Kafka in appender [\u]");
virtualinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: void error(java.lang.String,org.apache.logging.log4j.core.LogEvent,java.lang.Throwable)>(v, v, v);
label:
return;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
public void start()
{
org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager v;
org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender v;
v := @this: org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender;
specialinvoke v.<org.apache.logging.log4j.core.appender.AbstractAppender: void start()>();
v = v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager manager>;
virtualinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager: void startup()>();
return;
}
public boolean stop(long, java.util.concurrent.TimeUnit)
{
java.util.concurrent.TimeUnit v;
org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender v;
org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager v;
long v;
boolean v, v, v;
v := @this: org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender;
v := @parameter: long;
v := @parameter: java.util.concurrent.TimeUnit;
virtualinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: void setStopping()>();
v = specialinvoke v.<org.apache.logging.log4j.core.appender.AbstractAppender: boolean stop(long,java.util.concurrent.TimeUnit,boolean)>(v, v, 0);
v = v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager manager>;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager: boolean stop(long,java.util.concurrent.TimeUnit)>(v, v);
v = v & v;
virtualinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: void setStopped()>();
return v;
}
public java.lang.String toString()
{
org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender v;
org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager v;
java.lang.String v, v, v;
org.apache.logging.log4j.core.LifeCycle$State v;
v := @this: org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: java.lang.String getName()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: org.apache.logging.log4j.core.LifeCycle$State getState()>();
v = v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager manager>;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager: java.lang.String getTopic()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,org.apache.logging.log4j.core.LifeCycle$State,java.lang.String)>(v, 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[])>("KafkaAppender{name=\u, state=\u, topic=\u0001}");
return v;
}
private void tryAppend(org.apache.logging.log4j.core.LogEvent) throws java.util.concurrent.ExecutionException, java.lang.InterruptedException, java.util.concurrent.TimeoutException
{
byte[] v, v, v;
org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender v;
long v;
org.apache.logging.log4j.core.LogEvent v;
java.lang.Long v;
int v, v, v, v, v, v;
boolean v;
org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager v;
org.apache.logging.log4j.core.Layout v;
v := @this: org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: org.apache.logging.log4j.core.Layout getLayout()>();
v = v instanceof org.apache.logging.log4j.core.layout.SerializedLayout;
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.logging.log4j.core.Layout: byte[] getHeader()>();
v = interfaceinvoke v.<org.apache.logging.log4j.core.Layout: byte[] toByteArray(org.apache.logging.log4j.core.LogEvent)>(v);
v = lengthof v;
v = lengthof v;
v = v + v;
v = newarray (byte)[v];
v = lengthof v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 0, v);
v = lengthof v;
v = lengthof v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, v, v);
goto label;
label:
v = interfaceinvoke v.<org.apache.logging.log4j.core.Layout: byte[] toByteArray(org.apache.logging.log4j.core.LogEvent)>(v);
label:
v = v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager manager>;
v = interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: long getTimeMillis()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
virtualinvoke v.<org.apache.logging.log4j.core.appender.mom.kafka.KafkaManager: void send(byte[],java.lang.Long)>(v, v);
return;
}
static void <clinit>()
{
java.lang.String[] v;
v = newarray (java.lang.String)[2];
v[0] = "org.apache.kafka.common";
v[1] = "org.apache.kafka.clients";
<org.apache.logging.log4j.core.appender.mom.kafka.KafkaAppender: java.lang.String[] KAFKA_CLIENT_PACKAGES> = v;
return;
}
}