final class io.netty.handler.ssl.SslUtils extends java.lang.Object
{
private static final io.netty.util.internal.logging.InternalLogger logger;
static final java.util.Set TLSV13_CIPHERS;
static final int GMSSL_PROTOCOL_VERSION;
static final java.lang.String INVALID_CIPHER;
static final int SSL_CONTENT_TYPE_CHANGE_CIPHER_SPEC;
static final int SSL_CONTENT_TYPE_ALERT;
static final int SSL_CONTENT_TYPE_HANDSHAKE;
static final int SSL_CONTENT_TYPE_APPLICATION_DATA;
static final int SSL_CONTENT_TYPE_EXTENSION_HEARTBEAT;
static final int SSL_RECORD_HEADER_LENGTH;
static final int NOT_ENOUGH_DATA;
static final int NOT_ENCRYPTED;
static final java.lang.String[] DEFAULT_CIPHER_SUITES;
static final java.lang.String[] DEFAULT_TLSV13_CIPHER_SUITES;
static final java.lang.String[] TLSV13_CIPHER_SUITES;
private static final boolean TLSV1_3_JDK_SUPPORTED;
private static final boolean TLSV1_3_JDK_DEFAULT_ENABLED;
static boolean isTLSv13SupportedByJDK(java.security.Provider)
{
boolean v, v;
java.security.Provider v;
v := @parameter: java.security.Provider;
if v != null goto label;
v = <io.netty.handler.ssl.SslUtils: boolean TLSV1_3_JDK_SUPPORTED>;
return v;
label:
v = staticinvoke <io.netty.handler.ssl.SslUtils: boolean isTLSv13SupportedByJDK0(java.security.Provider)>(v);
return v;
}
private static boolean isTLSv13SupportedByJDK0(java.security.Provider)
{
java.lang.Throwable v;
javax.net.ssl.SSLContext v;
io.netty.util.internal.logging.InternalLogger v;
javax.net.ssl.SSLParameters v;
java.lang.String[] v;
boolean v;
java.security.Provider v;
v := @parameter: java.security.Provider;
label:
v = staticinvoke <io.netty.handler.ssl.SslUtils: javax.net.ssl.SSLContext newInitContext(java.security.Provider)>(v);
v = virtualinvoke v.<javax.net.ssl.SSLContext: javax.net.ssl.SSLParameters getSupportedSSLParameters()>();
v = virtualinvoke v.<javax.net.ssl.SSLParameters: java.lang.String[] getProtocols()>();
v = staticinvoke <io.netty.handler.ssl.SslUtils: boolean arrayContains(java.lang.String[],java.lang.String)>(v, "TLSv.3");
label:
return v;
label:
v := @caughtexception;
v = <io.netty.handler.ssl.SslUtils: io.netty.util.internal.logging.InternalLogger logger>;
interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Unable to detect if JDK SSLEngine with provider {} supports TLSv.3, assuming no", v, v);
return 0;
catch java.lang.Throwable from label to label with label;
}
static boolean isTLSv13EnabledByJDK(java.security.Provider)
{
boolean v, v;
java.security.Provider v;
v := @parameter: java.security.Provider;
if v != null goto label;
v = <io.netty.handler.ssl.SslUtils: boolean TLSV1_3_JDK_DEFAULT_ENABLED>;
return v;
label:
v = staticinvoke <io.netty.handler.ssl.SslUtils: boolean isTLSv13EnabledByJDK0(java.security.Provider)>(v);
return v;
}
private static boolean isTLSv13EnabledByJDK0(java.security.Provider)
{
java.lang.Throwable v;
javax.net.ssl.SSLContext v;
io.netty.util.internal.logging.InternalLogger v;
javax.net.ssl.SSLParameters v;
java.lang.String[] v;
boolean v;
java.security.Provider v;
v := @parameter: java.security.Provider;
label:
v = staticinvoke <io.netty.handler.ssl.SslUtils: javax.net.ssl.SSLContext newInitContext(java.security.Provider)>(v);
v = virtualinvoke v.<javax.net.ssl.SSLContext: javax.net.ssl.SSLParameters getDefaultSSLParameters()>();
v = virtualinvoke v.<javax.net.ssl.SSLParameters: java.lang.String[] getProtocols()>();
v = staticinvoke <io.netty.handler.ssl.SslUtils: boolean arrayContains(java.lang.String[],java.lang.String)>(v, "TLSv.3");
label:
return v;
label:
v := @caughtexception;
v = <io.netty.handler.ssl.SslUtils: io.netty.util.internal.logging.InternalLogger logger>;
interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Unable to detect if JDK SSLEngine with provider {} enables TLSv.3 by default, assuming no", v, v);
return 0;
catch java.lang.Throwable from label to label with label;
}
private static javax.net.ssl.SSLContext newInitContext(java.security.Provider) throws java.security.NoSuchAlgorithmException, java.security.KeyManagementException
{
javax.net.ssl.SSLContext v;
javax.net.ssl.TrustManager[] v;
java.security.Provider v;
v := @parameter: java.security.Provider;
if v != null goto label;
v = staticinvoke <javax.net.ssl.SSLContext: javax.net.ssl.SSLContext getInstance(java.lang.String)>("TLS");
goto label;
label:
v = staticinvoke <javax.net.ssl.SSLContext: javax.net.ssl.SSLContext getInstance(java.lang.String,java.security.Provider)>("TLS", v);
label:
v = newarray (javax.net.ssl.TrustManager)[0];
virtualinvoke v.<javax.net.ssl.SSLContext: void init(javax.net.ssl.KeyManager[],javax.net.ssl.TrustManager[],java.security.SecureRandom)>(null, v, null);
return v;
}
static javax.net.ssl.SSLContext getSSLContext(java.lang.String) throws java.security.NoSuchAlgorithmException, java.security.KeyManagementException, java.security.NoSuchProviderException
{
javax.net.ssl.SSLContext v;
javax.net.ssl.TrustManager[] v;
java.lang.String v, v, v;
boolean v;
v := @parameter: java.lang.String;
v = staticinvoke <io.netty.util.internal.StringUtil: boolean isNullOrEmpty(java.lang.String)>(v);
if v == 0 goto label;
v = staticinvoke <io.netty.handler.ssl.SslUtils: java.lang.String getTlsVersion()>();
v = staticinvoke <javax.net.ssl.SSLContext: javax.net.ssl.SSLContext getInstance(java.lang.String)>(v);
goto label;
label:
v = staticinvoke <io.netty.handler.ssl.SslUtils: java.lang.String getTlsVersion()>();
v = staticinvoke <javax.net.ssl.SSLContext: javax.net.ssl.SSLContext getInstance(java.lang.String,java.lang.String)>(v, v);
label:
v = newarray (javax.net.ssl.TrustManager)[0];
virtualinvoke v.<javax.net.ssl.SSLContext: void init(javax.net.ssl.KeyManager[],javax.net.ssl.TrustManager[],java.security.SecureRandom)>(null, v, null);
return v;
}
private static java.lang.String getTlsVersion()
{
java.lang.String v;
boolean v;
v = <io.netty.handler.ssl.SslUtils: boolean TLSV1_3_JDK_SUPPORTED>;
if v == 0 goto label;
v = "TLSv.3";
goto label;
label:
v = "TLSv.2";
label:
return v;
}
static boolean arrayContains(java.lang.String[], java.lang.String)
{
int v, v;
java.lang.String[] v;
java.lang.String v, v;
boolean v;
v := @parameter: java.lang.String[];
v := @parameter: java.lang.String;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
return 1;
label:
v = v + 1;
goto label;
label:
return 0;
}
static transient void addIfSupported(java.util.Set, java.util.List, java.lang.String[])
{
java.util.List v;
int v, v;
java.util.Set v;
java.lang.String[] v;
java.lang.String v;
boolean v;
v := @parameter: java.util.Set;
v := @parameter: java.util.List;
v := @parameter: java.lang.String[];
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
v = v + 1;
goto label;
label:
return;
}
static void useFallbackCiphersIfDefaultIsEmpty(java.util.List, java.lang.Iterable)
{
java.util.Iterator v;
java.lang.Iterable v;
java.util.List v;
java.lang.Object v;
boolean v, v, v, v;
v := @parameter: java.util.List;
v := @parameter: java.lang.Iterable;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.lang.Iterable: 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.lang.String: boolean startsWith(java.lang.String)>("SSL_");
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean contains(java.lang.CharSequence)>("_RC4_");
if v != 0 goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
return;
}
static transient void useFallbackCiphersIfDefaultIsEmpty(java.util.List, java.lang.String[])
{
java.lang.String[] v;
java.util.List v, v;
v := @parameter: java.util.List;
v := @parameter: java.lang.String[];
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
staticinvoke <io.netty.handler.ssl.SslUtils: void useFallbackCiphersIfDefaultIsEmpty(java.util.List,java.lang.Iterable)>(v, v);
return;
}
static javax.net.ssl.SSLHandshakeException toSSLHandshakeException(java.lang.Throwable)
{
java.lang.Throwable v, v;
javax.net.ssl.SSLHandshakeException v;
java.lang.String v;
boolean v;
v := @parameter: java.lang.Throwable;
v = v instanceof javax.net.ssl.SSLHandshakeException;
if v == 0 goto label;
return v;
label:
v = new javax.net.ssl.SSLHandshakeException;
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
specialinvoke v.<javax.net.ssl.SSLHandshakeException: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<javax.net.ssl.SSLHandshakeException: java.lang.Throwable initCause(java.lang.Throwable)>(v);
return v;
}
static int getEncryptedPacketLength(io.netty.buffer.ByteBuf, int)
{
short v, v, v, v, v, v, v, v, v, v;
byte v, v;
io.netty.buffer.ByteBuf v;
int v, v, v, v, v, v, v, v, v, v, v;
boolean v;
v := @parameter: io.netty.buffer.ByteBuf;
v := @parameter: int;
v = 0;
v = virtualinvoke v.<io.netty.buffer.ByteBuf: short getUnsignedByte(int)>(v);
tableswitch(v)
{
case 20: goto label;
case 21: goto label;
case 22: goto label;
case 23: goto label;
case 24: goto label;
default: goto label;
};
label:
v = 1;
goto label;
label:
v = 0;
label:
if v == 0 goto label;
v = v + 1;
v = virtualinvoke v.<io.netty.buffer.ByteBuf: short getUnsignedByte(int)>(v);
if v == 3 goto label;
v = v + 1;
v = virtualinvoke v.<io.netty.buffer.ByteBuf: short getShort(int)>(v);
if v != 257 goto label;
label:
v = v + 3;
v = staticinvoke <io.netty.handler.ssl.SslUtils: int unsignedShortBE(io.netty.buffer.ByteBuf,int)>(v, v);
v = v + 5;
if v > 5 goto label;
v = 0;
goto label;
label:
v = 0;
label:
if v != 0 goto label;
v = virtualinvoke v.<io.netty.buffer.ByteBuf: short getUnsignedByte(int)>(v);
v = v & 128;
if v == 0 goto label;
v = 2;
goto label;
label:
v = 3;
label:
v = v;
v = v + v;
v = v + 1;
v = virtualinvoke v.<io.netty.buffer.ByteBuf: short getUnsignedByte(int)>(v);
if v == 2 goto label;
if v != 3 goto label;
label:
if v != 2 goto label;
v = staticinvoke <io.netty.handler.ssl.SslUtils: short shortBE(io.netty.buffer.ByteBuf,int)>(v, v);
v = v & 32767;
v = v + 2;
goto label;
label:
v = staticinvoke <io.netty.handler.ssl.SslUtils: short shortBE(io.netty.buffer.ByteBuf,int)>(v, v);
v = v & 16383;
v = v + 3;
label:
v = v;
if v > v goto label;
v = (int) -1;
return v;
label:
v = (int) -2;
return v;
label:
return v;
}
private static int unsignedShortBE(io.netty.buffer.ByteBuf, int)
{
java.nio.ByteOrder v, v;
io.netty.buffer.ByteBuf v;
int v, v, v;
v := @parameter: io.netty.buffer.ByteBuf;
v := @parameter: int;
v = virtualinvoke v.<io.netty.buffer.ByteBuf: int getUnsignedShort(int)>(v);
v = virtualinvoke v.<io.netty.buffer.ByteBuf: java.nio.ByteOrder order()>();
v = <java.nio.ByteOrder: java.nio.ByteOrder LITTLE_ENDIAN>;
if v != v goto label;
v = staticinvoke <java.lang.Integer: int reverseBytes(int)>(v);
v = v >>> 16;
label:
return v;
}
private static short shortBE(io.netty.buffer.ByteBuf, int)
{
java.nio.ByteOrder v, v;
short v;
io.netty.buffer.ByteBuf v;
int v;
v := @parameter: io.netty.buffer.ByteBuf;
v := @parameter: int;
v = virtualinvoke v.<io.netty.buffer.ByteBuf: short getShort(int)>(v);
v = virtualinvoke v.<io.netty.buffer.ByteBuf: java.nio.ByteOrder order()>();
v = <java.nio.ByteOrder: java.nio.ByteOrder LITTLE_ENDIAN>;
if v != v goto label;
v = staticinvoke <java.lang.Short: short reverseBytes(short)>(v);
label:
return v;
}
private static short unsignedByte(byte)
{
short v;
byte v;
v := @parameter: byte;
v = v & 255;
return v;
}
private static int unsignedShortBE(java.nio.ByteBuffer, int)
{
short v;
int v, v, v;
java.nio.ByteBuffer v;
v := @parameter: java.nio.ByteBuffer;
v := @parameter: int;
v = staticinvoke <io.netty.handler.ssl.SslUtils: short shortBE(java.nio.ByteBuffer,int)>(v, v);
v = (int) 65535;
v = v & v;
return v;
}
private static short shortBE(java.nio.ByteBuffer, int)
{
java.nio.ByteOrder v, v;
short v, v;
int v;
java.nio.ByteBuffer v;
v := @parameter: java.nio.ByteBuffer;
v := @parameter: int;
v = virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteOrder order()>();
v = <java.nio.ByteOrder: java.nio.ByteOrder BIG_ENDIAN>;
if v != v goto label;
v = virtualinvoke v.<java.nio.ByteBuffer: short getShort(int)>(v);
goto label;
label:
v = virtualinvoke v.<java.nio.ByteBuffer: short getShort(int)>(v);
v = staticinvoke <io.netty.buffer.ByteBufUtil: short swapShort(short)>(v);
label:
return v;
}
static int getEncryptedPacketLength(java.nio.ByteBuffer[], int)
{
java.nio.ByteBuffer v, v, v, v;
int v, v, v, v, v, v, v, v, v, v;
boolean v;
java.nio.ByteBuffer[] v;
v := @parameter: java.nio.ByteBuffer[];
v := @parameter: int;
v = v[v];
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
if v < 5 goto label;
v = staticinvoke <io.netty.handler.ssl.SslUtils: int getEncryptedPacketLength(java.nio.ByteBuffer)>(v);
return v;
label:
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer allocate(int)>(5);
label:
v = v;
v = v + 1;
v = v[v];
v = virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer duplicate()>();
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: int position()>();
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
v = v + v;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer limit(int)>(v);
label:
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer put(java.nio.ByteBuffer)>(v);
v = virtualinvoke v.<java.nio.ByteBuffer: boolean hasRemaining()>();
if v != 0 goto label;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.Buffer flip()>();
v = staticinvoke <io.netty.handler.ssl.SslUtils: int getEncryptedPacketLength(java.nio.ByteBuffer)>(v);
return v;
}
private static int getEncryptedPacketLength(java.nio.ByteBuffer)
{
java.nio.ByteBuffer v;
short v, v, v, v, v, v, v, v, v, v;
byte v, v, v, v, v, v;
int v, v, v, v, v, v, v, v, v, v, v;
boolean v;
v := @parameter: java.nio.ByteBuffer;
v = 0;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
v = virtualinvoke v.<java.nio.ByteBuffer: byte get(int)>(v);
v = staticinvoke <io.netty.handler.ssl.SslUtils: short unsignedByte(byte)>(v);
tableswitch(v)
{
case 20: goto label;
case 21: goto label;
case 22: goto label;
case 23: goto label;
case 24: goto label;
default: goto label;
};
label:
v = 1;
goto label;
label:
v = 0;
label:
if v == 0 goto label;
v = v + 1;
v = virtualinvoke v.<java.nio.ByteBuffer: byte get(int)>(v);
v = staticinvoke <io.netty.handler.ssl.SslUtils: short unsignedByte(byte)>(v);
if v == 3 goto label;
v = v + 1;
v = virtualinvoke v.<java.nio.ByteBuffer: short getShort(int)>(v);
if v != 257 goto label;
label:
v = v + 3;
v = staticinvoke <io.netty.handler.ssl.SslUtils: int unsignedShortBE(java.nio.ByteBuffer,int)>(v, v);
v = v + 5;
if v > 5 goto label;
v = 0;
goto label;
label:
v = 0;
label:
if v != 0 goto label;
v = virtualinvoke v.<java.nio.ByteBuffer: byte get(int)>(v);
v = staticinvoke <io.netty.handler.ssl.SslUtils: short unsignedByte(byte)>(v);
v = v & 128;
if v == 0 goto label;
v = 2;
goto label;
label:
v = 3;
label:
v = v;
v = v + v;
v = v + 1;
v = virtualinvoke v.<java.nio.ByteBuffer: byte get(int)>(v);
v = staticinvoke <io.netty.handler.ssl.SslUtils: short unsignedByte(byte)>(v);
if v == 2 goto label;
if v != 3 goto label;
label:
if v != 2 goto label;
v = staticinvoke <io.netty.handler.ssl.SslUtils: short shortBE(java.nio.ByteBuffer,int)>(v, v);
v = v & 32767;
v = v + 2;
goto label;
label:
v = staticinvoke <io.netty.handler.ssl.SslUtils: short shortBE(java.nio.ByteBuffer,int)>(v, v);
v = v & 16383;
v = v + 3;
label:
v = v;
if v > v goto label;
v = (int) -1;
return v;
label:
v = (int) -2;
return v;
label:
return v;
}
static void handleHandshakeFailure(io.netty.channel.ChannelHandlerContext, java.lang.Throwable, boolean)
{
java.lang.Throwable v;
io.netty.channel.ChannelHandlerContext v;
io.netty.handler.ssl.SslHandshakeCompletionEvent v;
boolean v;
v := @parameter: io.netty.channel.ChannelHandlerContext;
v := @parameter: java.lang.Throwable;
v := @parameter: boolean;
interfaceinvoke v.<io.netty.channel.ChannelHandlerContext: io.netty.channel.ChannelHandlerContext flush()>();
if v == 0 goto label;
v = new io.netty.handler.ssl.SslHandshakeCompletionEvent;
specialinvoke v.<io.netty.handler.ssl.SslHandshakeCompletionEvent: void <init>(java.lang.Throwable)>(v);
interfaceinvoke v.<io.netty.channel.ChannelHandlerContext: io.netty.channel.ChannelHandlerContext fireUserEventTriggered(java.lang.Object)>(v);
label:
interfaceinvoke v.<io.netty.channel.ChannelHandlerContext: io.netty.channel.ChannelFuture close()>();
return;
}
static void zeroout(io.netty.buffer.ByteBuf)
{
int v;
io.netty.buffer.ByteBuf v;
boolean v;
v := @parameter: io.netty.buffer.ByteBuf;
v = virtualinvoke v.<io.netty.buffer.ByteBuf: boolean isReadOnly()>();
if v != 0 goto label;
v = virtualinvoke v.<io.netty.buffer.ByteBuf: int capacity()>();
virtualinvoke v.<io.netty.buffer.ByteBuf: io.netty.buffer.ByteBuf setZero(int,int)>(0, v);
label:
return;
}
static void zerooutAndRelease(io.netty.buffer.ByteBuf)
{
io.netty.buffer.ByteBuf v;
v := @parameter: io.netty.buffer.ByteBuf;
staticinvoke <io.netty.handler.ssl.SslUtils: void zeroout(io.netty.buffer.ByteBuf)>(v);
virtualinvoke v.<io.netty.buffer.ByteBuf: boolean release()>();
return;
}
static io.netty.buffer.ByteBuf toBase64(io.netty.buffer.ByteBufAllocator, io.netty.buffer.ByteBuf)
{
io.netty.buffer.ByteBuf v, v;
io.netty.buffer.ByteBufAllocator v;
int v, v, v;
io.netty.handler.codec.base.Base64Dialect v;
v := @parameter: io.netty.buffer.ByteBufAllocator;
v := @parameter: io.netty.buffer.ByteBuf;
v = virtualinvoke v.<io.netty.buffer.ByteBuf: int readerIndex()>();
v = virtualinvoke v.<io.netty.buffer.ByteBuf: int readableBytes()>();
v = <io.netty.handler.codec.base.Base64Dialect: io.netty.handler.codec.base.Base64Dialect STANDARD>;
v = staticinvoke <io.netty.handler.codec.base.Base64: io.netty.buffer.ByteBuf encode(io.netty.buffer.ByteBuf,int,int,boolean,io.netty.handler.codec.base.Base64Dialect,io.netty.buffer.ByteBufAllocator)>(v, v, v, 1, v, v);
v = virtualinvoke v.<io.netty.buffer.ByteBuf: int writerIndex()>();
virtualinvoke v.<io.netty.buffer.ByteBuf: io.netty.buffer.ByteBuf readerIndex(int)>(v);
return v;
}
static boolean isValidHostNameForSNI(java.lang.String)
{
int v;
java.lang.String v;
boolean v, v, v, v, v;
v := @parameter: java.lang.String;
if v == null goto label;
v = virtualinvoke v.<java.lang.String: int indexOf(int)>(46);
if v <= 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>(".");
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("/");
if v != 0 goto label;
v = staticinvoke <io.netty.util.NetUtil: boolean isValidIpV4Address(java.lang.String)>(v);
if v != 0 goto label;
v = staticinvoke <io.netty.util.NetUtil: boolean isValidIpV6Address(java.lang.String)>(v);
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
static boolean isTLSv13Cipher(java.lang.String)
{
java.util.Set v;
java.lang.String v;
boolean v;
v := @parameter: java.lang.String;
v = <io.netty.handler.ssl.SslUtils: java.util.Set TLSV13_CIPHERS>;
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
return v;
}
private void <init>()
{
io.netty.handler.ssl.SslUtils v;
v := @this: io.netty.handler.ssl.SslUtils;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
static void <clinit>()
{
java.lang.Object[] v;
java.util.Set v;
java.lang.String[] v, v, v, v, v, v;
java.util.List v;
io.netty.util.internal.logging.InternalLogger v;
java.util.LinkedHashSet v, v;
boolean 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/SslUtils;");
<io.netty.handler.ssl.SslUtils: io.netty.util.internal.logging.InternalLogger logger> = v;
v = new java.util.LinkedHashSet;
v = newarray (java.lang.String)[5];
v[0] = "TLS_AES_256_GCM_SHA384";
v[1] = "TLS_CHACHA20_POLY1305_SHA256";
v[2] = "TLS_AES_128_GCM_SHA256";
v[3] = "TLS_AES_128_CCM_8_SHA256";
v[4] = "TLS_AES_128_CCM_SHA256";
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
specialinvoke v.<java.util.LinkedHashSet: void <init>(java.util.Collection)>(v);
v = staticinvoke <java.util.Collections: java.util.Set unmodifiableSet(java.util.Set)>(v);
<io.netty.handler.ssl.SslUtils: java.util.Set TLSV13_CIPHERS> = v;
v = newarray (java.lang.String)[2];
v[0] = "TLS_AES_128_GCM_SHA256";
v[1] = "TLS_AES_256_GCM_SHA384";
<io.netty.handler.ssl.SslUtils: java.lang.String[] TLSV13_CIPHER_SUITES> = v;
v = staticinvoke <io.netty.handler.ssl.SslUtils: boolean isTLSv13SupportedByJDK0(java.security.Provider)>(null);
<io.netty.handler.ssl.SslUtils: boolean TLSV1_3_JDK_SUPPORTED> = v;
v = staticinvoke <io.netty.handler.ssl.SslUtils: boolean isTLSv13EnabledByJDK0(java.security.Provider)>(null);
<io.netty.handler.ssl.SslUtils: boolean TLSV1_3_JDK_DEFAULT_ENABLED> = v;
v = <io.netty.handler.ssl.SslUtils: boolean TLSV1_3_JDK_SUPPORTED>;
if v == 0 goto label;
v = <io.netty.handler.ssl.SslUtils: java.lang.String[] TLSV13_CIPHER_SUITES>;
<io.netty.handler.ssl.SslUtils: java.lang.String[] DEFAULT_TLSV13_CIPHER_SUITES> = v;
goto label;
label:
v = <io.netty.util.internal.EmptyArrays: java.lang.String[] EMPTY_STRINGS>;
<io.netty.handler.ssl.SslUtils: java.lang.String[] DEFAULT_TLSV13_CIPHER_SUITES> = v;
label:
v = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>()>();
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>("TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384");
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>("TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256");
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>("TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256");
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>("TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384");
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>("TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA");
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>("TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA");
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>("TLS_RSA_WITH_AES_128_GCM_SHA256");
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>("TLS_RSA_WITH_AES_128_CBC_SHA");
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>("TLS_RSA_WITH_AES_256_CBC_SHA");
v = <io.netty.handler.ssl.SslUtils: java.lang.String[] DEFAULT_TLSV13_CIPHER_SUITES>;
staticinvoke <java.util.Collections: boolean addAll(java.util.Collection,java.lang.Object[])>(v, v);
v = <io.netty.util.internal.EmptyArrays: java.lang.String[] EMPTY_STRINGS>;
v = interfaceinvoke v.<java.util.Set: java.lang.Object[] toArray(java.lang.Object[])>(v);
<io.netty.handler.ssl.SslUtils: java.lang.String[] DEFAULT_CIPHER_SUITES> = v;
return;
}
}