final class io.netty.handler.ssl.BouncyCastlePemReader extends java.lang.Object
{
private static final java.lang.String BC_PROVIDER;
private static final java.lang.String BC_PEMPARSER;
private static final io.netty.util.internal.logging.InternalLogger logger;
private static volatile java.lang.Throwable unavailabilityCause;
private static volatile java.security.Provider bcProvider;
private static volatile boolean attemptedLoading;
public static boolean hasAttemptedLoading()
{
boolean v;
v = <io.netty.handler.ssl.BouncyCastlePemReader: boolean attemptedLoading>;
return v;
}
public static boolean isAvailable()
{
java.lang.Throwable v;
boolean v, v;
v = staticinvoke <io.netty.handler.ssl.BouncyCastlePemReader: boolean hasAttemptedLoading()>();
if v != 0 goto label;
staticinvoke <io.netty.handler.ssl.BouncyCastlePemReader: void tryLoading()>();
label:
v = <io.netty.handler.ssl.BouncyCastlePemReader: java.lang.Throwable unavailabilityCause>;
if v != null goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public static java.lang.Throwable unavailabilityCause()
{
java.lang.Throwable v;
v = <io.netty.handler.ssl.BouncyCastlePemReader: java.lang.Throwable unavailabilityCause>;
return v;
}
private static void tryLoading()
{
io.netty.handler.ssl.BouncyCastlePemReader$1 v;
v = new io.netty.handler.ssl.BouncyCastlePemReader$1;
specialinvoke v.<io.netty.handler.ssl.BouncyCastlePemReader$1: void <init>()>();
staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedAction)>(v);
return;
}
public static java.security.PrivateKey getPrivateKey(java.io.InputStream, java.lang.String)
{
java.lang.Throwable v;
org.bouncycastle.openssl.PEMParser v;
java.lang.Exception v;
java.security.PrivateKey v;
io.netty.util.internal.logging.InternalLogger v, v, v;
java.lang.String v;
boolean v, v;
java.io.InputStream v;
v := @parameter: java.io.InputStream;
v := @parameter: java.lang.String;
v = staticinvoke <io.netty.handler.ssl.BouncyCastlePemReader: boolean isAvailable()>();
if v != 0 goto label;
v = <io.netty.handler.ssl.BouncyCastlePemReader: io.netty.util.internal.logging.InternalLogger logger>;
v = interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <io.netty.handler.ssl.BouncyCastlePemReader: io.netty.util.internal.logging.InternalLogger logger>;
v = staticinvoke <io.netty.handler.ssl.BouncyCastlePemReader: java.lang.Throwable unavailabilityCause()>();
interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: void debug(java.lang.String,java.lang.Throwable)>("Bouncy castle provider is unavailable.", v);
label:
return null;
label:
v = staticinvoke <io.netty.handler.ssl.BouncyCastlePemReader: org.bouncycastle.openssl.PEMParser newParser(java.io.InputStream)>(v);
v = staticinvoke <io.netty.handler.ssl.BouncyCastlePemReader: java.security.PrivateKey getPrivateKey(org.bouncycastle.openssl.PEMParser,java.lang.String)>(v, v);
label:
return v;
label:
v := @caughtexception;
v = <io.netty.handler.ssl.BouncyCastlePemReader: io.netty.util.internal.logging.InternalLogger logger>;
interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: void debug(java.lang.String,java.lang.Throwable)>("Unable to extract private key", v);
return null;
catch java.lang.Exception from label to label with label;
}
public static java.security.PrivateKey getPrivateKey(java.io.File, java.lang.String)
{
java.lang.Throwable v;
org.bouncycastle.openssl.PEMParser v;
java.io.File v;
java.lang.Exception v;
java.security.PrivateKey v;
io.netty.util.internal.logging.InternalLogger v, v, v;
java.lang.String v;
boolean v, v;
v := @parameter: java.io.File;
v := @parameter: java.lang.String;
v = staticinvoke <io.netty.handler.ssl.BouncyCastlePemReader: boolean isAvailable()>();
if v != 0 goto label;
v = <io.netty.handler.ssl.BouncyCastlePemReader: io.netty.util.internal.logging.InternalLogger logger>;
v = interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <io.netty.handler.ssl.BouncyCastlePemReader: io.netty.util.internal.logging.InternalLogger logger>;
v = staticinvoke <io.netty.handler.ssl.BouncyCastlePemReader: java.lang.Throwable unavailabilityCause()>();
interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: void debug(java.lang.String,java.lang.Throwable)>("Bouncy castle provider is unavailable.", v);
label:
return null;
label:
v = staticinvoke <io.netty.handler.ssl.BouncyCastlePemReader: org.bouncycastle.openssl.PEMParser newParser(java.io.File)>(v);
v = staticinvoke <io.netty.handler.ssl.BouncyCastlePemReader: java.security.PrivateKey getPrivateKey(org.bouncycastle.openssl.PEMParser,java.lang.String)>(v, v);
label:
return v;
label:
v := @caughtexception;
v = <io.netty.handler.ssl.BouncyCastlePemReader: io.netty.util.internal.logging.InternalLogger logger>;
interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: void debug(java.lang.String,java.lang.Throwable)>("Unable to extract private key", v);
return null;
catch java.lang.Exception from label to label with label;
}
private static org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter newConverter()
{
org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter v, v;
java.security.Provider v;
v = new org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter;
specialinvoke v.<org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter: void <init>()>();
v = <io.netty.handler.ssl.BouncyCastlePemReader: java.security.Provider bcProvider>;
v = virtualinvoke v.<org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter: org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter setProvider(java.security.Provider)>(v);
return v;
}
private static java.security.PrivateKey getPrivateKey(org.bouncycastle.openssl.PEMParser, java.lang.String) throws java.io.IOException, org.bouncycastle.pkcs.PKCSException, org.bouncycastle.operator.OperatorCreationException
{
java.security.KeyPair v, v;
org.bouncycastle.openssl.jcajce.JceOpenSSLPKCS8DecryptorProviderBuilder v, v;
org.bouncycastle.asn.pkcs.PrivateKeyInfo v;
boolean v, v, v, v, v, v;
org.bouncycastle.openssl.PEMParser v;
org.bouncycastle.openssl.PEMDecryptorProvider v;
java.security.Provider v, v;
java.security.PrivateKey v, v;
io.netty.util.internal.logging.InternalLogger v, v, v, v, v, v;
java.lang.Throwable v;
org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter v;
org.bouncycastle.operator.InputDecryptorProvider v;
org.bouncycastle.openssl.jcajce.JcePEMDecryptorProviderBuilder v, v;
java.lang.String v, v, v;
char[] v, v;
java.lang.Class v, v, v;
java.lang.Object v;
org.bouncycastle.openssl.PEMKeyPair v;
v := @parameter: org.bouncycastle.openssl.PEMParser;
v := @parameter: java.lang.String;
label:
v = staticinvoke <io.netty.handler.ssl.BouncyCastlePemReader: org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter newConverter()>();
v = null;
v = virtualinvoke v.<org.bouncycastle.openssl.PEMParser: java.lang.Object readObject()>();
label:
if v == null goto label;
if v != null goto label;
v = <io.netty.handler.ssl.BouncyCastlePemReader: io.netty.util.internal.logging.InternalLogger logger>;
v = interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <io.netty.handler.ssl.BouncyCastlePemReader: io.netty.util.internal.logging.InternalLogger logger>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
if v != null goto label;
v = "not ";
goto label;
label:
v = "";
label:
interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Parsed PEM object of type {} and assume key is {}encrypted", v, v);
label:
if v != null goto label;
v = v instanceof org.bouncycastle.asn.pkcs.PrivateKeyInfo;
if v == 0 goto label;
v = virtualinvoke v.<org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter: java.security.PrivateKey getPrivateKey(org.bouncycastle.asn.pkcs.PrivateKeyInfo)>(v);
goto label;
label:
v = v instanceof org.bouncycastle.openssl.PEMKeyPair;
if v == 0 goto label;
v = virtualinvoke v.<org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter: java.security.KeyPair getKeyPair(org.bouncycastle.openssl.PEMKeyPair)>(v);
v = virtualinvoke v.<java.security.KeyPair: java.security.PrivateKey getPrivate()>();
goto label;
label:
v = <io.netty.handler.ssl.BouncyCastlePemReader: io.netty.util.internal.logging.InternalLogger logger>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: void debug(java.lang.String,java.lang.Object)>("Unable to handle PEM object of type {} as a non encrypted key", v);
goto label;
label:
v = v instanceof org.bouncycastle.openssl.PEMEncryptedKeyPair;
if v == 0 goto label;
v = new org.bouncycastle.openssl.jcajce.JcePEMDecryptorProviderBuilder;
specialinvoke v.<org.bouncycastle.openssl.jcajce.JcePEMDecryptorProviderBuilder: void <init>()>();
v = <io.netty.handler.ssl.BouncyCastlePemReader: java.security.Provider bcProvider>;
v = virtualinvoke v.<org.bouncycastle.openssl.jcajce.JcePEMDecryptorProviderBuilder: org.bouncycastle.openssl.jcajce.JcePEMDecryptorProviderBuilder setProvider(java.security.Provider)>(v);
v = virtualinvoke v.<java.lang.String: char[] toCharArray()>();
v = virtualinvoke v.<org.bouncycastle.openssl.jcajce.JcePEMDecryptorProviderBuilder: org.bouncycastle.openssl.PEMDecryptorProvider build(char[])>(v);
v = virtualinvoke v.<org.bouncycastle.openssl.PEMEncryptedKeyPair: org.bouncycastle.openssl.PEMKeyPair decryptKeyPair(org.bouncycastle.openssl.PEMDecryptorProvider)>(v);
v = virtualinvoke v.<org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter: java.security.KeyPair getKeyPair(org.bouncycastle.openssl.PEMKeyPair)>(v);
v = virtualinvoke v.<java.security.KeyPair: java.security.PrivateKey getPrivate()>();
goto label;
label:
v = v instanceof org.bouncycastle.pkcs.PKCS8EncryptedPrivateKeyInfo;
if v == 0 goto label;
v = new org.bouncycastle.openssl.jcajce.JceOpenSSLPKCS8DecryptorProviderBuilder;
specialinvoke v.<org.bouncycastle.openssl.jcajce.JceOpenSSLPKCS8DecryptorProviderBuilder: void <init>()>();
v = <io.netty.handler.ssl.BouncyCastlePemReader: java.security.Provider bcProvider>;
v = virtualinvoke v.<org.bouncycastle.openssl.jcajce.JceOpenSSLPKCS8DecryptorProviderBuilder: org.bouncycastle.openssl.jcajce.JceOpenSSLPKCS8DecryptorProviderBuilder setProvider(java.security.Provider)>(v);
v = virtualinvoke v.<java.lang.String: char[] toCharArray()>();
v = virtualinvoke v.<org.bouncycastle.openssl.jcajce.JceOpenSSLPKCS8DecryptorProviderBuilder: org.bouncycastle.operator.InputDecryptorProvider build(char[])>(v);
v = virtualinvoke v.<org.bouncycastle.pkcs.PKCS8EncryptedPrivateKeyInfo: org.bouncycastle.asn.pkcs.PrivateKeyInfo decryptPrivateKeyInfo(org.bouncycastle.operator.InputDecryptorProvider)>(v);
v = virtualinvoke v.<org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter: java.security.PrivateKey getPrivateKey(org.bouncycastle.asn.pkcs.PrivateKeyInfo)>(v);
goto label;
label:
v = <io.netty.handler.ssl.BouncyCastlePemReader: io.netty.util.internal.logging.InternalLogger logger>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: void debug(java.lang.String,java.lang.Object)>("Unable to handle PEM object of type {} as a encrypted key", v);
label:
if v != null goto label;
v = virtualinvoke v.<org.bouncycastle.openssl.PEMParser: java.lang.Object readObject()>();
goto label;
label:
if v != null goto label;
v = <io.netty.handler.ssl.BouncyCastlePemReader: io.netty.util.internal.logging.InternalLogger logger>;
v = interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <io.netty.handler.ssl.BouncyCastlePemReader: io.netty.util.internal.logging.InternalLogger logger>;
interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: void debug(java.lang.String)>("No key found");
label:
v = v;
label:
return v;
label:
v := @caughtexception;
throw v;
catch java.lang.Throwable from label to label with label;
}
private static org.bouncycastle.openssl.PEMParser newParser(java.io.File) throws java.io.FileNotFoundException
{
java.io.FileReader v;
java.io.File v;
org.bouncycastle.openssl.PEMParser v;
v := @parameter: java.io.File;
v = new org.bouncycastle.openssl.PEMParser;
v = new java.io.FileReader;
specialinvoke v.<java.io.FileReader: void <init>(java.io.File)>(v);
specialinvoke v.<org.bouncycastle.openssl.PEMParser: void <init>(java.io.Reader)>(v);
return v;
}
private static org.bouncycastle.openssl.PEMParser newParser(java.io.InputStream)
{
java.nio.charset.Charset v;
org.bouncycastle.openssl.PEMParser v;
java.io.InputStreamReader v;
java.io.InputStream v;
v := @parameter: java.io.InputStream;
v = new org.bouncycastle.openssl.PEMParser;
v = new java.io.InputStreamReader;
v = <io.netty.util.CharsetUtil: java.nio.charset.Charset US_ASCII>;
specialinvoke v.<java.io.InputStreamReader: void <init>(java.io.InputStream,java.nio.charset.Charset)>(v, v);
specialinvoke v.<org.bouncycastle.openssl.PEMParser: void <init>(java.io.Reader)>(v);
return v;
}
private void <init>()
{
io.netty.handler.ssl.BouncyCastlePemReader v;
v := @this: io.netty.handler.ssl.BouncyCastlePemReader;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
static void <clinit>()
{
io.netty.util.internal.logging.InternalLogger v;
v = staticinvoke <io.netty.util.internal.logging.InternalLoggerFactory: io.netty.util.internal.logging.InternalLogger getInstance(java.lang.Class)>(class "Lio/netty/handler/ssl/BouncyCastlePemReader;");
<io.netty.handler.ssl.BouncyCastlePemReader: io.netty.util.internal.logging.InternalLogger logger> = v;
return;
}
}