public final class org.apache.zookeeper.audit.AuditHelper extends java.lang.Object
{
private static final org.slf4j.Logger LOG;
public void <init>()
{
org.apache.zookeeper.audit.AuditHelper v;
v := @this: org.apache.zookeeper.audit.AuditHelper;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static void addAuditLog(org.apache.zookeeper.server.Request, org.apache.zookeeper.server.DataTree$ProcessTxnResult)
{
org.apache.zookeeper.server.Request v;
org.apache.zookeeper.server.DataTree$ProcessTxnResult v;
v := @parameter: org.apache.zookeeper.server.Request;
v := @parameter: org.apache.zookeeper.server.DataTree$ProcessTxnResult;
staticinvoke <org.apache.zookeeper.audit.AuditHelper: void addAuditLog(org.apache.zookeeper.server.Request,org.apache.zookeeper.server.DataTree$ProcessTxnResult,boolean)>(v, v, 0);
return;
}
public static void addAuditLog(org.apache.zookeeper.server.Request, org.apache.zookeeper.server.DataTree$ProcessTxnResult, boolean)
{
java.lang.Throwable v;
java.lang.Integer v;
java.util.function.Supplier v, v, v, v;
int v, v;
java.lang.String v, v, v, v;
boolean v, v;
org.apache.zookeeper.server.DataTree$ProcessTxnResult v;
org.slf4j.Logger v;
org.apache.jute.Record v, v, v, v;
org.apache.zookeeper.server.Request v;
java.util.List v;
org.apache.zookeeper.audit.AuditEvent$Result v;
v := @parameter: org.apache.zookeeper.server.Request;
v := @parameter: org.apache.zookeeper.server.DataTree$ProcessTxnResult;
v := @parameter: boolean;
v = staticinvoke <org.apache.zookeeper.audit.ZKAuditProvider: boolean isAuditEnabled()>();
if v != 0 goto label;
return;
label:
v = v.<org.apache.zookeeper.server.DataTree$ProcessTxnResult: java.lang.String path>;
v = null;
v = null;
label:
v = v.<org.apache.zookeeper.server.Request: int type>;
tableswitch(v)
{
case 1: goto label;
case 2: goto label;
case 3: goto label;
case 4: goto label;
case 5: goto label;
case 6: goto label;
case 7: goto label;
case 8: goto label;
case 9: goto label;
case 10: goto label;
case 11: goto label;
case 12: goto label;
case 13: goto label;
case 14: goto label;
case 15: goto label;
case 16: goto label;
case 17: goto label;
case 18: goto label;
case 19: goto label;
case 20: goto label;
default: goto label;
};
label:
v = "create";
v = staticinvoke <org.apache.zookeeper.audit.AuditHelper$init__9: java.util.function.Supplier bootstrap$()>();
v = virtualinvoke v.<org.apache.zookeeper.server.Request: org.apache.jute.Record readRequestRecord(java.util.function.Supplier)>(v);
v = staticinvoke <org.apache.zookeeper.audit.AuditHelper: java.lang.String getCreateMode(org.apache.zookeeper.proto.CreateRequest)>(v);
if v == 0 goto label;
v = virtualinvoke v.<org.apache.zookeeper.proto.CreateRequest: java.lang.String getPath()>();
goto label;
label:
v = "delete";
if v == 0 goto label;
v = staticinvoke <org.apache.zookeeper.audit.AuditHelper$init__8: java.util.function.Supplier bootstrap$()>();
v = virtualinvoke v.<org.apache.zookeeper.server.Request: org.apache.jute.Record readRequestRecord(java.util.function.Supplier)>(v);
v = virtualinvoke v.<org.apache.zookeeper.proto.DeleteRequest: java.lang.String getPath()>();
goto label;
label:
v = "setData";
if v == 0 goto label;
v = staticinvoke <org.apache.zookeeper.audit.AuditHelper$init__7: java.util.function.Supplier bootstrap$()>();
v = virtualinvoke v.<org.apache.zookeeper.server.Request: org.apache.jute.Record readRequestRecord(java.util.function.Supplier)>(v);
v = virtualinvoke v.<org.apache.zookeeper.proto.SetDataRequest: java.lang.String getPath()>();
goto label;
label:
v = "setAcl";
v = staticinvoke <org.apache.zookeeper.audit.AuditHelper$init__6: java.util.function.Supplier bootstrap$()>();
v = virtualinvoke v.<org.apache.zookeeper.server.Request: org.apache.jute.Record readRequestRecord(java.util.function.Supplier)>(v);
v = virtualinvoke v.<org.apache.zookeeper.proto.SetACLRequest: java.util.List getAcl()>();
v = staticinvoke <org.apache.zookeeper.ZKUtil: java.lang.String aclToString(java.util.List)>(v);
if v == 0 goto label;
v = virtualinvoke v.<org.apache.zookeeper.proto.SetACLRequest: java.lang.String getPath()>();
goto label;
label:
if v == 0 goto label;
v = "multiOperation";
goto label;
label:
staticinvoke <org.apache.zookeeper.audit.AuditHelper: void logMultiOperation(org.apache.zookeeper.server.Request,org.apache.zookeeper.server.DataTree$ProcessTxnResult)>(v, v);
label:
return;
label:
v = "reconfig";
goto label;
label:
return;
label:
v = staticinvoke <org.apache.zookeeper.audit.AuditHelper: org.apache.zookeeper.audit.AuditEvent$Result getResult(org.apache.zookeeper.server.DataTree$ProcessTxnResult,boolean)>(v, v);
staticinvoke <org.apache.zookeeper.audit.AuditHelper: void log(org.apache.zookeeper.server.Request,java.lang.String,java.lang.String,java.lang.String,java.lang.String,org.apache.zookeeper.audit.AuditEvent$Result)>(v, v, v, v, v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.zookeeper.audit.AuditHelper: org.slf4j.Logger LOG>;
v = v.<org.apache.zookeeper.server.Request: int type>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object,java.lang.Object)>("Failed to audit log request {}", v, v);
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private static org.apache.zookeeper.audit.AuditEvent$Result getResult(org.apache.zookeeper.server.DataTree$ProcessTxnResult, boolean)
{
org.apache.zookeeper.KeeperException$Code v;
int v, v;
org.apache.zookeeper.audit.AuditEvent$Result v, v;
boolean v;
org.apache.zookeeper.server.DataTree$ProcessTxnResult v;
v := @parameter: org.apache.zookeeper.server.DataTree$ProcessTxnResult;
v := @parameter: boolean;
if v == 0 goto label;
v = <org.apache.zookeeper.audit.AuditEvent$Result: org.apache.zookeeper.audit.AuditEvent$Result FAILURE>;
return v;
label:
v = v.<org.apache.zookeeper.server.DataTree$ProcessTxnResult: int err>;
v = <org.apache.zookeeper.KeeperException$Code: org.apache.zookeeper.KeeperException$Code OK>;
v = virtualinvoke v.<org.apache.zookeeper.KeeperException$Code: int intValue()>();
if v != v goto label;
v = <org.apache.zookeeper.audit.AuditEvent$Result: org.apache.zookeeper.audit.AuditEvent$Result SUCCESS>;
goto label;
label:
v = <org.apache.zookeeper.audit.AuditEvent$Result: org.apache.zookeeper.audit.AuditEvent$Result FAILURE>;
label:
return v;
}
private static void logMultiOperation(org.apache.zookeeper.server.Request, org.apache.zookeeper.server.DataTree$ProcessTxnResult) throws java.io.IOException, org.apache.zookeeper.KeeperException
{
java.util.Map v;
int v;
java.lang.String v, v, v, v, v;
boolean v, v;
org.apache.zookeeper.server.DataTree$ProcessTxnResult v;
java.util.Iterator v;
org.apache.zookeeper.server.Request v;
java.util.List v;
java.lang.Object v, v;
org.apache.zookeeper.audit.AuditEvent$Result v, v, v, v;
v := @parameter: org.apache.zookeeper.server.Request;
v := @parameter: org.apache.zookeeper.server.DataTree$ProcessTxnResult;
v = staticinvoke <org.apache.zookeeper.audit.AuditHelper: java.util.Map getCreateModes(org.apache.zookeeper.server.Request)>(v);
v = 0;
v = v.<org.apache.zookeeper.server.DataTree$ProcessTxnResult: java.util.List multiResult>;
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.zookeeper.server.DataTree$ProcessTxnResult: int type>;
tableswitch(v)
{
case -1: goto label;
case 0: goto label;
case 1: goto label;
case 2: goto label;
case 3: goto label;
case 4: goto label;
case 5: goto label;
case 6: goto label;
case 7: goto label;
case 8: goto label;
case 9: goto label;
case 10: goto label;
case 11: goto label;
case 12: goto label;
case 13: goto label;
case 14: goto label;
case 15: goto label;
case 16: goto label;
case 17: goto label;
case 18: goto label;
case 19: goto label;
case 20: goto label;
case 21: goto label;
default: goto label;
};
label:
v = v.<org.apache.zookeeper.server.DataTree$ProcessTxnResult: java.lang.String path>;
v = v.<org.apache.zookeeper.server.DataTree$ProcessTxnResult: java.lang.String path>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = <org.apache.zookeeper.audit.AuditEvent$Result: org.apache.zookeeper.audit.AuditEvent$Result SUCCESS>;
staticinvoke <org.apache.zookeeper.audit.AuditHelper: void log(org.apache.zookeeper.server.Request,java.lang.String,java.lang.String,java.lang.String,java.lang.String,org.apache.zookeeper.audit.AuditEvent$Result)>(v, v, "create", null, v, v);
goto label;
label:
v = v.<org.apache.zookeeper.server.DataTree$ProcessTxnResult: java.lang.String path>;
v = <org.apache.zookeeper.audit.AuditEvent$Result: org.apache.zookeeper.audit.AuditEvent$Result SUCCESS>;
staticinvoke <org.apache.zookeeper.audit.AuditHelper: void log(org.apache.zookeeper.server.Request,java.lang.String,java.lang.String,java.lang.String,java.lang.String,org.apache.zookeeper.audit.AuditEvent$Result)>(v, v, "delete", null, null, v);
goto label;
label:
v = v.<org.apache.zookeeper.server.DataTree$ProcessTxnResult: java.lang.String path>;
v = <org.apache.zookeeper.audit.AuditEvent$Result: org.apache.zookeeper.audit.AuditEvent$Result SUCCESS>;
staticinvoke <org.apache.zookeeper.audit.AuditHelper: void log(org.apache.zookeeper.server.Request,java.lang.String,java.lang.String,java.lang.String,java.lang.String,org.apache.zookeeper.audit.AuditEvent$Result)>(v, v, "setData", null, null, v);
goto label;
label:
v = 1;
goto label;
label:
if v == 0 goto label;
v = v.<org.apache.zookeeper.server.DataTree$ProcessTxnResult: java.lang.String path>;
v = <org.apache.zookeeper.audit.AuditEvent$Result: org.apache.zookeeper.audit.AuditEvent$Result FAILURE>;
staticinvoke <org.apache.zookeeper.audit.AuditHelper: void log(org.apache.zookeeper.server.Request,java.lang.String,java.lang.String,java.lang.String,java.lang.String,org.apache.zookeeper.audit.AuditEvent$Result)>(v, v, "multiOperation", null, null, v);
label:
return;
}
private static void log(org.apache.zookeeper.server.Request, java.lang.String, java.lang.String, java.lang.String, java.lang.String, org.apache.zookeeper.audit.AuditEvent$Result)
{
org.apache.zookeeper.server.Request v;
org.apache.zookeeper.audit.AuditEvent$Result v;
org.apache.zookeeper.server.ServerCnxn v, v;
java.lang.String v, v, v, v, v, v, v;
v := @parameter: org.apache.zookeeper.server.Request;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: org.apache.zookeeper.audit.AuditEvent$Result;
v = virtualinvoke v.<org.apache.zookeeper.server.Request: java.lang.String getUsersForAudit()>();
v = v.<org.apache.zookeeper.server.Request: org.apache.zookeeper.server.ServerCnxn cnxn>;
v = virtualinvoke v.<org.apache.zookeeper.server.ServerCnxn: java.lang.String getSessionIdHex()>();
v = v.<org.apache.zookeeper.server.Request: org.apache.zookeeper.server.ServerCnxn cnxn>;
v = virtualinvoke v.<org.apache.zookeeper.server.ServerCnxn: java.lang.String getHostAddress()>();
staticinvoke <org.apache.zookeeper.audit.AuditHelper: void log(java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lang.String,org.apache.zookeeper.audit.AuditEvent$Result)>(v, v, v, v, v, v, v, v);
return;
}
private static void log(java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String, org.apache.zookeeper.audit.AuditEvent$Result)
{
org.apache.zookeeper.audit.AuditEvent$Result v;
java.lang.String v, v, 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.lang.String;
v := @parameter: java.lang.String;
v := @parameter: org.apache.zookeeper.audit.AuditEvent$Result;
staticinvoke <org.apache.zookeeper.audit.ZKAuditProvider: void log(java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lang.String,org.apache.zookeeper.audit.AuditEvent$Result)>(v, v, v, v, v, v, v, v);
return;
}
private static java.lang.String getCreateMode(org.apache.zookeeper.proto.CreateRequest) throws org.apache.zookeeper.KeeperException
{
org.apache.zookeeper.CreateMode v;
int v;
org.apache.zookeeper.proto.CreateRequest v;
java.lang.String v, v;
v := @parameter: org.apache.zookeeper.proto.CreateRequest;
v = virtualinvoke v.<org.apache.zookeeper.proto.CreateRequest: int getFlags()>();
v = staticinvoke <org.apache.zookeeper.CreateMode: org.apache.zookeeper.CreateMode fromFlag(int)>(v);
v = virtualinvoke v.<org.apache.zookeeper.CreateMode: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.String: java.lang.String toLowerCase()>();
return v;
}
private static java.util.Map getCreateModes(org.apache.zookeeper.server.Request) throws java.io.IOException, org.apache.zookeeper.KeeperException
{
java.util.Iterator v;
java.util.HashMap v;
org.apache.jute.Record v, v;
java.util.function.Supplier v;
org.apache.zookeeper.server.Request v;
int v, v, v;
java.lang.Object v;
java.lang.String v, v;
boolean v, v;
v := @parameter: org.apache.zookeeper.server.Request;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = staticinvoke <org.apache.zookeeper.audit.ZKAuditProvider: boolean isAuditEnabled()>();
if v != 0 goto label;
return v;
label:
v = staticinvoke <org.apache.zookeeper.audit.AuditHelper$init__10: java.util.function.Supplier bootstrap$()>();
v = virtualinvoke v.<org.apache.zookeeper.server.Request: org.apache.jute.Record readRequestRecord(java.util.function.Supplier)>(v);
v = virtualinvoke v.<org.apache.zookeeper.MultiOperationRecord: 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 = virtualinvoke v.<org.apache.zookeeper.Op: int getType()>();
if v == 1 goto label;
v = virtualinvoke v.<org.apache.zookeeper.Op: int getType()>();
if v == 15 goto label;
v = virtualinvoke v.<org.apache.zookeeper.Op: int getType()>();
if v != 19 goto label;
label:
v = virtualinvoke v.<org.apache.zookeeper.Op: org.apache.jute.Record toRequestRecord()>();
v = virtualinvoke v.<org.apache.zookeeper.proto.CreateRequest: java.lang.String getPath()>();
v = staticinvoke <org.apache.zookeeper.audit.AuditHelper: java.lang.String getCreateMode(org.apache.zookeeper.proto.CreateRequest)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/zookeeper/audit/AuditHelper;");
<org.apache.zookeeper.audit.AuditHelper: org.slf4j.Logger LOG> = v;
return;
}
}