final class io.netty.handler.ssl.PemReader extends java.lang.Object
{
private static final io.netty.util.internal.logging.InternalLogger logger;
private static final java.util.regex.Pattern CERT_HEADER;
private static final java.util.regex.Pattern CERT_FOOTER;
private static final java.util.regex.Pattern KEY_HEADER;
private static final java.util.regex.Pattern KEY_FOOTER;
private static final java.util.regex.Pattern BODY;
static io.netty.buffer.ByteBuf[] readCertificates(java.io.File) throws java.security.cert.CertificateException
{
java.lang.Throwable v;
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 <io.netty.handler.ssl.PemReader: io.netty.buffer.ByteBuf[] readCertificates(java.io.InputStream)>(v);
label:
staticinvoke <io.netty.handler.ssl.PemReader: void safeClose(java.io.InputStream)>(v);
label:
return v;
label:
v := @caughtexception;
staticinvoke <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 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;
io.netty.buffer.ByteBuf v, v;
java.nio.charset.Charset v;
int v;
java.lang.String v, v;
boolean v, v, v, v;
io.netty.buffer.ByteBuf[] v;
java.io.IOException v;
java.security.cert.CertificateException v, v;
java.util.regex.Pattern v, v, v, v;
java.io.InputStream v;
v := @parameter: java.io.InputStream;
label:
v = staticinvoke <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 = <io.netty.handler.ssl.PemReader: java.util.regex.Pattern CERT_HEADER>;
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 = <io.netty.handler.ssl.PemReader: java.util.regex.Pattern BODY>;
virtualinvoke v.<java.util.regex.Matcher: java.util.regex.Matcher usePattern(java.util.regex.Pattern)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: boolean find()>();
if v == 0 goto label;
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(0);
v = <io.netty.util.CharsetUtil: java.nio.charset.Charset US_ASCII>;
v = staticinvoke <io.netty.buffer.Unpooled: io.netty.buffer.ByteBuf copiedBuffer(java.lang.CharSequence,java.nio.charset.Charset)>(v, v);
v = <io.netty.handler.ssl.PemReader: java.util.regex.Pattern CERT_FOOTER>;
virtualinvoke v.<java.util.regex.Matcher: java.util.regex.Matcher usePattern(java.util.regex.Pattern)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: boolean find()>();
if v == 0 goto label;
v = staticinvoke <io.netty.handler.codec.base.Base64: io.netty.buffer.ByteBuf decode(io.netty.buffer.ByteBuf)>(v);
virtualinvoke v.<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()>();
v = <io.netty.handler.ssl.PemReader: java.util.regex.Pattern CERT_HEADER>;
virtualinvoke v.<java.util.regex.Matcher: java.util.regex.Matcher usePattern(java.util.regex.Pattern)>(v);
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 (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 io.netty.buffer.ByteBuf readPrivateKey(java.io.File) throws java.security.KeyException
{
java.lang.Throwable v;
io.netty.buffer.ByteBuf v;
java.security.KeyException v;
java.io.FileInputStream v;
java.lang.String 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 <io.netty.handler.ssl.PemReader: io.netty.buffer.ByteBuf readPrivateKey(java.io.InputStream)>(v);
label:
staticinvoke <io.netty.handler.ssl.PemReader: void safeClose(java.io.InputStream)>(v);
label:
return v;
label:
v := @caughtexception;
staticinvoke <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 io.netty.buffer.ByteBuf readPrivateKey(java.io.InputStream) throws java.security.KeyException
{
java.security.KeyException v, v, v, v;
java.util.regex.Matcher v;
io.netty.buffer.ByteBuf v, v;
java.nio.charset.Charset v;
java.lang.String v, v;
boolean v, v, v;
java.io.IOException v;
java.util.regex.Pattern v, v, v;
java.io.InputStream v;
v := @parameter: java.io.InputStream;
label:
v = staticinvoke <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 = <io.netty.handler.ssl.PemReader: java.util.regex.Pattern KEY_HEADER>;
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 = staticinvoke <io.netty.handler.ssl.PemReader: java.security.KeyException keyNotFoundException()>();
throw v;
label:
v = <io.netty.handler.ssl.PemReader: java.util.regex.Pattern BODY>;
virtualinvoke v.<java.util.regex.Matcher: java.util.regex.Matcher usePattern(java.util.regex.Pattern)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: boolean find()>();
if v != 0 goto label;
v = staticinvoke <io.netty.handler.ssl.PemReader: java.security.KeyException keyNotFoundException()>();
throw v;
label:
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(0);
v = <io.netty.util.CharsetUtil: java.nio.charset.Charset US_ASCII>;
v = staticinvoke <io.netty.buffer.Unpooled: io.netty.buffer.ByteBuf copiedBuffer(java.lang.CharSequence,java.nio.charset.Charset)>(v, v);
v = <io.netty.handler.ssl.PemReader: java.util.regex.Pattern KEY_FOOTER>;
virtualinvoke v.<java.util.regex.Matcher: java.util.regex.Matcher usePattern(java.util.regex.Pattern)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: boolean find()>();
if v != 0 goto label;
v = staticinvoke <io.netty.handler.ssl.PemReader: java.security.KeyException keyNotFoundException()>();
throw v;
label:
v = staticinvoke <io.netty.handler.codec.base.Base64: io.netty.buffer.ByteBuf decode(io.netty.buffer.ByteBuf)>(v);
virtualinvoke v.<io.netty.buffer.ByteBuf: boolean release()>();
return v;
catch java.io.IOException from label to label with label;
}
private static java.security.KeyException keyNotFoundException()
{
java.security.KeyException v;
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)");
return v;
}
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 = <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 <io.netty.handler.ssl.PemReader: void safeClose(java.io.OutputStream)>(v);
return v;
label:
v := @caughtexception;
staticinvoke <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>()
{
io.netty.handler.ssl.PemReader v;
v := @this: io.netty.handler.ssl.PemReader;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
static void <clinit>()
{
io.netty.util.internal.logging.InternalLogger v;
java.util.regex.Pattern 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/PemReader;");
<io.netty.handler.ssl.PemReader: io.netty.util.internal.logging.InternalLogger logger> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>("-+BEGIN\\s[^-\\r\\n]*CERTIFICATE[^-\\r\\n]*-+(?:\\s|\\r|\\n)+");
<io.netty.handler.ssl.PemReader: java.util.regex.Pattern CERT_HEADER> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>("-+END\\s[^-\\r\\n]*CERTIFICATE[^-\\r\\n]*-+(?:\\s|\\r|\\n)*");
<io.netty.handler.ssl.PemReader: java.util.regex.Pattern CERT_FOOTER> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>("-+BEGIN\\s[^-\\r\\n]*PRIVATE\\s+KEY[^-\\r\\n]*-+(?:\\s|\\r|\\n)+");
<io.netty.handler.ssl.PemReader: java.util.regex.Pattern KEY_HEADER> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>("-+END\\s[^-\\r\\n]*PRIVATE\\s+KEY[^-\\r\\n]*-+(?:\\s|\\r|\\n)*");
<io.netty.handler.ssl.PemReader: java.util.regex.Pattern KEY_FOOTER> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String,int)>("[a-z0-9+/=][a-z0-9+/=\\r\\n]*", 2);
<io.netty.handler.ssl.PemReader: java.util.regex.Pattern BODY> = v;
return;
}
}