final class io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator extends java.lang.Object
{
private static final io.netty.util.internal.logging.InternalLogger logger;
private static final java.lang.reflect.Method CERT_INFO_SET_METHOD;
private static final java.lang.reflect.Constructor ISSUER_NAME_CONSTRUCTOR;
private static final java.lang.reflect.Constructor CERT_IMPL_CONSTRUCTOR;
private static final java.lang.reflect.Method CERT_IMPL_GET_METHOD;
private static final java.lang.reflect.Method CERT_IMPL_SIGN_METHOD;
static java.lang.String[] generate(java.lang.String, java.security.KeyPair, java.security.SecureRandom, java.util.Date, java.util.Date, java.lang.String) throws java.lang.Exception
{
java.security.KeyPair v;
sun.security.x.CertificateSerialNumber v;
java.security.SecureRandom v;
sun.security.x.CertificateSubjectName v;
sun.security.x.X500Name v;
java.math.BigInteger v;
java.lang.reflect.InvocationTargetException v, v;
java.security.PrivateKey v;
sun.security.x.AlgorithmId v;
sun.security.x.X509CertInfo v;
java.lang.Throwable v, v;
sun.security.x.CertificateValidity v;
java.lang.Object[] v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.reflect.Constructor v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v;
java.lang.UnsupportedOperationException v;
sun.security.x.CertificateX509Key v;
java.util.Date v, v;
java.lang.reflect.Method v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
boolean v, v, v, v;
sun.security.x.CertificateVersion v;
java.lang.String[] v;
java.security.PublicKey v, v;
sun.security.x.CertificateAlgorithmId v;
java.lang.Class v;
java.lang.Object v, v, v, v;
v := @parameter: java.lang.String;
v := @parameter: java.security.KeyPair;
v := @parameter: java.security.SecureRandom;
v := @parameter: java.util.Date;
v := @parameter: java.util.Date;
v := @parameter: java.lang.String;
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_INFO_SET_METHOD>;
if v == null goto label;
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Constructor ISSUER_NAME_CONSTRUCTOR>;
if v == null goto label;
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Constructor CERT_IMPL_CONSTRUCTOR>;
if v == null goto label;
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_IMPL_GET_METHOD>;
if v == null goto label;
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_IMPL_SIGN_METHOD>;
if v != null goto label;
label:
v = new java.lang.UnsupportedOperationException;
v = class "Lio/netty/handler/ssl/util/OpenJdkSelfSignedCertGenerator;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
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[])>("\u not supported on the used JDK version");
specialinvoke v.<java.lang.UnsupportedOperationException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<java.security.KeyPair: java.security.PrivateKey getPrivate()>();
v = new sun.security.x.X509CertInfo;
specialinvoke v.<sun.security.x.X509CertInfo: void <init>()>();
v = new sun.security.x.X500Name;
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[])>("CN=\u0001");
specialinvoke v.<sun.security.x.X500Name: void <init>(java.lang.String)>(v);
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_INFO_SET_METHOD>;
v = newarray (java.lang.Object)[2];
v[0] = "version";
v = new sun.security.x.CertificateVersion;
specialinvoke v.<sun.security.x.CertificateVersion: void <init>(int)>(2);
v[1] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_INFO_SET_METHOD>;
v = newarray (java.lang.Object)[2];
v[0] = "serialNumber";
v = new sun.security.x.CertificateSerialNumber;
v = new java.math.BigInteger;
specialinvoke v.<java.math.BigInteger: void <init>(int,java.util.Random)>(64, v);
specialinvoke v.<sun.security.x.CertificateSerialNumber: void <init>(java.math.BigInteger)>(v);
v[1] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_INFO_SET_METHOD>;
v = newarray (java.lang.Object)[2];
v[0] = "subject";
v = new sun.security.x.CertificateSubjectName;
specialinvoke v.<sun.security.x.CertificateSubjectName: void <init>(sun.security.x.X500Name)>(v);
v[1] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<java.lang.reflect.InvocationTargetException: java.lang.Throwable getCause()>();
v = v instanceof java.security.cert.CertificateException;
if v == 0 goto label;
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_INFO_SET_METHOD>;
v = newarray (java.lang.Object)[2];
v[0] = "subject";
v[1] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
goto label;
label:
throw v;
label:
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_INFO_SET_METHOD>;
v = newarray (java.lang.Object)[2];
v[0] = "issuer";
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Constructor ISSUER_NAME_CONSTRUCTOR>;
v = newarray (java.lang.Object)[1];
v[0] = v;
v = virtualinvoke v.<java.lang.reflect.Constructor: java.lang.Object newInstance(java.lang.Object[])>(v);
v[1] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<java.lang.reflect.InvocationTargetException: java.lang.Throwable getCause()>();
v = v instanceof java.security.cert.CertificateException;
if v == 0 goto label;
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_INFO_SET_METHOD>;
v = newarray (java.lang.Object)[2];
v[0] = "issuer";
v[1] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
goto label;
label:
throw v;
label:
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_INFO_SET_METHOD>;
v = newarray (java.lang.Object)[2];
v[0] = "validity";
v = new sun.security.x.CertificateValidity;
specialinvoke v.<sun.security.x.CertificateValidity: void <init>(java.util.Date,java.util.Date)>(v, v);
v[1] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_INFO_SET_METHOD>;
v = newarray (java.lang.Object)[2];
v[0] = "key";
v = new sun.security.x.CertificateX509Key;
v = virtualinvoke v.<java.security.KeyPair: java.security.PublicKey getPublic()>();
specialinvoke v.<sun.security.x.CertificateX509Key: void <init>(java.security.PublicKey)>(v);
v[1] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_INFO_SET_METHOD>;
v = newarray (java.lang.Object)[2];
v[0] = "algorithmID";
v = new sun.security.x.CertificateAlgorithmId;
v = staticinvoke <sun.security.x.AlgorithmId: sun.security.x.AlgorithmId get(java.lang.String)>("1.2.840.113549.1.1.11");
specialinvoke v.<sun.security.x.CertificateAlgorithmId: void <init>(sun.security.x.AlgorithmId)>(v);
v[1] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Constructor CERT_IMPL_CONSTRUCTOR>;
v = newarray (java.lang.Object)[1];
v[0] = v;
v = virtualinvoke v.<java.lang.reflect.Constructor: java.lang.Object newInstance(java.lang.Object[])>(v);
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_IMPL_SIGN_METHOD>;
v = newarray (java.lang.Object)[2];
v[0] = v;
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>("EC");
if v == 0 goto label;
v = "SHA256withECDSA";
goto label;
label:
v = "SHA256withRSA";
label:
v[1] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_INFO_SET_METHOD>;
v = newarray (java.lang.Object)[2];
v[0] = "algorithmID.algorithm";
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_IMPL_GET_METHOD>;
v = newarray (java.lang.Object)[1];
v[0] = "x.algorithm";
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v[1] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Constructor CERT_IMPL_CONSTRUCTOR>;
v = newarray (java.lang.Object)[1];
v[0] = v;
v = virtualinvoke v.<java.lang.reflect.Constructor: java.lang.Object newInstance(java.lang.Object[])>(v);
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_IMPL_SIGN_METHOD>;
v = newarray (java.lang.Object)[2];
v[0] = v;
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>("EC");
if v == 0 goto label;
v = "SHA256withECDSA";
goto label;
label:
v = "SHA256withRSA";
label:
v[1] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = virtualinvoke v.<java.security.KeyPair: java.security.PublicKey getPublic()>();
virtualinvoke v.<sun.security.x.X509CertImpl: void verify(java.security.PublicKey)>(v);
v = staticinvoke <io.netty.handler.ssl.util.SelfSignedCertificate: java.lang.String[] newSelfSignedCertificate(java.lang.String,java.security.PrivateKey,java.security.cert.X509Certificate)>(v, v, v);
return v;
catch java.lang.reflect.InvocationTargetException from label to label with label;
catch java.lang.reflect.InvocationTargetException from label to label with label;
}
private void <init>()
{
io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator v;
v := @this: io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
static void <clinit>()
{
java.lang.Throwable v;
java.lang.reflect.Constructor v;
io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$2 v;
io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$3 v;
io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$4 v;
io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$5 v;
java.lang.String v, v;
boolean v, v, v, v, v;
io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$1 v;
io.netty.util.internal.logging.InternalLogger v, v;
java.lang.Class v;
java.lang.Object 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/util/OpenJdkSelfSignedCertGenerator;");
<io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: io.netty.util.internal.logging.InternalLogger logger> = v;
v = null;
label:
v = new io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$1;
specialinvoke v.<io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$1: void <init>()>();
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedAction)>(v);
v = v instanceof java.lang.reflect.Method;
if v != 0 goto label;
throw v;
label:
v = new io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$2;
specialinvoke v.<io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$2: void <init>()>();
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedAction)>(v);
v = v instanceof java.lang.reflect.Constructor;
if v != 0 goto label;
throw v;
label:
v = new io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$3;
specialinvoke v.<io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$3: void <init>()>();
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedAction)>(v);
v = v instanceof java.lang.reflect.Constructor;
if v == 0 goto label;
v = v;
goto label;
label:
throw v;
label:
v = new io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$4;
specialinvoke v.<io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$4: void <init>()>();
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedAction)>(v);
v = v instanceof java.lang.reflect.Method;
if v != 0 goto label;
throw v;
label:
v = new io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$5;
specialinvoke v.<io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator$5: void <init>()>();
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedAction)>(v);
v = v instanceof java.lang.reflect.Method;
if v != 0 goto label;
throw v;
label:
v := @caughtexception;
v = <io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: io.netty.util.internal.logging.InternalLogger logger>;
v = class "Lio/netty/handler/ssl/util/OpenJdkSelfSignedCertGenerator;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
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[])>("\u not supported");
interfaceinvoke v.<io.netty.util.internal.logging.InternalLogger: void debug(java.lang.String,java.lang.Throwable)>(v, v);
label:
<io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_INFO_SET_METHOD> = v;
<io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Constructor ISSUER_NAME_CONSTRUCTOR> = v;
<io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Constructor CERT_IMPL_CONSTRUCTOR> = v;
<io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_IMPL_GET_METHOD> = v;
<io.netty.handler.ssl.util.OpenJdkSelfSignedCertGenerator: java.lang.reflect.Method CERT_IMPL_SIGN_METHOD> = v;
return;
catch java.lang.Throwable from label to label with label;
}
}