public class org.fusesource.hawtdispatch.transport.SslProtocolCodec extends java.lang.Object implements org.fusesource.hawtdispatch.transport.WrappingProtocolCodec, org.fusesource.hawtdispatch.transport.SecuredSession
{
private java.nio.channels.ReadableByteChannel readChannel;
private java.nio.channels.WritableByteChannel writeChannel;
private javax.net.ssl.SSLContext sslContext;
private javax.net.ssl.SSLEngine engine;
private java.nio.ByteBuffer readBuffer;
private boolean readUnderflow;
private java.nio.ByteBuffer writeBuffer;
private boolean writeFlushing;
private java.nio.ByteBuffer readOverflowBuffer;
org.fusesource.hawtdispatch.transport.Transport transport;
int lastReadSize;
int lastWriteSize;
long readCounter;
long writeCounter;
org.fusesource.hawtdispatch.transport.ProtocolCodec next;
org.fusesource.hawtdispatch.transport.SslProtocolCodec$SSLReadChannel sslReadChannel;
org.fusesource.hawtdispatch.transport.SslProtocolCodec$SSLWriteChannel sslWriteChannel;
static final boolean $assertionsDisabled;
public void <init>()
{
org.fusesource.hawtdispatch.transport.SslProtocolCodec$SSLReadChannel v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec$SSLWriteChannel v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new org.fusesource.hawtdispatch.transport.SslProtocolCodec$SSLReadChannel;
specialinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec$SSLReadChannel: void <init>(org.fusesource.hawtdispatch.transport.SslProtocolCodec)>(v);
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.SslProtocolCodec$SSLReadChannel sslReadChannel> = v;
v = new org.fusesource.hawtdispatch.transport.SslProtocolCodec$SSLWriteChannel;
specialinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec$SSLWriteChannel: void <init>(org.fusesource.hawtdispatch.transport.SslProtocolCodec)>(v);
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.SslProtocolCodec$SSLWriteChannel sslWriteChannel> = v;
return;
}
public org.fusesource.hawtdispatch.transport.ProtocolCodec getNext()
{
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
org.fusesource.hawtdispatch.transport.ProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.ProtocolCodec next>;
return v;
}
public void setNext(org.fusesource.hawtdispatch.transport.ProtocolCodec)
{
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
org.fusesource.hawtdispatch.transport.ProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v := @parameter: org.fusesource.hawtdispatch.transport.ProtocolCodec;
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.ProtocolCodec next> = v;
specialinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: void initNext()>();
return;
}
private void initNext()
{
org.fusesource.hawtdispatch.transport.Transport v;
org.fusesource.hawtdispatch.transport.ProtocolCodec v, v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec$1 v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.ProtocolCodec next>;
if v == null goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.ProtocolCodec next>;
v = new org.fusesource.hawtdispatch.transport.SslProtocolCodec$1;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.Transport transport>;
specialinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec$1: void <init>(org.fusesource.hawtdispatch.transport.SslProtocolCodec,org.fusesource.hawtdispatch.transport.Transport)>(v, v);
interfaceinvoke v.<org.fusesource.hawtdispatch.transport.ProtocolCodec: void setTransport(org.fusesource.hawtdispatch.transport.Transport)>(v);
label:
return;
}
public void setSSLContext(javax.net.ssl.SSLContext)
{
javax.net.ssl.SSLContext v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
java.lang.AssertionError v;
boolean v;
javax.net.ssl.SSLEngine v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v := @parameter: javax.net.ssl.SSLContext;
v = <org.fusesource.hawtdispatch.transport.SslProtocolCodec: boolean $assertionsDisabled>;
if v != 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
if v == null goto label;
v = new java.lang.AssertionError;
specialinvoke v.<java.lang.AssertionError: void <init>()>();
throw v;
label:
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLContext sslContext> = v;
return;
}
public org.fusesource.hawtdispatch.transport.SslProtocolCodec client() throws java.lang.Exception
{
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
javax.net.ssl.SSLEngine v, v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: void initializeEngine()>();
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void setUseClientMode(boolean)>(1);
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void beginHandshake()>();
return v;
}
public org.fusesource.hawtdispatch.transport.SslProtocolCodec server(org.fusesource.hawtdispatch.transport.SslProtocolCodec$ClientAuth) throws java.lang.Exception
{
org.fusesource.hawtdispatch.transport.SslProtocolCodec$ClientAuth v;
javax.net.ssl.SSLEngine v, v, v, v, v;
int[] v;
int v, v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v := @parameter: org.fusesource.hawtdispatch.transport.SslProtocolCodec$ClientAuth;
virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: void initializeEngine()>();
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void setUseClientMode(boolean)>(0);
v = <org.fusesource.hawtdispatch.transport.SslProtocolCodec$3: int[] $SwitchMap$org$fusesource$hawtdispatch$transport$SslProtocolCodec$ClientAuth>;
v = virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec$ClientAuth: int ordinal()>();
v = v[v];
tableswitch(v)
{
case 1: goto label;
case 2: goto label;
case 3: goto label;
default: goto label;
};
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void setWantClientAuth(boolean)>(1);
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void setNeedClientAuth(boolean)>(1);
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void setWantClientAuth(boolean)>(0);
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void beginHandshake()>();
return v;
}
protected void initializeEngine() throws java.lang.Exception
{
javax.net.ssl.SSLContext v, v, v;
java.lang.AssertionError v;
java.nio.ByteBuffer v, v, v;
javax.net.ssl.SSLEngine v, v, v;
javax.net.ssl.SSLSession v;
int v, v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
boolean v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = <org.fusesource.hawtdispatch.transport.SslProtocolCodec: boolean $assertionsDisabled>;
if v != 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
if v == null goto label;
v = new java.lang.AssertionError;
specialinvoke v.<java.lang.AssertionError: void <init>()>();
throw v;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLContext sslContext>;
if v != null goto label;
v = staticinvoke <javax.net.ssl.SSLContext: javax.net.ssl.SSLContext getDefault()>();
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLContext sslContext> = v;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLContext sslContext>;
v = virtualinvoke v.<javax.net.ssl.SSLContext: javax.net.ssl.SSLEngine createSSLEngine()>();
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine> = v;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLSession getSession()>();
v = interfaceinvoke v.<javax.net.ssl.SSLSession: int getPacketBufferSize()>();
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer allocateDirect(int)>(v);
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readBuffer> = v;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer flip()>();
v = interfaceinvoke v.<javax.net.ssl.SSLSession: int getPacketBufferSize()>();
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer allocateDirect(int)>(v);
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer writeBuffer> = v;
return;
}
public javax.net.ssl.SSLSession getSSLSession()
{
javax.net.ssl.SSLSession v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
javax.net.ssl.SSLEngine v, v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
if v != null goto label;
v = null;
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLSession getSession()>();
label:
return v;
}
public java.security.cert.X509Certificate[] getPeerX509Certificates()
{
java.lang.Object[] v;
java.util.ArrayList v;
javax.net.ssl.SSLEngine v, v;
java.security.cert.Certificate v;
javax.net.ssl.SSLSession v;
int v, v, v;
java.security.cert.Certificate[] v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
java.security.cert.X509Certificate[] v;
boolean v;
javax.net.ssl.SSLPeerUnverifiedException v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
if v != null goto label;
return null;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLSession getSession()>();
v = interfaceinvoke v.<javax.net.ssl.SSLSession: java.security.cert.Certificate[] getPeerCertificates()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = v instanceof java.security.cert.X509Certificate;
if v == 0 goto label;
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
label:
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.util.ArrayList: int size()>();
v = newarray (java.security.cert.X509Certificate)[v];
v = virtualinvoke v.<java.util.ArrayList: java.lang.Object[] toArray(java.lang.Object[])>(v);
label:
return v;
label:
v := @caughtexception;
return null;
catch javax.net.ssl.SSLPeerUnverifiedException from label to label with label;
}
public void setTransport(org.fusesource.hawtdispatch.transport.Transport)
{
java.nio.channels.ReadableByteChannel v;
org.fusesource.hawtdispatch.transport.Transport v;
java.nio.channels.WritableByteChannel v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v := @parameter: org.fusesource.hawtdispatch.transport.Transport;
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.Transport transport> = v;
v = interfaceinvoke v.<org.fusesource.hawtdispatch.transport.Transport: java.nio.channels.ReadableByteChannel getReadChannel()>();
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.channels.ReadableByteChannel readChannel> = v;
v = interfaceinvoke v.<org.fusesource.hawtdispatch.transport.Transport: java.nio.channels.WritableByteChannel getWriteChannel()>();
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.channels.WritableByteChannel writeChannel> = v;
specialinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: void initNext()>();
return;
}
public void handshake() throws java.io.IOException
{
javax.net.ssl.SSLEngineResult$HandshakeStatus v, v;
java.lang.Runnable v;
java.nio.ByteBuffer v, v;
javax.net.ssl.SSLEngine v, v, v;
org.fusesource.hawtdispatch.transport.Transport v, v, v;
int[] v;
int v, v, v, v;
java.lang.String v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec$2 v;
boolean v;
java.io.PrintStream v;
java.util.concurrent.Executor v;
java.io.EOFException v;
org.fusesource.hawtdispatch.transport.TransportListener v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: boolean transportFlush()>();
if v != 0 goto label;
return;
label:
v = <org.fusesource.hawtdispatch.transport.SslProtocolCodec$3: int[] $SwitchMap$javax$net$ssl$SSLEngineResult$HandshakeStatus>;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLEngineResult$HandshakeStatus getHandshakeStatus()>();
v = virtualinvoke v.<javax.net.ssl.SSLEngineResult$HandshakeStatus: int ordinal()>();
v = v[v];
tableswitch(v)
{
case 1: goto label;
case 2: goto label;
case 3: goto label;
case 4: goto label;
case 5: goto label;
default: goto label;
};
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: java.lang.Runnable getDelegatedTask()>();
if v == null goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.Transport transport>;
v = interfaceinvoke v.<org.fusesource.hawtdispatch.transport.Transport: java.util.concurrent.Executor getBlockingExecutor()>();
v = new org.fusesource.hawtdispatch.transport.SslProtocolCodec$2;
specialinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec$2: void <init>(org.fusesource.hawtdispatch.transport.SslProtocolCodec,java.lang.Runnable)>(v, v);
interfaceinvoke v.<java.util.concurrent.Executor: void execute(java.lang.Runnable)>(v);
goto label;
label:
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer allocate(int)>(0);
specialinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: int secure_write(java.nio.ByteBuffer)>(v);
goto label;
label:
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer allocate(int)>(0);
v = specialinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: int secure_read(java.nio.ByteBuffer)>(v);
v = (int) -1;
if v != v goto label;
v = new java.io.EOFException;
specialinvoke v.<java.io.EOFException: void <init>(java.lang.String)>("Peer disconnected during ssl handshake");
throw v;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.Transport transport>;
interfaceinvoke v.<org.fusesource.hawtdispatch.transport.Transport: void drainInbound()>();
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.Transport transport>;
v = interfaceinvoke v.<org.fusesource.hawtdispatch.transport.Transport: org.fusesource.hawtdispatch.transport.TransportListener getTransportListener()>();
interfaceinvoke v.<org.fusesource.hawtdispatch.transport.TransportListener: void onRefill()>();
goto label;
label:
v = <java.lang.System: java.io.PrintStream err>;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLEngineResult$HandshakeStatus getHandshakeStatus()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (javax.net.ssl.SSLEngineResult$HandshakeStatus)>(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[])>("Unexpected ssl engine handshake status: \u0001");
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
label:
return;
}
protected boolean transportFlush() throws java.io.IOException
{
long v, v;
java.nio.ByteBuffer v, v, v, v, v;
int v, v, v, v;
java.nio.channels.WritableByteChannel v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
boolean v, v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: boolean writeFlushing>;
if v == 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.channels.WritableByteChannel writeChannel>;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer writeBuffer>;
v = interfaceinvoke v.<java.nio.channels.WritableByteChannel: int write(java.nio.ByteBuffer)>(v);
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: int lastWriteSize> = v;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: int lastWriteSize>;
if v <= 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: long writeCounter>;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: int lastWriteSize>;
v = v + v;
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: long writeCounter> = v;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer writeBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: boolean hasRemaining()>();
if v != 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer writeBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer clear()>();
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: boolean writeFlushing> = 0;
return 1;
label:
return 0;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer writeBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
if v == 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer writeBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer flip()>();
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: boolean writeFlushing> = 1;
goto label;
label:
return 1;
}
private int secure_read(java.nio.ByteBuffer) throws java.io.IOException
{
byte[] v;
long v, v;
java.lang.AssertionError v;
javax.net.ssl.SSLEngineResult v;
javax.net.ssl.SSLSession v;
javax.net.ssl.SSLEngineResult$Status v, v, v;
javax.net.ssl.SSLEngineResult$HandshakeStatus v, v, v, v;
java.nio.ByteBuffer v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
int[] v;
boolean v, v, v, v, v, v;
javax.net.ssl.SSLEngine v, v, v, v, v, v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.nio.channels.ReadableByteChannel v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v := @parameter: java.nio.ByteBuffer;
v = 0;
label:
v = virtualinvoke v.<java.nio.ByteBuffer: boolean hasRemaining()>();
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLEngineResult$HandshakeStatus getHandshakeStatus()>();
v = <javax.net.ssl.SSLEngineResult$HandshakeStatus: javax.net.ssl.SSLEngineResult$HandshakeStatus NEED_UNWRAP>;
if v != v goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v ^ v;
if v == 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readOverflowBuffer>;
if v == null goto label;
v = virtualinvoke v.<java.nio.ByteBuffer: boolean hasRemaining()>();
if v == 0 goto label;
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readOverflowBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
v = staticinvoke <java.lang.Math: int min(int,int)>(v, v);
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readOverflowBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: byte[] array()>();
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readOverflowBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer put(byte[],int,int)>(v, v, v);
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readOverflowBuffer>;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readOverflowBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
v = v + v;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer position(int)>(v);
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readOverflowBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: boolean hasRemaining()>();
if v != 0 goto label;
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readOverflowBuffer> = null;
label:
v = v + v;
goto label;
label:
return v;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: boolean readUnderflow>;
if v == 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.channels.ReadableByteChannel readChannel>;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readBuffer>;
v = interfaceinvoke v.<java.nio.channels.ReadableByteChannel: int read(java.nio.ByteBuffer)>(v);
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: int lastReadSize> = v;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: int lastReadSize>;
v = (int) -1;
if v != v goto label;
if v != 0 goto label;
v = (int) -1;
return v;
label:
return v;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: int lastReadSize>;
if v != 0 goto label;
return v;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: long readCounter>;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: int lastReadSize>;
v = v + v;
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: long readCounter> = v;
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: boolean readUnderflow> = 0;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer flip()>();
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readBuffer>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLEngineResult unwrap(java.nio.ByteBuffer,java.nio.ByteBuffer)>(v, v);
v = virtualinvoke v.<javax.net.ssl.SSLEngineResult: int bytesProduced()>();
v = v + v;
v = virtualinvoke v.<javax.net.ssl.SSLEngineResult: javax.net.ssl.SSLEngineResult$Status getStatus()>();
v = <javax.net.ssl.SSLEngineResult$Status: javax.net.ssl.SSLEngineResult$Status BUFFER_OVERFLOW>;
if v != v goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLSession getSession()>();
v = interfaceinvoke v.<javax.net.ssl.SSLSession: int getApplicationBufferSize()>();
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer allocate(int)>(v);
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readOverflowBuffer> = v;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readBuffer>;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readOverflowBuffer>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLEngineResult unwrap(java.nio.ByteBuffer,java.nio.ByteBuffer)>(v, v);
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readOverflowBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
if v != 0 goto label;
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readOverflowBuffer> = null;
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readOverflowBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer flip()>();
label:
v = <org.fusesource.hawtdispatch.transport.SslProtocolCodec$3: int[] $SwitchMap$javax$net$ssl$SSLEngineResult$Status>;
v = virtualinvoke v.<javax.net.ssl.SSLEngineResult: javax.net.ssl.SSLEngineResult$Status getStatus()>();
v = virtualinvoke v.<javax.net.ssl.SSLEngineResult$Status: int ordinal()>();
v = v[v];
tableswitch(v)
{
case 1: goto label;
case 2: goto label;
case 3: goto label;
case 4: goto label;
default: goto label;
};
label:
if v != 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void closeInbound()>();
v = (int) -1;
return v;
label:
return v;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLEngineResult$HandshakeStatus getHandshakeStatus()>();
v = <javax.net.ssl.SSLEngineResult$HandshakeStatus: javax.net.ssl.SSLEngineResult$HandshakeStatus NOT_HANDSHAKING>;
if v == v goto label;
virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: void handshake()>();
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer compact()>();
v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: boolean readUnderflow> = 1;
goto label;
label:
v = new java.lang.AssertionError;
specialinvoke v.<java.lang.AssertionError: void <init>(java.lang.Object)>("Unexpected case.");
throw v;
label:
return v;
}
private int secure_write(java.nio.ByteBuffer) throws java.io.IOException
{
javax.net.ssl.SSLEngineResult$HandshakeStatus v, v, v, v;
java.lang.AssertionError v;
java.nio.ByteBuffer v, v;
javax.net.ssl.SSLEngine v, v, v;
javax.net.ssl.SSLEngineResult v;
int v, v, v;
javax.net.ssl.SSLEngineResult$Status v, v;
boolean v, v, v, v, v, v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v := @parameter: java.nio.ByteBuffer;
v = virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: boolean transportFlush()>();
if v != 0 goto label;
return 0;
label:
v = 0;
label:
v = virtualinvoke v.<java.nio.ByteBuffer: boolean hasRemaining()>();
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLEngineResult$HandshakeStatus getHandshakeStatus()>();
v = <javax.net.ssl.SSLEngineResult$HandshakeStatus: javax.net.ssl.SSLEngineResult$HandshakeStatus NEED_WRAP>;
if v != v goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v ^ v;
if v == 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer writeBuffer>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLEngineResult wrap(java.nio.ByteBuffer,java.nio.ByteBuffer)>(v, v);
v = <org.fusesource.hawtdispatch.transport.SslProtocolCodec: boolean $assertionsDisabled>;
if v != 0 goto label;
v = virtualinvoke v.<javax.net.ssl.SSLEngineResult: javax.net.ssl.SSLEngineResult$Status getStatus()>();
v = <javax.net.ssl.SSLEngineResult$Status: javax.net.ssl.SSLEngineResult$Status BUFFER_OVERFLOW>;
if v != v goto label;
v = new java.lang.AssertionError;
specialinvoke v.<java.lang.AssertionError: void <init>()>();
throw v;
label:
v = virtualinvoke v.<javax.net.ssl.SSLEngineResult: int bytesConsumed()>();
v = v + v;
v = virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: boolean transportFlush()>();
if v != 0 goto label;
label:
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
if v != 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLEngineResult$HandshakeStatus getHandshakeStatus()>();
v = <javax.net.ssl.SSLEngineResult$HandshakeStatus: javax.net.ssl.SSLEngineResult$HandshakeStatus NOT_HANDSHAKING>;
if v == v goto label;
virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: void handshake()>();
label:
return v;
}
public void unread(byte[])
{
byte[] v;
java.lang.IllegalStateException v;
java.nio.ByteBuffer v, v, v, v;
int v, v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v := @parameter: byte[];
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer compact()>();
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
v = lengthof v;
if v >= v goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("Cannot unread now");
throw v;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer put(byte[])>(v);
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer flip()>();
return;
}
public java.lang.Object read() throws java.io.IOException
{
java.lang.Object v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
org.fusesource.hawtdispatch.transport.ProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.ProtocolCodec next>;
v = interfaceinvoke v.<org.fusesource.hawtdispatch.transport.ProtocolCodec: java.lang.Object read()>();
return v;
}
public org.fusesource.hawtdispatch.transport.ProtocolCodec$BufferState write(java.lang.Object) throws java.io.IOException
{
org.fusesource.hawtdispatch.transport.ProtocolCodec v;
org.fusesource.hawtdispatch.transport.ProtocolCodec$BufferState v;
java.lang.Object v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v := @parameter: java.lang.Object;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.ProtocolCodec next>;
v = interfaceinvoke v.<org.fusesource.hawtdispatch.transport.ProtocolCodec: org.fusesource.hawtdispatch.transport.ProtocolCodec$BufferState write(java.lang.Object)>(v);
return v;
}
public org.fusesource.hawtdispatch.transport.ProtocolCodec$BufferState flush() throws java.io.IOException
{
org.fusesource.hawtdispatch.transport.ProtocolCodec$BufferState v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
org.fusesource.hawtdispatch.transport.ProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.ProtocolCodec next>;
v = interfaceinvoke v.<org.fusesource.hawtdispatch.transport.ProtocolCodec: org.fusesource.hawtdispatch.transport.ProtocolCodec$BufferState flush()>();
return v;
}
public boolean full()
{
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
boolean v;
org.fusesource.hawtdispatch.transport.ProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: org.fusesource.hawtdispatch.transport.ProtocolCodec next>;
v = interfaceinvoke v.<org.fusesource.hawtdispatch.transport.ProtocolCodec: boolean full()>();
return v;
}
public long getWriteCounter()
{
long v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: long writeCounter>;
return v;
}
public long getLastWriteSize()
{
int v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: int lastWriteSize>;
return v;
}
public long getReadCounter()
{
long v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: long readCounter>;
return v;
}
public long getLastReadSize()
{
int v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: int lastReadSize>;
return v;
}
public int getReadBufferSize()
{
int v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
java.nio.ByteBuffer v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer readBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int capacity()>();
return v;
}
public int getWriteBufferSize()
{
int v;
org.fusesource.hawtdispatch.transport.SslProtocolCodec v;
java.nio.ByteBuffer v;
v := @this: org.fusesource.hawtdispatch.transport.SslProtocolCodec;
v = v.<org.fusesource.hawtdispatch.transport.SslProtocolCodec: java.nio.ByteBuffer writeBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int capacity()>();
return v;
}
static void <clinit>()
{
java.lang.Class v;
boolean v, v;
v = class "Lorg/fusesource/hawtdispatch/transport/SslProtocolCodec;";
v = virtualinvoke v.<java.lang.Class: boolean desiredAssertionStatus()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
<org.fusesource.hawtdispatch.transport.SslProtocolCodec: boolean $assertionsDisabled> = v;
return;
}
}