public final class io.netty.handler.ssl.util.FingerprintTrustManagerFactory extends io.netty.handler.ssl.util.SimpleTrustManagerFactory
{
private static final java.util.regex.Pattern FINGERPRINT_PATTERN;
private static final java.util.regex.Pattern FINGERPRINT_STRIP_PATTERN;
private final io.netty.util.concurrent.FastThreadLocal tlmd;
private final javax.net.ssl.TrustManager tm;
private final byte[][] fingerprints;
public static io.netty.handler.ssl.util.FingerprintTrustManagerFactoryBuilder builder(java.lang.String)
{
io.netty.handler.ssl.util.FingerprintTrustManagerFactoryBuilder v;
java.lang.String v;
v := @parameter: java.lang.String;
v = new io.netty.handler.ssl.util.FingerprintTrustManagerFactoryBuilder;
specialinvoke v.<io.netty.handler.ssl.util.FingerprintTrustManagerFactoryBuilder: void <init>(java.lang.String)>(v);
return v;
}
public void <init>(java.lang.Iterable)
{
byte[][] v;
io.netty.handler.ssl.util.FingerprintTrustManagerFactory v;
java.lang.Iterable v;
v := @this: io.netty.handler.ssl.util.FingerprintTrustManagerFactory;
v := @parameter: java.lang.Iterable;
v = staticinvoke <io.netty.handler.ssl.util.FingerprintTrustManagerFactory: byte[][] toFingerprintArray(java.lang.Iterable)>(v);
specialinvoke v.<io.netty.handler.ssl.util.FingerprintTrustManagerFactory: void <init>(java.lang.String,byte[][])>("SHA1", v);
return;
}
public transient void <init>(java.lang.String[])
{
byte[][] v;
java.util.List v;
io.netty.handler.ssl.util.FingerprintTrustManagerFactory v;
java.lang.String[] v;
v := @this: io.netty.handler.ssl.util.FingerprintTrustManagerFactory;
v := @parameter: java.lang.String[];
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
v = staticinvoke <io.netty.handler.ssl.util.FingerprintTrustManagerFactory: byte[][] toFingerprintArray(java.lang.Iterable)>(v);
specialinvoke v.<io.netty.handler.ssl.util.FingerprintTrustManagerFactory: void <init>(java.lang.String,byte[][])>("SHA1", v);
return;
}
public transient void <init>(byte[][])
{
byte[][] v;
io.netty.handler.ssl.util.FingerprintTrustManagerFactory v;
v := @this: io.netty.handler.ssl.util.FingerprintTrustManagerFactory;
v := @parameter: byte[][];
specialinvoke v.<io.netty.handler.ssl.util.FingerprintTrustManagerFactory: void <init>(java.lang.String,byte[][])>("SHA1", v);
return;
}
void <init>(java.lang.String, byte[][])
{
byte[] v;
java.lang.Object[] v, v, v;
java.security.MessageDigest v;
java.lang.Integer v, v;
java.util.ArrayList v;
io.netty.buffer.ByteBuf v;
io.netty.handler.ssl.util.FingerprintTrustManagerFactory v;
int v, v, v, v, v, v, v;
java.lang.String v, v, v, v;
java.lang.IllegalArgumentException v, v, v;
byte[][] v, v;
io.netty.handler.ssl.util.FingerprintTrustManagerFactory$1 v;
io.netty.handler.ssl.util.FingerprintTrustManagerFactory$2 v;
java.security.NoSuchAlgorithmException v;
java.lang.Object v;
v := @this: io.netty.handler.ssl.util.FingerprintTrustManagerFactory;
v := @parameter: java.lang.String;
v := @parameter: byte[][];
specialinvoke v.<io.netty.handler.ssl.util.SimpleTrustManagerFactory: void <init>()>();
v = new io.netty.handler.ssl.util.FingerprintTrustManagerFactory$1;
specialinvoke v.<io.netty.handler.ssl.util.FingerprintTrustManagerFactory$1: void <init>(io.netty.handler.ssl.util.FingerprintTrustManagerFactory)>(v);
v.<io.netty.handler.ssl.util.FingerprintTrustManagerFactory: javax.net.ssl.TrustManager tm> = v;
staticinvoke <io.netty.util.internal.ObjectUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "algorithm");
staticinvoke <io.netty.util.internal.ObjectUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "fingerprints");
v = lengthof v;
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("No fingerprints provided");
throw v;
label:
v = staticinvoke <java.security.MessageDigest: java.security.MessageDigest getInstance(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new java.lang.IllegalArgumentException;
v = newarray (java.lang.Object)[1];
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Unsupported hash algorithm: %s", v);
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
v = virtualinvoke v.<java.security.MessageDigest: int getDigestLength()>();
v = new java.util.ArrayList;
v = lengthof v;
specialinvoke v.<java.util.ArrayList: void <init>(int)>(v);
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
if v == null goto label;
v = lengthof v;
if v == v goto label;
v = new java.lang.IllegalArgumentException;
v = newarray (java.lang.Object)[3];
v = lengthof v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = staticinvoke <io.netty.buffer.Unpooled: io.netty.buffer.ByteBuf wrappedBuffer(byte[])>(v);
v = staticinvoke <io.netty.buffer.ByteBufUtil: java.lang.String hexDump(io.netty.buffer.ByteBuf)>(v);
v[2] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("malformed fingerprint (length is %d but expected %d): %s", v);
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<java.lang.Object: java.lang.Object clone()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = new io.netty.handler.ssl.util.FingerprintTrustManagerFactory$2;
specialinvoke v.<io.netty.handler.ssl.util.FingerprintTrustManagerFactory$2: void <init>(io.netty.handler.ssl.util.FingerprintTrustManagerFactory,java.lang.String)>(v, v);
v.<io.netty.handler.ssl.util.FingerprintTrustManagerFactory: io.netty.util.concurrent.FastThreadLocal tlmd> = v;
v = newarray (byte[])[0];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
v.<io.netty.handler.ssl.util.FingerprintTrustManagerFactory: byte[][] fingerprints> = v;
return;
catch java.security.NoSuchAlgorithmException from label to label with label;
}
static byte[][] toFingerprintArray(java.lang.Iterable)
{
byte[] v;
java.lang.Object[] v;
java.lang.Iterable v;
java.util.ArrayList v;
java.util.regex.Matcher v, v;
java.lang.String v, v;
boolean v, v;
java.util.Iterator v;
java.lang.IllegalArgumentException v;
byte[][] v;
java.lang.Object v;
java.util.regex.Pattern v, v;
v := @parameter: java.lang.Iterable;
staticinvoke <io.netty.util.internal.ObjectUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "fingerprints");
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
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()>();
if v == null goto label;
v = <io.netty.handler.ssl.util.FingerprintTrustManagerFactory: java.util.regex.Pattern FINGERPRINT_PATTERN>;
v = virtualinvoke v.<java.util.regex.Pattern: java.util.regex.Matcher matcher(java.lang.CharSequence)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: boolean matches()>();
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
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[])>("malformed fingerprint: \u0001");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = <io.netty.handler.ssl.util.FingerprintTrustManagerFactory: java.util.regex.Pattern FINGERPRINT_STRIP_PATTERN>;
v = virtualinvoke v.<java.util.regex.Pattern: java.util.regex.Matcher matcher(java.lang.CharSequence)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String replaceAll(java.lang.String)>("");
v = staticinvoke <io.netty.util.internal.StringUtil: byte[] decodeHexDump(java.lang.CharSequence)>(v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = newarray (byte[])[0];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
return v;
}
protected void engineInit(java.security.KeyStore) throws java.lang.Exception
{
java.security.KeyStore v;
io.netty.handler.ssl.util.FingerprintTrustManagerFactory v;
v := @this: io.netty.handler.ssl.util.FingerprintTrustManagerFactory;
v := @parameter: java.security.KeyStore;
return;
}
protected void engineInit(javax.net.ssl.ManagerFactoryParameters) throws java.lang.Exception
{
javax.net.ssl.ManagerFactoryParameters v;
io.netty.handler.ssl.util.FingerprintTrustManagerFactory v;
v := @this: io.netty.handler.ssl.util.FingerprintTrustManagerFactory;
v := @parameter: javax.net.ssl.ManagerFactoryParameters;
return;
}
protected javax.net.ssl.TrustManager[] engineGetTrustManagers()
{
javax.net.ssl.TrustManager v;
io.netty.handler.ssl.util.FingerprintTrustManagerFactory v;
javax.net.ssl.TrustManager[] v;
v := @this: io.netty.handler.ssl.util.FingerprintTrustManagerFactory;
v = newarray (javax.net.ssl.TrustManager)[1];
v = v.<io.netty.handler.ssl.util.FingerprintTrustManagerFactory: javax.net.ssl.TrustManager tm>;
v[0] = v;
return v;
}
static void <clinit>()
{
java.util.regex.Pattern v, v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>("^[0-9a-fA-F:]+$");
<io.netty.handler.ssl.util.FingerprintTrustManagerFactory: java.util.regex.Pattern FINGERPRINT_PATTERN> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>(":");
<io.netty.handler.ssl.util.FingerprintTrustManagerFactory: java.util.regex.Pattern FINGERPRINT_STRIP_PATTERN> = v;
return;
}
}