public class org.fusesource.hawtdispatch.transport.SslTransport extends org.fusesource.hawtdispatch.transport.TcpTransport implements org.fusesource.hawtdispatch.transport.SecuredSession
{
private org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth clientAuth;
private java.lang.String disabledCypherSuites;
private java.lang.String enabledCipherSuites;
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;
private org.fusesource.hawtdispatch.transport.SslTransport$SSLChannel ssl_channel;
static final boolean $assertionsDisabled;
public void <init>()
{
org.fusesource.hawtdispatch.transport.SslTransport$SSLChannel v;
org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth v;
org.fusesource.hawtdispatch.transport.SslTransport v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
specialinvoke v.<org.fusesource.hawtdispatch.transport.TcpTransport: void <init>()>();
v = <org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth: org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth WANT>;
v.<org.fusesource.hawtdispatch.transport.SslTransport: org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth clientAuth> = v;
v.<org.fusesource.hawtdispatch.transport.SslTransport: java.lang.String disabledCypherSuites> = null;
v.<org.fusesource.hawtdispatch.transport.SslTransport: java.lang.String enabledCipherSuites> = null;
v = new org.fusesource.hawtdispatch.transport.SslTransport$SSLChannel;
specialinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport$SSLChannel: void <init>(org.fusesource.hawtdispatch.transport.SslTransport)>(v);
v.<org.fusesource.hawtdispatch.transport.SslTransport: org.fusesource.hawtdispatch.transport.SslTransport$SSLChannel ssl_channel> = v;
return;
}
public static java.lang.String protocol(java.lang.String)
{
java.lang.String v, v, v, v, v;
boolean v, v, v, v;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("tls");
if v == 0 goto label;
return "TLS";
label:
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("tlsv");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(4);
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[])>("TLSv\u0001");
return v;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("ssl");
if v == 0 goto label;
return "SSL";
label:
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("sslv");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(4);
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[])>("SSLv\u0001");
return v;
label:
return null;
}
public void setSSLContext(javax.net.ssl.SSLContext)
{
javax.net.ssl.SSLContext v;
org.fusesource.hawtdispatch.transport.SslTransport v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v := @parameter: javax.net.ssl.SSLContext;
v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLContext sslContext> = v;
return;
}
public static org.fusesource.hawtdispatch.transport.SslTransport createTransport(java.net.URI) throws java.lang.Exception
{
javax.net.ssl.SSLContext v;
java.lang.String v, v;
java.net.URI v;
org.fusesource.hawtdispatch.transport.SslTransport v;
v := @parameter: java.net.URI;
v = virtualinvoke v.<java.net.URI: java.lang.String getScheme()>();
v = staticinvoke <org.fusesource.hawtdispatch.transport.SslTransport: java.lang.String protocol(java.lang.String)>(v);
if v == null goto label;
v = new org.fusesource.hawtdispatch.transport.SslTransport;
specialinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport: void <init>()>();
v = staticinvoke <javax.net.ssl.SSLContext: javax.net.ssl.SSLContext getInstance(java.lang.String)>(v);
virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport: void setSSLContext(javax.net.ssl.SSLContext)>(v);
return v;
label:
return null;
}
public javax.net.ssl.SSLSession getSSLSession()
{
javax.net.ssl.SSLSession v;
org.fusesource.hawtdispatch.transport.SslTransport v;
javax.net.ssl.SSLEngine v, v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
if v != null goto label;
v = null;
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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;
org.fusesource.hawtdispatch.transport.SslTransport 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;
java.security.cert.X509Certificate[] v;
boolean v;
javax.net.ssl.SSLPeerUnverifiedException v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: 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 connecting(java.net.URI, java.net.URI) throws java.lang.Exception
{
javax.net.ssl.SSLContext v;
java.lang.AssertionError v;
org.fusesource.hawtdispatch.transport.SslTransport v;
javax.net.ssl.SSLEngine v, v, v;
int v;
java.lang.String v;
java.net.URI v, v;
boolean v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v := @parameter: java.net.URI;
v := @parameter: java.net.URI;
v = <org.fusesource.hawtdispatch.transport.SslTransport: boolean $assertionsDisabled>;
if v != 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: javax.net.ssl.SSLContext sslContext>;
v = virtualinvoke v.<java.net.URI: java.lang.String getHost()>();
v = virtualinvoke v.<java.net.URI: int getPort()>();
v = virtualinvoke v.<javax.net.ssl.SSLContext: javax.net.ssl.SSLEngine createSSLEngine(java.lang.String,int)>(v, v);
v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine> = v;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void setUseClientMode(boolean)>(1);
specialinvoke v.<org.fusesource.hawtdispatch.transport.TcpTransport: void connecting(java.net.URI,java.net.URI)>(v, v);
return;
}
public void connected(java.nio.channels.SocketChannel) throws java.lang.Exception
{
org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth v;
javax.net.ssl.SSLContext v;
java.nio.channels.SocketChannel v;
int[] v;
boolean v, v;
org.fusesource.hawtdispatch.transport.SslTransport v;
java.lang.Object[] v;
java.lang.String[] v, v, v, v, v;
java.util.ArrayList v;
javax.net.ssl.SSLEngine v, v, v, v, v, v, v, v, v, v, v;
int v, v, v, v, v, v, v;
java.lang.String v, v, v, v, v, v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v := @parameter: java.nio.channels.SocketChannel;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
if v != null goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLContext sslContext>;
v = virtualinvoke v.<javax.net.ssl.SSLContext: javax.net.ssl.SSLEngine createSSLEngine()>();
v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine> = v;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void setUseClientMode(boolean)>(0);
v = <org.fusesource.hawtdispatch.transport.SslTransport$4: int[] $SwitchMap$org$fusesource$hawtdispatch$transport$SslTransport$ClientAuth>;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth clientAuth>;
v = virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport$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.SslTransport: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void setWantClientAuth(boolean)>(1);
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void setNeedClientAuth(boolean)>(1);
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void setWantClientAuth(boolean)>(0);
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.lang.String enabledCipherSuites>;
if v == null goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.lang.String enabledCipherSuites>;
v = specialinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport: java.lang.String[] splitOnCommas(java.lang.String)>(v);
virtualinvoke v.<javax.net.ssl.SSLEngine: void setEnabledCipherSuites(java.lang.String[])>(v);
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: java.lang.String[] getSupportedCipherSuites()>();
virtualinvoke v.<javax.net.ssl.SSLEngine: void setEnabledCipherSuites(java.lang.String[])>(v);
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.lang.String disabledCypherSuites>;
if v == null goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.lang.String disabledCypherSuites>;
v = specialinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport: java.lang.String[] splitOnCommas(java.lang.String)>(v);
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: java.lang.String[] getEnabledCipherSuites()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = 1;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.String: boolean contains(java.lang.CharSequence)>(v);
if v == 0 goto label;
v = 0;
goto label;
label:
v = v + 1;
goto label;
label:
if v == 0 goto label;
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
label:
v = v + 1;
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
v = virtualinvoke v.<java.util.ArrayList: int size()>();
v = newarray (java.lang.String)[v];
v = virtualinvoke v.<java.util.ArrayList: java.lang.Object[] toArray(java.lang.Object[])>(v);
virtualinvoke v.<javax.net.ssl.SSLEngine: void setEnabledCipherSuites(java.lang.String[])>(v);
label:
specialinvoke v.<org.fusesource.hawtdispatch.transport.TcpTransport: void connected(java.nio.channels.SocketChannel)>(v);
return;
}
private java.lang.String[] splitOnCommas(java.lang.String)
{
java.lang.Object[] v;
java.lang.String[] v, v;
org.fusesource.hawtdispatch.transport.SslTransport v;
java.util.ArrayList v;
int v, v, v;
java.lang.String v, v, v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v := @parameter: java.lang.String;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>(",");
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.util.ArrayList: int size()>();
v = newarray (java.lang.String)[v];
v = virtualinvoke v.<java.util.ArrayList: java.lang.Object[] toArray(java.lang.Object[])>(v);
return v;
}
protected void initializeChannel() throws java.lang.Exception
{
org.fusesource.hawtdispatch.transport.SslTransport v;
java.nio.ByteBuffer v, v, v;
javax.net.ssl.SSLEngine v;
javax.net.ssl.SSLSession v;
int v, v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
specialinvoke v.<org.fusesource.hawtdispatch.transport.TcpTransport: void initializeChannel()>();
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: java.nio.ByteBuffer readBuffer> = v;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: java.nio.ByteBuffer writeBuffer> = v;
return;
}
protected void onConnected() throws java.io.IOException
{
org.fusesource.hawtdispatch.transport.SslTransport v;
javax.net.ssl.SSLEngine v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
specialinvoke v.<org.fusesource.hawtdispatch.transport.TcpTransport: void onConnected()>();
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
virtualinvoke v.<javax.net.ssl.SSLEngine: void beginHandshake()>();
virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport: void handshake()>();
return;
}
public void flush()
{
javax.net.ssl.SSLEngineResult$HandshakeStatus v, v;
org.fusesource.hawtdispatch.transport.SslTransport v;
javax.net.ssl.SSLEngine v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: void handshake()>();
goto label;
label:
specialinvoke v.<org.fusesource.hawtdispatch.transport.TcpTransport: void flush()>();
label:
return;
}
public void drainInbound()
{
javax.net.ssl.SSLEngineResult$HandshakeStatus v, v;
org.fusesource.hawtdispatch.transport.SslTransport v;
javax.net.ssl.SSLEngine v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: void handshake()>();
goto label;
label:
specialinvoke v.<org.fusesource.hawtdispatch.transport.TcpTransport: void drainInbound()>();
label:
return;
}
protected boolean transportFlush() throws java.io.IOException
{
org.fusesource.hawtdispatch.transport.SslTransport v;
java.nio.ByteBuffer v, v, v, v, v;
int v;
java.nio.channels.WritableByteChannel v;
boolean v, v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: boolean writeFlushing>;
if v == 0 goto label;
v = specialinvoke v.<org.fusesource.hawtdispatch.transport.TcpTransport: java.nio.channels.WritableByteChannel getWriteChannel()>();
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.nio.ByteBuffer writeBuffer>;
interfaceinvoke v.<java.nio.channels.WritableByteChannel: int write(java.nio.ByteBuffer)>(v);
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.nio.ByteBuffer writeBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: boolean hasRemaining()>();
if v != 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.nio.ByteBuffer writeBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer clear()>();
v.<org.fusesource.hawtdispatch.transport.SslTransport: boolean writeFlushing> = 0;
virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport: void suspendWrite()>();
return 1;
label:
return 0;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.nio.ByteBuffer writeBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
if v == 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.nio.ByteBuffer writeBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer flip()>();
v.<org.fusesource.hawtdispatch.transport.SslTransport: boolean writeFlushing> = 1;
virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport: void resumeWrite()>();
goto label;
label:
return 1;
}
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;
org.fusesource.hawtdispatch.transport.SslTransport$1 v;
javax.net.ssl.SSLEngineResult$Status v, v, v, v;
boolean v, v, v, v, v, v;
org.fusesource.hawtdispatch.DispatchQueue v;
org.fusesource.hawtdispatch.transport.SslTransport v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v := @parameter: java.nio.ByteBuffer;
v = virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: 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.SslTransport: javax.net.ssl.SSLEngine engine>;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: 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.SslTransport: boolean transportFlush()>();
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 CLOSED>;
if v != v goto label;
label:
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
if v != 0 goto label;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: org.fusesource.hawtdispatch.DispatchQueue dispatchQueue>;
v = new org.fusesource.hawtdispatch.transport.SslTransport$1;
specialinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport$1: void <init>(org.fusesource.hawtdispatch.transport.SslTransport)>(v);
interfaceinvoke v.<org.fusesource.hawtdispatch.DispatchQueue: void execute(org.fusesource.hawtdispatch.Task)>(v);
label:
return v;
}
private int secure_read(java.nio.ByteBuffer) throws java.io.IOException
{
byte[] 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;
org.fusesource.hawtdispatch.transport.SslTransport$2 v;
boolean v, v, v, v, v, v;
org.fusesource.hawtdispatch.DispatchQueue v;
org.fusesource.hawtdispatch.transport.SslTransport v;
java.lang.AssertionError v;
javax.net.ssl.SSLEngine v, v, v, v, v, v;
javax.net.ssl.SSLEngineResult v;
javax.net.ssl.SSLSession v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
javax.net.ssl.SSLEngineResult$Status v, v, v;
java.nio.channels.ReadableByteChannel v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v := @parameter: java.nio.ByteBuffer;
v = 0;
label:
v = virtualinvoke v.<java.nio.ByteBuffer: boolean hasRemaining()>();
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: 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.SslTransport: 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.SslTransport: java.nio.ByteBuffer readOverflowBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: byte[] array()>();
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: java.nio.ByteBuffer readOverflowBuffer>;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: java.nio.ByteBuffer readOverflowBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: boolean hasRemaining()>();
if v != 0 goto label;
v.<org.fusesource.hawtdispatch.transport.SslTransport: java.nio.ByteBuffer readOverflowBuffer> = null;
label:
v = v + v;
goto label;
label:
return v;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: boolean readUnderflow>;
if v == 0 goto label;
v = specialinvoke v.<org.fusesource.hawtdispatch.transport.TcpTransport: java.nio.channels.ReadableByteChannel getReadChannel()>();
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.nio.ByteBuffer readBuffer>;
v = interfaceinvoke v.<java.nio.channels.ReadableByteChannel: int read(java.nio.ByteBuffer)>(v);
v = (int) -1;
if v != v goto label;
if v != 0 goto label;
v = (int) -1;
return v;
label:
return v;
label:
if v != 0 goto label;
return v;
label:
v.<org.fusesource.hawtdispatch.transport.SslTransport: boolean readUnderflow> = 0;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.nio.ByteBuffer readBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer flip()>();
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: 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.SslTransport: java.nio.ByteBuffer readOverflowBuffer> = v;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: javax.net.ssl.SSLEngine engine>;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.nio.ByteBuffer readBuffer>;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: java.nio.ByteBuffer readOverflowBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
if v != 0 goto label;
v.<org.fusesource.hawtdispatch.transport.SslTransport: java.nio.ByteBuffer readOverflowBuffer> = null;
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.nio.ByteBuffer readOverflowBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer flip()>();
label:
v = <org.fusesource.hawtdispatch.transport.SslTransport$4: 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.SslTransport: 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.SslTransport: 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;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: org.fusesource.hawtdispatch.DispatchQueue dispatchQueue>;
v = new org.fusesource.hawtdispatch.transport.SslTransport$2;
specialinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport$2: void <init>(org.fusesource.hawtdispatch.transport.SslTransport)>(v);
interfaceinvoke v.<org.fusesource.hawtdispatch.DispatchQueue: void execute(org.fusesource.hawtdispatch.Task)>(v);
goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.nio.ByteBuffer readBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer compact()>();
v.<org.fusesource.hawtdispatch.transport.SslTransport: 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;
}
public void handshake()
{
javax.net.ssl.SSLEngineResult$HandshakeStatus v, v, v, v, v, v, v, v, v, v;
java.lang.Integer v, v, v, v;
java.lang.Runnable v;
java.nio.ByteBuffer v, v;
int[] v;
org.fusesource.hawtdispatch.transport.SslTransport$3 v;
boolean v;
java.io.EOFException v;
org.fusesource.hawtdispatch.transport.SslTransport v;
java.lang.Throwable v;
javax.net.ssl.SSLEngine v, v, v, v, v, v, v;
int v, v, v, v;
java.lang.String v;
java.io.PrintStream v;
java.util.concurrent.Executor v;
java.io.IOException v;
org.fusesource.hawtdispatch.CustomDispatchSource v, v, v, v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
label:
v = virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport: boolean transportFlush()>();
if v != 0 goto label;
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: org.fusesource.hawtdispatch.CustomDispatchSource drainOutboundSource>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(1);
interfaceinvoke v.<org.fusesource.hawtdispatch.CustomDispatchSource: void merge(java.lang.Object)>(v);
specialinvoke v.<org.fusesource.hawtdispatch.transport.TcpTransport: void drainInbound()>();
label:
return;
label:
v = <org.fusesource.hawtdispatch.transport.SslTransport$4: int[] $SwitchMap$javax$net$ssl$SSLEngineResult$HandshakeStatus>;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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.SslTransport: 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.SslTransport: java.util.concurrent.Executor blockingExecutor>;
v = new org.fusesource.hawtdispatch.transport.SslTransport$3;
specialinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport$3: void <init>(org.fusesource.hawtdispatch.transport.SslTransport,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.SslTransport: 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.SslTransport: 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 = <java.lang.System: java.io.PrintStream err>;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: org.fusesource.hawtdispatch.CustomDispatchSource drainOutboundSource>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(1);
interfaceinvoke v.<org.fusesource.hawtdispatch.CustomDispatchSource: void merge(java.lang.Object)>(v);
specialinvoke v.<org.fusesource.hawtdispatch.transport.TcpTransport: void drainInbound()>();
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport: void onTransportFailure(java.io.IOException)>(v);
label:
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: org.fusesource.hawtdispatch.CustomDispatchSource drainOutboundSource>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(1);
interfaceinvoke v.<org.fusesource.hawtdispatch.CustomDispatchSource: void merge(java.lang.Object)>(v);
specialinvoke v.<org.fusesource.hawtdispatch.transport.TcpTransport: void drainInbound()>();
goto label;
label:
v := @caughtexception;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: 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;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: org.fusesource.hawtdispatch.CustomDispatchSource drainOutboundSource>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(1);
interfaceinvoke v.<org.fusesource.hawtdispatch.CustomDispatchSource: void merge(java.lang.Object)>(v);
specialinvoke v.<org.fusesource.hawtdispatch.transport.TcpTransport: void drainInbound()>();
label:
throw 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.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public java.nio.channels.ReadableByteChannel getReadChannel()
{
org.fusesource.hawtdispatch.transport.SslTransport$SSLChannel v;
org.fusesource.hawtdispatch.transport.SslTransport v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: org.fusesource.hawtdispatch.transport.SslTransport$SSLChannel ssl_channel>;
return v;
}
public java.nio.channels.WritableByteChannel getWriteChannel()
{
org.fusesource.hawtdispatch.transport.SslTransport$SSLChannel v;
org.fusesource.hawtdispatch.transport.SslTransport v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: org.fusesource.hawtdispatch.transport.SslTransport$SSLChannel ssl_channel>;
return v;
}
public java.lang.String getClientAuth()
{
org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth v;
java.lang.String v;
org.fusesource.hawtdispatch.transport.SslTransport v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth clientAuth>;
v = virtualinvoke v.<org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth: java.lang.String name()>();
return v;
}
public void setClientAuth(java.lang.String)
{
org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth v;
java.lang.String v, v;
org.fusesource.hawtdispatch.transport.SslTransport v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: java.lang.String toUpperCase()>();
v = staticinvoke <org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth: org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth valueOf(java.lang.String)>(v);
v.<org.fusesource.hawtdispatch.transport.SslTransport: org.fusesource.hawtdispatch.transport.SslTransport$ClientAuth clientAuth> = v;
return;
}
public java.lang.String getDisabledCypherSuites()
{
java.lang.String v;
org.fusesource.hawtdispatch.transport.SslTransport v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.lang.String disabledCypherSuites>;
return v;
}
public java.lang.String getEnabledCypherSuites()
{
java.lang.String v;
org.fusesource.hawtdispatch.transport.SslTransport v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v = v.<org.fusesource.hawtdispatch.transport.SslTransport: java.lang.String enabledCipherSuites>;
return v;
}
public void setDisabledCypherSuites(java.lang.String)
{
java.lang.String v;
org.fusesource.hawtdispatch.transport.SslTransport v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v := @parameter: java.lang.String;
v.<org.fusesource.hawtdispatch.transport.SslTransport: java.lang.String disabledCypherSuites> = v;
return;
}
public void setEnabledCypherSuites(java.lang.String)
{
java.lang.String v;
org.fusesource.hawtdispatch.transport.SslTransport v;
v := @this: org.fusesource.hawtdispatch.transport.SslTransport;
v := @parameter: java.lang.String;
v.<org.fusesource.hawtdispatch.transport.SslTransport: java.lang.String enabledCipherSuites> = v;
return;
}
static void <clinit>()
{
java.lang.Class v;
boolean v, v;
v = class "Lorg/fusesource/hawtdispatch/transport/SslTransport;";
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.SslTransport: boolean $assertionsDisabled> = v;
return;
}
}