public class oadd.org.apache.zookeeper.server.NIOServerCnxn extends oadd.org.apache.zookeeper.server.ServerCnxn
{
private static final org.slf4j.Logger LOG;
private final oadd.org.apache.zookeeper.server.NIOServerCnxnFactory factory;
private final java.nio.channels.SocketChannel sock;
private final oadd.org.apache.zookeeper.server.NIOServerCnxnFactory$SelectorThread selectorThread;
private final java.nio.channels.SelectionKey sk;
private boolean initialized;
private final java.nio.ByteBuffer lenBuffer;
private java.nio.ByteBuffer incomingBuffer;
private final java.util.Queue outgoingBuffers;
private int sessionTimeout;
private final oadd.org.apache.zookeeper.server.ZooKeeperServer zkServer;
private final java.util.concurrent.atomic.AtomicInteger outstandingRequests;
private long sessionId;
private final int outstandingLimit;
private final java.util.concurrent.atomic.AtomicBoolean selectable;
private final java.util.concurrent.atomic.AtomicBoolean throttled;
public void <init>(oadd.org.apache.zookeeper.server.ZooKeeperServer, java.nio.channels.SocketChannel, java.nio.channels.SelectionKey, oadd.org.apache.zookeeper.server.NIOServerCnxnFactory, oadd.org.apache.zookeeper.server.NIOServerCnxnFactory$SelectorThread) throws java.io.IOException
{
java.net.Socket v, v, v;
java.net.SocketAddress v;
oadd.org.apache.zookeeper.server.NIOServerCnxnFactory v, v;
java.util.concurrent.atomic.AtomicBoolean v, v;
oadd.org.apache.zookeeper.server.ZooKeeperServer v;
java.nio.ByteBuffer v, v;
java.util.ArrayList v;
java.net.InetAddress v;
java.nio.channels.SocketChannel v;
java.util.concurrent.atomic.AtomicInteger v;
int v, v, v;
java.lang.String v;
oadd.org.apache.zookeeper.server.ZooKeeperSaslServer v;
oadd.org.apache.zookeeper.data.Id v;
java.nio.channels.SelectionKey v;
oadd.org.apache.zookeeper.Login v, v;
java.util.concurrent.LinkedBlockingQueue v;
oadd.org.apache.zookeeper.server.NIOServerCnxnFactory$SelectorThread v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v := @parameter: oadd.org.apache.zookeeper.server.ZooKeeperServer;
v := @parameter: java.nio.channels.SocketChannel;
v := @parameter: java.nio.channels.SelectionKey;
v := @parameter: oadd.org.apache.zookeeper.server.NIOServerCnxnFactory;
v := @parameter: oadd.org.apache.zookeeper.server.NIOServerCnxnFactory$SelectorThread;
specialinvoke v.<oadd.org.apache.zookeeper.server.ServerCnxn: void <init>()>();
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer allocate(int)>(4);
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer lenBuffer> = v;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer lenBuffer>;
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer> = v;
v = new java.util.concurrent.LinkedBlockingQueue;
specialinvoke v.<java.util.concurrent.LinkedBlockingQueue: void <init>()>();
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.Queue outgoingBuffers> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(0);
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.concurrent.atomic.AtomicInteger outstandingRequests> = v;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>(boolean)>(1);
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.concurrent.atomic.AtomicBoolean selectable> = v;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>(boolean)>(0);
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.concurrent.atomic.AtomicBoolean throttled> = v;
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.ZooKeeperServer zkServer> = v;
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock> = v;
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SelectionKey sk> = v;
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.NIOServerCnxnFactory factory> = v;
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.NIOServerCnxnFactory$SelectorThread selectorThread> = v;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.NIOServerCnxnFactory factory>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxnFactory: oadd.org.apache.zookeeper.Login login>;
if v == null goto label;
v = new oadd.org.apache.zookeeper.server.ZooKeeperSaslServer;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxnFactory: oadd.org.apache.zookeeper.Login login>;
specialinvoke v.<oadd.org.apache.zookeeper.server.ZooKeeperSaslServer: void <init>(oadd.org.apache.zookeeper.Login)>(v);
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.ZooKeeperSaslServer zooKeeperSaslServer> = v;
label:
if v == null goto label;
v = virtualinvoke v.<oadd.org.apache.zookeeper.server.ZooKeeperServer: int getGlobalOutstandingLimit()>();
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: int outstandingLimit> = v;
goto label;
label:
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: int outstandingLimit> = 1;
label:
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
virtualinvoke v.<java.net.Socket: void setTcpNoDelay(boolean)>(1);
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
v = (int) -1;
virtualinvoke v.<java.net.Socket: void setSoLinger(boolean,int)>(0, v);
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
v = virtualinvoke v.<java.net.Socket: java.net.SocketAddress getRemoteSocketAddress()>();
v = virtualinvoke v.<java.net.InetSocketAddress: java.net.InetAddress getAddress()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.ArrayList authInfo>;
v = new oadd.org.apache.zookeeper.data.Id;
v = virtualinvoke v.<java.net.InetAddress: java.lang.String getHostAddress()>();
specialinvoke v.<oadd.org.apache.zookeeper.data.Id: void <init>(java.lang.String,java.lang.String)>("ip", v);
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxnFactory: int sessionlessCnxnTimeout>;
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: int sessionTimeout> = v;
return;
}
public void sendCloseSession()
{
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
java.nio.ByteBuffer v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = <oadd.org.apache.zookeeper.server.ServerCnxnFactory: java.nio.ByteBuffer closeConn>;
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void sendBuffer(java.nio.ByteBuffer)>(v);
return;
}
void sendBufferSync(java.nio.ByteBuffer)
{
org.slf4j.Logger v;
java.io.IOException v;
java.nio.ByteBuffer v, v;
java.nio.channels.SocketChannel v, v, v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v := @parameter: java.nio.ByteBuffer;
label:
v = <oadd.org.apache.zookeeper.server.ServerCnxnFactory: java.nio.ByteBuffer closeConn>;
if v == v goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: boolean isOpen()>();
if v == 0 goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
virtualinvoke v.<java.nio.channels.SocketChannel: java.nio.channels.SelectableChannel configureBlocking(boolean)>(1);
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
virtualinvoke v.<java.nio.channels.SocketChannel: int write(java.nio.ByteBuffer)>(v);
label:
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void packetSent()>();
label:
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Error sending data synchronously ", v);
label:
return;
catch java.io.IOException from label to label with label;
}
public void sendBuffer(java.nio.ByteBuffer)
{
org.slf4j.Logger v, v;
java.nio.channels.SelectionKey v, v;
java.nio.ByteBuffer v;
java.lang.String v;
java.util.Queue v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v, v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v := @parameter: java.nio.ByteBuffer;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SelectionKey sk>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SelectionKey sk>;
v = virtualinvoke v.<java.nio.channels.SelectionKey: boolean isValid()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.nio.channels.SelectionKey,boolean)>(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[])>("Add a buffer to outgoingBuffers, sk \u is valid: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>(v);
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.Queue outgoingBuffers>;
interfaceinvoke v.<java.util.Queue: boolean add(java.lang.Object)>(v);
specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void requestInterestOpsUpdate()>();
return;
}
private void readPayload() throws java.io.IOException, java.lang.InterruptedException
{
oadd.org.apache.zookeeper.server.ServerCnxn$EndOfStreamException v;
long v;
java.nio.ByteBuffer v, v, v, v, v, v;
java.nio.channels.SocketChannel v;
int v, v, v;
java.lang.String v, v;
boolean v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
if v == 0 goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: int read(java.nio.ByteBuffer)>(v);
if v >= 0 goto label;
v = new oadd.org.apache.zookeeper.server.ServerCnxn$EndOfStreamException;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: long sessionId>;
v = staticinvoke <java.lang.Long: java.lang.String toHexString(long)>(v);
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 read additional data from client sessionid 0x\u, likely client has closed socket");
specialinvoke v.<oadd.org.apache.zookeeper.server.ServerCnxn$EndOfStreamException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
if v != 0 goto label;
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void packetReceived()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer flip()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean initialized>;
if v != 0 goto label;
specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void readConnectRequest()>();
goto label;
label:
specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void readRequest()>();
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer lenBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer clear()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer lenBuffer>;
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer> = v;
label:
return;
}
public boolean isSelectable()
{
java.nio.channels.SelectionKey v;
java.util.concurrent.atomic.AtomicBoolean v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v, v, v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SelectionKey sk>;
v = virtualinvoke v.<java.nio.channels.SelectionKey: boolean isValid()>();
if v == 0 goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.concurrent.atomic.AtomicBoolean selectable>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public void disableSelectable()
{
java.util.concurrent.atomic.AtomicBoolean v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.concurrent.atomic.AtomicBoolean selectable>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void set(boolean)>(0);
return;
}
public void enableSelectable()
{
java.util.concurrent.atomic.AtomicBoolean v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.concurrent.atomic.AtomicBoolean selectable>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void set(boolean)>(1);
return;
}
private void requestInterestOpsUpdate()
{
java.nio.channels.SelectionKey v;
oadd.org.apache.zookeeper.server.NIOServerCnxnFactory$SelectorThread v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean isSelectable()>();
if v == 0 goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.NIOServerCnxnFactory$SelectorThread selectorThread>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SelectionKey sk>;
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxnFactory$SelectorThread: boolean addInterestOpsUpdateRequest(java.nio.channels.SelectionKey)>(v);
label:
return;
}
void handleWrite(java.nio.channels.SelectionKey) throws java.io.IOException, oadd.org.apache.zookeeper.server.ServerCnxn$CloseRequestException
{
java.nio.ByteBuffer v, v, v, v;
java.nio.channels.SocketChannel v, v;
oadd.org.apache.zookeeper.server.ServerCnxn$CloseRequestException v, v;
boolean v, v;
java.nio.ByteBuffer[] v;
java.util.Queue v, v, v, v, v, v, v, v;
java.lang.Object[] v;
int v, v, v, v, v, v, v, v, v, v, v, v;
java.util.Iterator v;
java.nio.channels.SelectionKey v;
java.lang.Object v, v, v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v := @parameter: java.nio.channels.SelectionKey;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.Queue outgoingBuffers>;
v = interfaceinvoke v.<java.util.Queue: boolean isEmpty()>();
if v == 0 goto label;
return;
label:
v = staticinvoke <oadd.org.apache.zookeeper.server.NIOServerCnxnFactory: java.nio.ByteBuffer getDirectBuffer()>();
if v != null goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.Queue outgoingBuffers>;
v = interfaceinvoke v.<java.util.Queue: int size()>();
v = newarray (java.nio.ByteBuffer)[v];
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.Queue outgoingBuffers>;
v = interfaceinvoke v.<java.util.Queue: java.lang.Object[] toArray(java.lang.Object[])>(v);
virtualinvoke v.<java.nio.channels.SocketChannel: long write(java.nio.ByteBuffer[])>(v);
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.Queue outgoingBuffers>;
v = interfaceinvoke v.<java.util.Queue: java.lang.Object peek()>();
if v == null goto label;
v = <oadd.org.apache.zookeeper.server.ServerCnxnFactory: java.nio.ByteBuffer closeConn>;
if v != v goto label;
v = new oadd.org.apache.zookeeper.server.ServerCnxn$CloseRequestException;
specialinvoke v.<oadd.org.apache.zookeeper.server.ServerCnxn$CloseRequestException: void <init>(java.lang.String)>("close requested");
throw v;
label:
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
if v > 0 goto label;
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void packetSent()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.Queue outgoingBuffers>;
interfaceinvoke v.<java.util.Queue: java.lang.Object remove()>();
goto label;
label:
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer clear()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.Queue outgoingBuffers>;
v = interfaceinvoke v.<java.util.Queue: 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.<java.nio.ByteBuffer: int remaining()>();
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
if v >= v goto label;
v = virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer slice()>();
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer limit(int)>(v);
label:
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer put(java.nio.ByteBuffer)>(v);
virtualinvoke v.<java.nio.ByteBuffer: java.nio.Buffer position(int)>(v);
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
if v != 0 goto label;
label:
virtualinvoke v.<java.nio.ByteBuffer: java.nio.Buffer flip()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: int write(java.nio.ByteBuffer)>(v);
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.Queue outgoingBuffers>;
v = interfaceinvoke v.<java.util.Queue: java.lang.Object peek()>();
if v == null goto label;
v = <oadd.org.apache.zookeeper.server.ServerCnxnFactory: java.nio.ByteBuffer closeConn>;
if v != v goto label;
v = new oadd.org.apache.zookeeper.server.ServerCnxn$CloseRequestException;
specialinvoke v.<oadd.org.apache.zookeeper.server.ServerCnxn$CloseRequestException: void <init>(java.lang.String)>("close requested");
throw v;
label:
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
if v >= v goto label;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
v = v + v;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.Buffer position(int)>(v);
goto label;
label:
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void packetSent()>();
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
v = v - v;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.Queue outgoingBuffers>;
interfaceinvoke v.<java.util.Queue: java.lang.Object remove()>();
goto label;
label:
return;
}
protected boolean isSocketOpen()
{
java.nio.channels.SocketChannel v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: boolean isOpen()>();
return v;
}
void doIO(java.nio.channels.SelectionKey) throws java.lang.InterruptedException
{
oadd.org.apache.zookeeper.server.ServerCnxn$EndOfStreamException v, v;
java.nio.ByteBuffer v, v, v, v, v, v;
java.nio.channels.SocketChannel v;
oadd.org.apache.zookeeper.server.ServerCnxn$CloseRequestException v, v;
boolean v, v, v, v, v, v, v, v, v;
java.nio.channels.CancelledKeyException v;
long v, v, v, v;
int v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
org.slf4j.Logger v, v, v, v, v, v, v, v;
java.nio.channels.SelectionKey v;
java.io.IOException v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v := @parameter: java.nio.channels.SelectionKey;
label:
v = virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean isSocketOpen()>();
if v != 0 goto label;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: long sessionId>;
v = staticinvoke <java.lang.Long: java.lang.String toHexString(long)>(v);
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[])>("trying to do i/o on a null socket for session:0x\u0001");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
label:
return;
label:
v = virtualinvoke v.<java.nio.channels.SelectionKey: boolean isReadable()>();
if v == 0 goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: int read(java.nio.ByteBuffer)>(v);
if v >= 0 goto label;
v = new oadd.org.apache.zookeeper.server.ServerCnxn$EndOfStreamException;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: long sessionId>;
v = staticinvoke <java.lang.Long: java.lang.String toHexString(long)>(v);
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 read additional data from client sessionid 0x\u, likely client has closed socket");
specialinvoke v.<oadd.org.apache.zookeeper.server.ServerCnxn$EndOfStreamException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
if v != 0 goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer lenBuffer>;
if v != v goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer flip()>();
v = specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean readLength(java.nio.channels.SelectionKey)>(v);
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer clear()>();
goto label;
label:
v = 1;
label:
if v == 0 goto label;
specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void readPayload()>();
goto label;
label:
return;
label:
v = virtualinvoke v.<java.nio.channels.SelectionKey: boolean isWritable()>();
if v == 0 goto label;
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void handleWrite(java.nio.channels.SelectionKey)>(v);
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean initialized>;
if v != 0 goto label;
v = specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean getReadInterest()>();
if v != 0 goto label;
v = specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean getWriteInterest()>();
if v != 0 goto label;
v = new oadd.org.apache.zookeeper.server.ServerCnxn$CloseRequestException;
specialinvoke v.<oadd.org.apache.zookeeper.server.ServerCnxn$CloseRequestException: void <init>(java.lang.String)>("responded to info probe");
throw v;
label:
v := @caughtexception;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: long sessionId>;
v = staticinvoke <java.lang.Long: java.lang.String toHexString(long)>(v);
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[])>("CancelledKeyException causing close of session 0x\u0001");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>("CancelledKeyException stack trace", v);
label:
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void close()>();
goto label;
label:
v := @caughtexception;
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void close()>();
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = virtualinvoke v.<oadd.org.apache.zookeeper.server.ServerCnxn$EndOfStreamException: java.lang.String getMessage()>();
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void close()>();
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: long sessionId>;
v = staticinvoke <java.lang.Long: java.lang.String toHexString(long)>(v);
v = virtualinvoke v.<java.io.IOException: java.lang.String getMessage()>();
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[])>("Exception causing close of session 0x\u0001: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>("IOException stack trace", v);
label:
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void close()>();
label:
return;
catch java.nio.channels.CancelledKeyException from label to label with label;
catch java.nio.channels.CancelledKeyException from label to label with label;
catch java.nio.channels.CancelledKeyException from label to label with label;
catch oadd.org.apache.zookeeper.server.ServerCnxn$CloseRequestException from label to label with label;
catch oadd.org.apache.zookeeper.server.ServerCnxn$CloseRequestException from label to label with label;
catch oadd.org.apache.zookeeper.server.ServerCnxn$CloseRequestException from label to label with label;
catch oadd.org.apache.zookeeper.server.ServerCnxn$EndOfStreamException from label to label with label;
catch oadd.org.apache.zookeeper.server.ServerCnxn$EndOfStreamException from label to label with label;
catch oadd.org.apache.zookeeper.server.ServerCnxn$EndOfStreamException from label to label with label;
catch java.io.IOException from label to label with label;
catch java.io.IOException from label to label with label;
catch java.io.IOException from label to label with label;
}
private void readRequest() throws java.io.IOException
{
oadd.org.apache.zookeeper.server.ZooKeeperServer v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
java.nio.ByteBuffer v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.ZooKeeperServer zkServer>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
virtualinvoke v.<oadd.org.apache.zookeeper.server.ZooKeeperServer: void processPacket(oadd.org.apache.zookeeper.server.ServerCnxn,java.nio.ByteBuffer)>(v, v);
return;
}
protected void incrOutstandingRequests(oadd.org.apache.zookeeper.proto.RequestHeader)
{
org.slf4j.Logger v, v;
oadd.org.apache.zookeeper.server.ZooKeeperServer v;
oadd.org.apache.zookeeper.proto.RequestHeader v;
java.util.concurrent.atomic.AtomicInteger v;
int v, v, v;
java.lang.String v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v := @parameter: oadd.org.apache.zookeeper.proto.RequestHeader;
v = virtualinvoke v.<oadd.org.apache.zookeeper.proto.RequestHeader: int getXid()>();
if v < 0 goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.concurrent.atomic.AtomicInteger outstandingRequests>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.ZooKeeperServer zkServer>;
v = virtualinvoke v.<oadd.org.apache.zookeeper.server.ZooKeeperServer: int getInProcess()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: int outstandingLimit>;
if v <= v goto label;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("Throttling recv \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void disableRecv()>();
label:
return;
}
private boolean getWriteInterest()
{
java.util.Queue v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v, v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.Queue outgoingBuffers>;
v = interfaceinvoke v.<java.util.Queue: boolean isEmpty()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private boolean getReadInterest()
{
java.util.concurrent.atomic.AtomicBoolean v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v, v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.concurrent.atomic.AtomicBoolean throttled>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public void disableRecv()
{
java.util.concurrent.atomic.AtomicBoolean v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.concurrent.atomic.AtomicBoolean throttled>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean compareAndSet(boolean,boolean)>(0, 1);
if v == 0 goto label;
specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void requestInterestOpsUpdate()>();
label:
return;
}
public void enableRecv()
{
java.util.concurrent.atomic.AtomicBoolean v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.concurrent.atomic.AtomicBoolean throttled>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean compareAndSet(boolean,boolean)>(1, 0);
if v == 0 goto label;
specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void requestInterestOpsUpdate()>();
label:
return;
}
private void readConnectRequest() throws java.io.IOException, java.lang.InterruptedException
{
java.io.IOException v;
oadd.org.apache.zookeeper.server.ZooKeeperServer v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
java.nio.ByteBuffer v;
boolean v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean isZKServerRunning()>();
if v != 0 goto label;
v = new java.io.IOException;
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>("ZooKeeperServer not running");
throw v;
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.ZooKeeperServer zkServer>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
virtualinvoke v.<oadd.org.apache.zookeeper.server.ZooKeeperServer: void processConnectRequest(oadd.org.apache.zookeeper.server.ServerCnxn,java.nio.ByteBuffer)>(v, v);
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean initialized> = 1;
return;
}
private boolean checkFourLetterWord(java.nio.channels.SelectionKey, int) throws java.io.IOException
{
java.net.SocketAddress v;
oadd.org.apache.zookeeper.server.command.NopCommand v;
java.nio.ByteBuffer v, v, v, v;
java.nio.channels.SocketChannel v, v;
boolean v, v, v;
java.io.PrintWriter v;
oadd.org.apache.zookeeper.server.command.CommandExecutor v;
oadd.org.apache.zookeeper.server.NIOServerCnxn$SendBufferWriter v;
java.lang.Exception v;
java.net.Socket v;
oadd.org.apache.zookeeper.server.NIOServerCnxnFactory v;
long v;
oadd.org.apache.zookeeper.server.ZooKeeperServer v;
oadd.org.apache.zookeeper.server.command.SetTraceMaskCommand v;
int v, v, v;
java.lang.String v, v, v;
org.slf4j.Logger v, v, v;
java.io.BufferedWriter v;
java.nio.channels.SelectionKey v;
java.io.IOException v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v := @parameter: java.nio.channels.SelectionKey;
v := @parameter: int;
v = staticinvoke <oadd.org.apache.zookeeper.server.command.FourLetterCommands: boolean isKnown(int)>(v);
if v != 0 goto label;
return 0;
label:
v = staticinvoke <oadd.org.apache.zookeeper.server.command.FourLetterCommands: java.lang.String getCommandString(int)>(v);
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void packetReceived()>();
if v == null goto label;
label:
virtualinvoke v.<java.nio.channels.SelectionKey: void cancel()>();
label:
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Error cancelling command selection key ", v);
label:
v = new java.io.PrintWriter;
v = new java.io.BufferedWriter;
v = new oadd.org.apache.zookeeper.server.NIOServerCnxn$SendBufferWriter;
specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn$SendBufferWriter: void <init>(oadd.org.apache.zookeeper.server.NIOServerCnxn)>(v);
specialinvoke v.<java.io.BufferedWriter: void <init>(java.io.Writer)>(v);
specialinvoke v.<java.io.PrintWriter: void <init>(java.io.Writer)>(v);
v = staticinvoke <oadd.org.apache.zookeeper.server.command.FourLetterCommands: boolean isEnabled(java.lang.String)>(v);
if v != 0 goto label;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Command {} is not executed because it is not in the whitelist.", v);
v = new oadd.org.apache.zookeeper.server.command.NopCommand;
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[])>("\u is not executed because it is not in the whitelist.");
specialinvoke v.<oadd.org.apache.zookeeper.server.command.NopCommand: void <init>(java.io.PrintWriter,oadd.org.apache.zookeeper.server.ServerCnxn,java.lang.String)>(v, v, v);
virtualinvoke v.<oadd.org.apache.zookeeper.server.command.NopCommand: void start()>();
return 1;
label:
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
v = virtualinvoke v.<java.net.Socket: java.net.SocketAddress getRemoteSocketAddress()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.net.SocketAddress)>(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[])>("Processing \u command from \u0001");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
v = <oadd.org.apache.zookeeper.server.command.FourLetterCommands: int setTraceMaskCmd>;
if v != v goto label;
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer allocate(int)>(8);
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer> = v;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: int read(java.nio.ByteBuffer)>(v);
if v >= 0 goto label;
v = new java.io.IOException;
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>("Read error");
throw v;
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer flip()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: long getLong()>();
staticinvoke <oadd.org.apache.zookeeper.server.ZooTrace: void setTextTraceLevel(long)>(v);
v = new oadd.org.apache.zookeeper.server.command.SetTraceMaskCommand;
specialinvoke v.<oadd.org.apache.zookeeper.server.command.SetTraceMaskCommand: void <init>(java.io.PrintWriter,oadd.org.apache.zookeeper.server.ServerCnxn,long)>(v, v, v);
virtualinvoke v.<oadd.org.apache.zookeeper.server.command.SetTraceMaskCommand: void start()>();
return 1;
label:
v = new oadd.org.apache.zookeeper.server.command.CommandExecutor;
specialinvoke v.<oadd.org.apache.zookeeper.server.command.CommandExecutor: void <init>()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.ZooKeeperServer zkServer>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.NIOServerCnxnFactory factory>;
v = virtualinvoke v.<oadd.org.apache.zookeeper.server.command.CommandExecutor: boolean execute(oadd.org.apache.zookeeper.server.ServerCnxn,java.io.PrintWriter,int,oadd.org.apache.zookeeper.server.ZooKeeperServer,oadd.org.apache.zookeeper.server.ServerCnxnFactory)>(v, v, v, v, v);
return v;
catch java.lang.Exception from label to label with label;
}
private boolean readLength(java.nio.channels.SelectionKey) throws java.io.IOException
{
java.nio.channels.SelectionKey v, v;
java.io.IOException v, v;
java.nio.ByteBuffer v, v;
int v, v;
java.lang.String v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v, v, v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v := @parameter: java.nio.channels.SelectionKey;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer lenBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int getInt()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean initialized>;
if v != 0 goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SelectionKey sk>;
v = specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean checkFourLetterWord(java.nio.channels.SelectionKey,int)>(v, v);
if v == 0 goto label;
return 0;
label:
if v < 0 goto label;
v = <oadd.org.apache.jute.BinaryInputArchive: int maxBuffer>;
if v <= v goto label;
label:
v = new java.io.IOException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("Len error \u0001");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean isZKServerRunning()>();
if v != 0 goto label;
v = new java.io.IOException;
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>("ZooKeeperServer not running");
throw v;
label:
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer allocate(int)>(v);
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.ByteBuffer incomingBuffer> = v;
return 1;
}
boolean isZKServerRunning()
{
oadd.org.apache.zookeeper.server.ZooKeeperServer v, v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v, v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.ZooKeeperServer zkServer>;
if v == null goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.ZooKeeperServer zkServer>;
v = virtualinvoke v.<oadd.org.apache.zookeeper.server.ZooKeeperServer: boolean isRunning()>();
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public long getOutstandingRequests()
{
int v;
java.util.concurrent.atomic.AtomicInteger v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.concurrent.atomic.AtomicInteger outstandingRequests>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
return v;
}
public int getSessionTimeout()
{
int v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: int sessionTimeout>;
return v;
}
public java.lang.String toString()
{
java.net.Socket v;
java.net.SocketAddress v;
java.nio.channels.SocketChannel v;
long v;
java.lang.String v, v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
v = virtualinvoke v.<java.net.Socket: java.net.SocketAddress getRemoteSocketAddress()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: long sessionId>;
v = staticinvoke <java.lang.Long: java.lang.String toHexString(long)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.SocketAddress,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[])>("ip: \u sessionId: 0x\u0001");
return v;
}
public void close()
{
org.slf4j.Logger v, v;
java.nio.channels.SelectionKey v, v;
oadd.org.apache.zookeeper.server.NIOServerCnxnFactory v;
oadd.org.apache.zookeeper.server.ZooKeeperServer v, v;
java.lang.Exception v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v, v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.NIOServerCnxnFactory factory>;
v = virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxnFactory: boolean removeCnxn(oadd.org.apache.zookeeper.server.NIOServerCnxn)>(v);
if v != 0 goto label;
return;
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.ZooKeeperServer zkServer>;
if v == null goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.ZooKeeperServer zkServer>;
virtualinvoke v.<oadd.org.apache.zookeeper.server.ZooKeeperServer: void removeCnxn(oadd.org.apache.zookeeper.server.ServerCnxn)>(v);
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SelectionKey sk>;
if v == null goto label;
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SelectionKey sk>;
virtualinvoke v.<java.nio.channels.SelectionKey: void cancel()>();
label:
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>("ignoring exception during selectionkey cancel", v);
label:
specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void closeSock()>();
return;
catch java.lang.Exception from label to label with label;
}
private void closeSock()
{
java.net.Socket v;
org.slf4j.Logger v;
java.net.SocketAddress v;
long v, v;
byte v;
java.nio.channels.SocketChannel v, v, v;
java.lang.String v, v, v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: boolean isOpen()>();
if v != 0 goto label;
return;
label:
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
v = virtualinvoke v.<java.net.Socket: java.net.SocketAddress getRemoteSocketAddress()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: long sessionId>;
v = v cmp 0L;
if v == 0 goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: long sessionId>;
v = staticinvoke <java.lang.Long: java.lang.String toHexString(long)>(v);
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[])>(" which had sessionid 0x\u0001");
goto label;
label:
v = " (no session established for client)";
label:
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.SocketAddress,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[])>("Closed socket connection for client \u0001\u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
staticinvoke <oadd.org.apache.zookeeper.server.NIOServerCnxn: void closeSock(java.nio.channels.SocketChannel)>(v);
return;
}
public static void closeSock(java.nio.channels.SocketChannel)
{
java.net.Socket v, v, v;
java.nio.channels.SocketChannel v;
boolean v, v, v, v;
org.slf4j.Logger v, v, v, v, v, v;
java.io.IOException v, v, v;
v := @parameter: java.nio.channels.SocketChannel;
v = virtualinvoke v.<java.nio.channels.SocketChannel: boolean isOpen()>();
if v != 0 goto label;
return;
label:
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
virtualinvoke v.<java.net.Socket: void shutdownOutput()>();
label:
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>("ignoring exception during output shutdown", v);
label:
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
virtualinvoke v.<java.net.Socket: void shutdownInput()>();
label:
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>("ignoring exception during input shutdown", v);
label:
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
virtualinvoke v.<java.net.Socket: void close()>();
label:
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>("ignoring exception during socket close", v);
label:
return;
catch java.io.IOException from label to label with label;
catch java.io.IOException from label to label with label;
catch java.io.IOException from label to label with label;
}
public void sendResponse(oadd.org.apache.zookeeper.proto.ReplyHeader, oadd.org.apache.jute.Record, java.lang.String)
{
oadd.org.apache.jute.Record v;
org.slf4j.Logger v;
oadd.org.apache.zookeeper.server.ZooKeeperServer v;
java.lang.Exception v;
java.util.concurrent.atomic.AtomicInteger v;
int v, v, v, v;
java.lang.String v;
oadd.org.apache.zookeeper.proto.ReplyHeader v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v := @parameter: oadd.org.apache.zookeeper.proto.ReplyHeader;
v := @parameter: oadd.org.apache.jute.Record;
v := @parameter: java.lang.String;
label:
specialinvoke v.<oadd.org.apache.zookeeper.server.ServerCnxn: void sendResponse(oadd.org.apache.zookeeper.proto.ReplyHeader,oadd.org.apache.jute.Record,java.lang.String)>(v, v, v);
v = virtualinvoke v.<oadd.org.apache.zookeeper.proto.ReplyHeader: int getXid()>();
if v <= 0 goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.util.concurrent.atomic.AtomicInteger outstandingRequests>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int decrementAndGet()>();
if v < 1 goto label;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.ZooKeeperServer zkServer>;
v = virtualinvoke v.<oadd.org.apache.zookeeper.server.ZooKeeperServer: int getInProcess()>();
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: int outstandingLimit>;
if v >= v goto label;
label:
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void enableRecv()>();
label:
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Unexpected exception. Destruction averted.", v);
label:
return;
catch java.lang.Exception from label to label with label;
}
public void process(oadd.org.apache.zookeeper.WatchedEvent)
{
org.slf4j.Logger v, v;
long v;
oadd.org.apache.zookeeper.WatchedEvent v;
int v;
oadd.org.apache.zookeeper.proto.WatcherEvent v;
java.lang.String v, v;
oadd.org.apache.zookeeper.proto.ReplyHeader v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v := @parameter: oadd.org.apache.zookeeper.WatchedEvent;
v = new oadd.org.apache.zookeeper.proto.ReplyHeader;
v = (int) -1;
specialinvoke v.<oadd.org.apache.zookeeper.proto.ReplyHeader: void <init>(int,long,int)>(v, -1L, 0);
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG>;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: long sessionId>;
v = staticinvoke <java.lang.Long: java.lang.String toHexString(long)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (oadd.org.apache.zookeeper.WatchedEvent,java.lang.String,oadd.org.apache.zookeeper.server.NIOServerCnxn)>(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[])>("Deliver event \u to 0x\u through \u0001");
staticinvoke <oadd.org.apache.zookeeper.server.ZooTrace: void logTraceMessage(org.slf4j.Logger,long,java.lang.String)>(v, 64L, v);
label:
v = virtualinvoke v.<oadd.org.apache.zookeeper.WatchedEvent: oadd.org.apache.zookeeper.proto.WatcherEvent getWrapper()>();
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: void sendResponse(oadd.org.apache.zookeeper.proto.ReplyHeader,oadd.org.apache.jute.Record,java.lang.String)>(v, v, "notification");
return;
}
public long getSessionId()
{
long v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: long sessionId>;
return v;
}
public void setSessionId(long)
{
oadd.org.apache.zookeeper.server.NIOServerCnxnFactory v;
long v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v := @parameter: long;
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: long sessionId> = v;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.NIOServerCnxnFactory factory>;
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxnFactory: void addSession(long,oadd.org.apache.zookeeper.server.NIOServerCnxn)>(v, v);
return;
}
public void setSessionTimeout(int)
{
int v;
oadd.org.apache.zookeeper.server.NIOServerCnxnFactory v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v := @parameter: int;
v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: int sessionTimeout> = v;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.NIOServerCnxnFactory factory>;
virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxnFactory: void touchCnxn(oadd.org.apache.zookeeper.server.NIOServerCnxn)>(v);
return;
}
public int getInterestOps()
{
byte v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v, v, v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = virtualinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean isSelectable()>();
if v != 0 goto label;
return 0;
label:
v = 0;
v = specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean getReadInterest()>();
if v == 0 goto label;
v = 1;
label:
v = specialinvoke v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: boolean getWriteInterest()>();
if v == 0 goto label;
v = v | 4;
label:
return v;
}
public java.net.InetSocketAddress getRemoteSocketAddress()
{
java.net.Socket v;
java.net.SocketAddress v;
java.nio.channels.SocketChannel v, v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: boolean isOpen()>();
if v != 0 goto label;
return null;
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
v = virtualinvoke v.<java.net.Socket: java.net.SocketAddress getRemoteSocketAddress()>();
return v;
}
public java.net.InetAddress getSocketAddress()
{
java.net.InetAddress v;
java.net.Socket v;
java.nio.channels.SocketChannel v, v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
boolean v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: boolean isOpen()>();
if v != 0 goto label;
return null;
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: java.nio.channels.SocketChannel sock>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
v = virtualinvoke v.<java.net.Socket: java.net.InetAddress getInetAddress()>();
return v;
}
protected oadd.org.apache.zookeeper.server.ServerStats serverStats()
{
oadd.org.apache.zookeeper.server.ZooKeeperServer v, v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
oadd.org.apache.zookeeper.server.ServerStats v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.ZooKeeperServer zkServer>;
if v != null goto label;
return null;
label:
v = v.<oadd.org.apache.zookeeper.server.NIOServerCnxn: oadd.org.apache.zookeeper.server.ZooKeeperServer zkServer>;
v = virtualinvoke v.<oadd.org.apache.zookeeper.server.ZooKeeperServer: oadd.org.apache.zookeeper.server.ServerStats serverStats()>();
return v;
}
public boolean isSecure()
{
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
return 0;
}
public java.security.cert.Certificate[] getClientCertificateChain()
{
java.lang.UnsupportedOperationException v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v = new java.lang.UnsupportedOperationException;
specialinvoke v.<java.lang.UnsupportedOperationException: void <init>(java.lang.String)>("SSL is unsupported in NIOServerCnxn");
throw v;
}
public void setClientCertificateChain(java.security.cert.Certificate[])
{
java.lang.UnsupportedOperationException v;
java.security.cert.Certificate[] v;
oadd.org.apache.zookeeper.server.NIOServerCnxn v;
v := @this: oadd.org.apache.zookeeper.server.NIOServerCnxn;
v := @parameter: java.security.cert.Certificate[];
v = new java.lang.UnsupportedOperationException;
specialinvoke v.<java.lang.UnsupportedOperationException: void <init>(java.lang.String)>("SSL is unsupported in NIOServerCnxn");
throw v;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Loadd/org/apache/zookeeper/server/NIOServerCnxn;");
<oadd.org.apache.zookeeper.server.NIOServerCnxn: org.slf4j.Logger LOG> = v;
return;
}
}