final class io.netty.handler.ssl.JdkAlpnSslUtils extends java.lang.Object
{
private static final io.netty.util.internal.logging.InternalLogger logger;
private static final java.lang.reflect.Method SET_APPLICATION_PROTOCOLS;
private static final java.lang.reflect.Method GET_APPLICATION_PROTOCOL;
private static final java.lang.reflect.Method GET_HANDSHAKE_APPLICATION_PROTOCOL;
private static final java.lang.reflect.Method SET_HANDSHAKE_APPLICATION_PROTOCOL_SELECTOR;
private static final java.lang.reflect.Method GET_HANDSHAKE_APPLICATION_PROTOCOL_SELECTOR;
private void <init>()
{
io.netty.handler.ssl.JdkAlpnSslUtils v;
v := @this: io.netty.handler.ssl.JdkAlpnSslUtils;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
static boolean supportsAlpn()
{
java.lang.reflect.Method v;
boolean v;
v = <io.netty.handler.ssl.JdkAlpnSslUtils: java.lang.reflect.Method GET_APPLICATION_PROTOCOL>;
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
static java.lang.String getApplicationProtocol(javax.net.ssl.SSLEngine)
{
java.lang.IllegalStateException v;
java.lang.UnsupportedOperationException v;
java.lang.Object[] v;
java.lang.Object v;
java.lang.reflect.Method v;
java.lang.Exception v;
javax.net.ssl.SSLEngine v;
v := @parameter: javax.net.ssl.SSLEngine;
label:
v = <io.netty.handler.ssl.JdkAlpnSslUtils: java.lang.reflect.Method GET_APPLICATION_PROTOCOL>;
v = newarray (java.lang.Object)[0];
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
return v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.Throwable)>(v);
throw v;
catch java.lang.UnsupportedOperationException from label to label with label;
catch java.lang.Exception from label to label with label;
}
static java.lang.String getHandshakeApplicationProtocol(javax.net.ssl.SSLEngine)
{
java.lang.IllegalStateException v;
java.lang.UnsupportedOperationException v;
java.lang.Object[] v;
java.lang.Object v;
java.lang.reflect.Method v;
java.lang.Exception v;
javax.net.ssl.SSLEngine v;
v := @parameter: javax.net.ssl.SSLEngine;
label:
v = <io.netty.handler.ssl.JdkAlpnSslUtils: java.lang.reflect.Method GET_HANDSHAKE_APPLICATION_PROTOCOL>;
v = newarray (java.lang.Object)[0];
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
return v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.Throwable)>(v);
throw v;
catch java.lang.UnsupportedOperationException from label to label with label;
catch java.lang.Exception from label to label with label;
}
static void setApplicationProtocols(javax.net.ssl.SSLEngine, java.util.List)
{
java.lang.IllegalStateException v;
java.lang.UnsupportedOperationException v;
java.lang.Object[] v, v;
javax.net.ssl.SSLParameters v;
java.lang.String[] v;
java.lang.Exception v;
javax.net.ssl.SSLEngine v;
java.util.List v;
java.lang.reflect.Method v;
v := @parameter: javax.net.ssl.SSLEngine;
v := @parameter: java.util.List;
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLParameters getSSLParameters()>();
v = <io.netty.util.internal.EmptyArrays: java.lang.String[] EMPTY_STRINGS>;
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
label:
v = <io.netty.handler.ssl.JdkAlpnSslUtils: java.lang.reflect.Method SET_APPLICATION_PROTOCOLS>;
v = newarray (java.lang.Object)[1];
v[0] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
virtualinvoke v.<javax.net.ssl.SSLEngine: void setSSLParameters(javax.net.ssl.SSLParameters)>(v);
return;
catch java.lang.UnsupportedOperationException from label to label with label;
catch java.lang.Exception from label to label with label;
}
static void setHandshakeApplicationProtocolSelector(javax.net.ssl.SSLEngine, java.util.function.BiFunction)
{
java.lang.IllegalStateException v;
java.lang.UnsupportedOperationException v;
java.lang.Object[] v;
java.util.function.BiFunction v;
java.lang.reflect.Method v;
java.lang.Exception v;
javax.net.ssl.SSLEngine v;
v := @parameter: javax.net.ssl.SSLEngine;
v := @parameter: java.util.function.BiFunction;
label:
v = <io.netty.handler.ssl.JdkAlpnSslUtils: java.lang.reflect.Method SET_HANDSHAKE_APPLICATION_PROTOCOL_SELECTOR>;
v = newarray (java.lang.Object)[1];
v[0] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
return;
catch java.lang.UnsupportedOperationException from label to label with label;
catch java.lang.Exception from label to label with label;
}
static java.util.function.BiFunction getHandshakeApplicationProtocolSelector(javax.net.ssl.SSLEngine)
{
java.lang.IllegalStateException v;
java.lang.UnsupportedOperationException v;
java.lang.Object[] v;
java.lang.Object v;
java.lang.reflect.Method v;
java.lang.Exception v;
javax.net.ssl.SSLEngine v;
v := @parameter: javax.net.ssl.SSLEngine;
label:
v = <io.netty.handler.ssl.JdkAlpnSslUtils: java.lang.reflect.Method GET_HANDSHAKE_APPLICATION_PROTOCOL_SELECTOR>;
v = newarray (java.lang.Object)[0];
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
return v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.Throwable)>(v);
throw v;
catch java.lang.UnsupportedOperationException from label to label with label;
catch java.lang.Exception from label to label with label;
}
static void <clinit>()
{
java.lang.Throwable v;
javax.net.ssl.SSLContext v;
java.lang.Object[] v, v, v, v, v;
javax.net.ssl.SSLParameters v;
java.lang.String[] v;
java.lang.Integer v;
javax.net.ssl.SSLEngine v;
io.netty.handler.ssl.JdkAlpnSslUtils$2 v;
io.netty.handler.ssl.JdkAlpnSslUtils$1 v;
io.netty.handler.ssl.JdkAlpnSslUtils$4 v;
io.netty.handler.ssl.JdkAlpnSslUtils$3 v;
io.netty.handler.ssl.JdkAlpnSslUtils$6 v;
io.netty.handler.ssl.JdkAlpnSslUtils$5 v;
int v;
io.netty.util.internal.logging.InternalLogger v, v;
java.lang.Object v, v, v, v, v;
v = staticinvoke <io.netty.util.internal.logging.InternalLoggerFactory: io.netty.util.internal.logging.InternalLogger getInstance(java.lang.Class)>(class "Lio/netty/handler/ssl/JdkAlpnSslUtils;");
<io.netty.handler.ssl.JdkAlpnSslUtils: io.netty.util.internal.logging.InternalLogger logger> = v;
label:
v = staticinvoke <javax.net.ssl.SSLContext: javax.net.ssl.SSLContext getInstance(java.lang.String)>("TLS");
virtualinvoke v.<javax.net.ssl.SSLContext: void init(javax.net.ssl.KeyManager[],javax.net.ssl.TrustManager[],java.security.SecureRandom)>(null, null, null);
v = virtualinvoke v.<javax.net.ssl.SSLContext: javax.net.ssl.SSLEngine createSSLEngine()>();
v = new io.netty.handler.ssl.JdkAlpnSslUtils$1;
specialinvoke v.<io.netty.handler.ssl.JdkAlpnSslUtils$1: void <init>()>();
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedExceptionAction)>(v);
v = newarray (java.lang.Object)[0];
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = new io.netty.handler.ssl.JdkAlpnSslUtils$2;
specialinvoke v.<io.netty.handler.ssl.JdkAlpnSslUtils$2: void <init>()>();
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedExceptionAction)>(v);
v = newarray (java.lang.Object)[0];
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = new io.netty.handler.ssl.JdkAlpnSslUtils$3;
specialinvoke v.<io.netty.handler.ssl.JdkAlpnSslUtils$3: void <init>()>();
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedExceptionAction)>(v);
v = virtualinvoke v.<javax.net.ssl.SSLEngine: javax.net.ssl.SSLParameters getSSLParameters()>();
v = newarray (java.lang.Object)[1];
v = <io.netty.util.internal.EmptyArrays: java.lang.String[] EMPTY_STRINGS>;
v[0] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = new io.netty.handler.ssl.JdkAlpnSslUtils$4;
specialinvoke v.<io.netty.handler.ssl.JdkAlpnSslUtils$4: void <init>()>();
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedExceptionAction)>(v);
v = newarray (java.lang.Object)[1];
v = new io.netty.handler.ssl.JdkAlpnSslUtils$5;
specialinvoke v.<io.netty.handler.ssl.JdkAlpnSslUtils$5: void <init>()>();
v[0] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = new io.netty.handler.ssl.JdkAlpnSslUtils$6;
specialinvoke v.<io.netty.handler.ssl.JdkAlpnSslUtils$6: void <init>()>();
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedExceptionAction)>(v);
v = newarray (java.lang.Object)[0];
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = staticinvoke <io.netty.util.internal.PlatformDependent: int javaVersion()>();
if v < 9 goto label;
v = <io.netty.handler.ssl.JdkAlpnSslUtils: io.netty.util.internal.logging.InternalLogger logger>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: void error(java.lang.String,java.lang.Object,java.lang.Object)>("Unable to initialize JdkAlpnSslUtils, but the detected java version was: {}", v, v);
label:
v = null;
v = null;
v = null;
v = null;
v = null;
label:
<io.netty.handler.ssl.JdkAlpnSslUtils: java.lang.reflect.Method GET_HANDSHAKE_APPLICATION_PROTOCOL> = v;
<io.netty.handler.ssl.JdkAlpnSslUtils: java.lang.reflect.Method GET_APPLICATION_PROTOCOL> = v;
<io.netty.handler.ssl.JdkAlpnSslUtils: java.lang.reflect.Method SET_APPLICATION_PROTOCOLS> = v;
<io.netty.handler.ssl.JdkAlpnSslUtils: java.lang.reflect.Method SET_HANDSHAKE_APPLICATION_PROTOCOL_SELECTOR> = v;
<io.netty.handler.ssl.JdkAlpnSslUtils: java.lang.reflect.Method GET_HANDSHAKE_APPLICATION_PROTOCOL_SELECTOR> = v;
return;
catch java.lang.Throwable from label to label with label;
}
}