final class oadd.io.netty.handler.ssl.PemReader extends java.lang.Object
{
private static final oadd.io.netty.util.internal.logging.InternalLogger logger;
private static final java.util.regex.Pattern CERT_PATTERN;
private static final java.util.regex.Pattern KEY_PATTERN;
static oadd.io.netty.buffer.ByteBuf[] readCertificates(java.io.File) throws java.security.cert.CertificateException
{
java.lang.Throwable v;
oadd.io.netty.buffer.ByteBuf[] v;
java.io.FileInputStream v;
java.lang.String v;
java.security.cert.CertificateException v;
java.io.File v;
java.io.FileNotFoundException v;
v := @parameter: java.io.File;
label:
v = new java.io.FileInputStream;
specialinvoke v.<java.io.FileInputStream: void <init>(java.io.File)>(v);
label:
v = staticinvoke <oadd.io.netty.handler.ssl.PemReader: oadd.io.netty.buffer.ByteBuf[] readCertificates(java.io.InputStream)>(v);
label:
staticinvoke <oadd.io.netty.handler.ssl.PemReader: void safeClose(java.io.InputStream)>(v);
label:
return v;
label:
v := @caughtexception;
staticinvoke <oadd.io.netty.handler.ssl.PemReader: void safeClose(java.io.InputStream)>(v);
throw v;
label:
v := @caughtexception;
v = new java.security.cert.CertificateException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("could not find certificate file: \u0001");
specialinvoke v.<java.security.cert.CertificateException: void <init>(java.lang.String)>(v);
throw v;
catch java.lang.Throwable from label to label with label;
catch java.io.FileNotFoundException from label to label with label;
}
static oadd.io.netty.buffer.ByteBuf[] readCertificates(java.io.InputStream) throws java.security.cert.CertificateException
{
java.lang.Object[] v;
java.util.ArrayList v;
java.util.regex.Matcher v;
java.nio.charset.Charset v;
int v;
java.lang.String v, v;
oadd.io.netty.buffer.ByteBuf v, v;
boolean v, v;
oadd.io.netty.buffer.ByteBuf[] v;
java.io.IOException v;
java.security.cert.CertificateException v, v;
java.util.regex.Pattern v;
java.io.InputStream v;
v := @parameter: java.io.InputStream;
label:
v = staticinvoke <oadd.io.netty.handler.ssl.PemReader: java.lang.String readContent(java.io.InputStream)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new java.security.cert.CertificateException;
specialinvoke v.<java.security.cert.CertificateException: void <init>(java.lang.String,java.lang.Throwable)>("failed to read certificate input stream", v);
throw v;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = <oadd.io.netty.handler.ssl.PemReader: java.util.regex.Pattern CERT_PATTERN>;
v = virtualinvoke v.<java.util.regex.Pattern: java.util.regex.Matcher matcher(java.lang.CharSequence)>(v);
v = 0;
label:
v = virtualinvoke v.<java.util.regex.Matcher: boolean find(int)>(v);
if v == 0 goto label;
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(1);
v = <oadd.io.netty.util.CharsetUtil: java.nio.charset.Charset US_ASCII>;
v = staticinvoke <oadd.io.netty.buffer.Unpooled: oadd.io.netty.buffer.ByteBuf copiedBuffer(java.lang.CharSequence,java.nio.charset.Charset)>(v, v);
v = staticinvoke <oadd.io.netty.handler.codec.base.Base64: oadd.io.netty.buffer.ByteBuf decode(oadd.io.netty.buffer.ByteBuf)>(v);
virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: boolean release()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: int end()>();
goto label;
label:
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
v = new java.security.cert.CertificateException;
specialinvoke v.<java.security.cert.CertificateException: void <init>(java.lang.String)>("found no certificates in input stream");
throw v;
label:
v = newarray (oadd.io.netty.buffer.ByteBuf)[0];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
return v;
catch java.io.IOException from label to label with label;
}
static oadd.io.netty.buffer.ByteBuf readPrivateKey(java.io.File) throws java.security.KeyException
{
java.lang.Throwable v;
java.security.KeyException v;
java.io.FileInputStream v;
java.lang.String v;
oadd.io.netty.buffer.ByteBuf v;
java.io.File v;
java.io.FileNotFoundException v;
v := @parameter: java.io.File;
label:
v = new java.io.FileInputStream;
specialinvoke v.<java.io.FileInputStream: void <init>(java.io.File)>(v);
label:
v = staticinvoke <oadd.io.netty.handler.ssl.PemReader: oadd.io.netty.buffer.ByteBuf readPrivateKey(java.io.InputStream)>(v);
label:
staticinvoke <oadd.io.netty.handler.ssl.PemReader: void safeClose(java.io.InputStream)>(v);
label:
return v;
label:
v := @caughtexception;
staticinvoke <oadd.io.netty.handler.ssl.PemReader: void safeClose(java.io.InputStream)>(v);
throw v;
label:
v := @caughtexception;
v = new java.security.KeyException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("could not find key file: \u0001");
specialinvoke v.<java.security.KeyException: void <init>(java.lang.String)>(v);
throw v;
catch java.lang.Throwable from label to label with label;
catch java.io.FileNotFoundException from label to label with label;
}
static oadd.io.netty.buffer.ByteBuf readPrivateKey(java.io.InputStream) throws java.security.KeyException
{
java.security.KeyException v, v;
java.io.IOException v;
java.util.regex.Matcher v;
java.nio.charset.Charset v;
java.lang.String v, v;
java.util.regex.Pattern v;
oadd.io.netty.buffer.ByteBuf v, v;
boolean v;
java.io.InputStream v;
v := @parameter: java.io.InputStream;
label:
v = staticinvoke <oadd.io.netty.handler.ssl.PemReader: java.lang.String readContent(java.io.InputStream)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new java.security.KeyException;
specialinvoke v.<java.security.KeyException: void <init>(java.lang.String,java.lang.Throwable)>("failed to read key input stream", v);
throw v;
label:
v = <oadd.io.netty.handler.ssl.PemReader: java.util.regex.Pattern KEY_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 find()>();
if v != 0 goto label;
v = new java.security.KeyException;
specialinvoke v.<java.security.KeyException: void <init>(java.lang.String)>("could not find a PKCS #8 private key in input stream (see https://netty.io/wiki/sslcontextbuilder-and-private-key.html for more information)");
throw v;
label:
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(1);
v = <oadd.io.netty.util.CharsetUtil: java.nio.charset.Charset US_ASCII>;
v = staticinvoke <oadd.io.netty.buffer.Unpooled: oadd.io.netty.buffer.ByteBuf copiedBuffer(java.lang.CharSequence,java.nio.charset.Charset)>(v, v);
v = staticinvoke <oadd.io.netty.handler.codec.base.Base64: oadd.io.netty.buffer.ByteBuf decode(oadd.io.netty.buffer.ByteBuf)>(v);
virtualinvoke v.<oadd.io.netty.buffer.ByteBuf: boolean release()>();
return v;
catch java.io.IOException from label to label with label;
}
private static java.lang.String readContent(java.io.InputStream) throws java.io.IOException
{
java.lang.Throwable v;
byte[] v;
java.io.ByteArrayOutputStream v;
java.nio.charset.Charset v;
int v;
java.lang.String v, v;
java.io.InputStream v;
v := @parameter: java.io.InputStream;
v = new java.io.ByteArrayOutputStream;
specialinvoke v.<java.io.ByteArrayOutputStream: void <init>()>();
label:
v = newarray (byte)[8192];
label:
v = virtualinvoke v.<java.io.InputStream: int read(byte[])>(v);
if v < 0 goto label;
virtualinvoke v.<java.io.ByteArrayOutputStream: void write(byte[],int,int)>(v, 0, v);
goto label;
label:
v = <oadd.io.netty.util.CharsetUtil: java.nio.charset.Charset US_ASCII>;
v = virtualinvoke v.<java.nio.charset.Charset: java.lang.String name()>();
v = virtualinvoke v.<java.io.ByteArrayOutputStream: java.lang.String toString(java.lang.String)>(v);
label:
staticinvoke <oadd.io.netty.handler.ssl.PemReader: void safeClose(java.io.OutputStream)>(v);
return v;
label:
v := @caughtexception;
staticinvoke <oadd.io.netty.handler.ssl.PemReader: void safeClose(java.io.OutputStream)>(v);
throw v;
catch java.lang.Throwable from label to label with label;
}
private static void safeClose(java.io.InputStream)
{
java.io.InputStream v;
v := @parameter: java.io.InputStream;
return;
}
private static void safeClose(java.io.OutputStream)
{
java.io.OutputStream v;
v := @parameter: java.io.OutputStream;
return;
}
private void <init>()
{
oadd.io.netty.handler.ssl.PemReader v;
v := @this: oadd.io.netty.handler.ssl.PemReader;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
static void <clinit>()
{
java.util.regex.Pattern v, v;
oadd.io.netty.util.internal.logging.InternalLogger v;
v = staticinvoke <oadd.io.netty.util.internal.logging.InternalLoggerFactory: oadd.io.netty.util.internal.logging.InternalLogger getInstance(java.lang.Class)>(class "Loadd/io/netty/handler/ssl/PemReader;");
<oadd.io.netty.handler.ssl.PemReader: oadd.io.netty.util.internal.logging.InternalLogger logger> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String,int)>("-+BEGIN\\s+.*CERTIFICATE[^-]*-+(?:\\s|\\r|\\n)+([a-z0-9+/=\\r\\n]+)-+END\\s+.*CERTIFICATE[^-]*-+", 2);
<oadd.io.netty.handler.ssl.PemReader: java.util.regex.Pattern CERT_PATTERN> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String,int)>("-+BEGIN\\s+.*PRIVATE\\s+KEY[^-]*-+(?:\\s|\\r|\\n)+([a-z0-9+/=\\r\\n]+)-+END\\s+.*PRIVATE\\s+KEY[^-]*-+", 2);
<oadd.io.netty.handler.ssl.PemReader: java.util.regex.Pattern KEY_PATTERN> = v;
return;
}
}