public class org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator extends java.lang.Object
{
private org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams;
private static volatile org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator sslCC;
private javax.net.ssl.SSLContext sslContext;
private static final java.util.logging.Logger _logger;
private java.lang.String[] enabledProtocols;
private java.lang.String[] enabledCipherSuites;
private static final java.lang.String errorPreparingSSL;
private static final java.lang.String noKeyEntry;
private static final java.lang.String noKeyStores;
private static final java.lang.String badMaxCertLength;
private static final java.lang.String keystoreLoadFailed;
private static final java.lang.String allVariantsDisabled;
private static final java.lang.String allCipherSuitesDisabled;
private static final java.lang.String unkCipher;
private void <init>()
{
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator getInstance()
{
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v, v, v, v;
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator sslCC>;
if v != null goto label;
v = new org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
specialinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: void <init>()>();
<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator sslCC> = v;
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator sslCC>;
return v;
label:
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator sslCC>;
return v;
}
public void setSSLParams(org.glassfish.admin.mbeanserver.ssl.SSLParams)
{
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
org.glassfish.admin.mbeanserver.ssl.SSLParams v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v := @parameter: org.glassfish.admin.mbeanserver.ssl.SSLParams;
v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams> = v;
return;
}
public javax.net.ssl.SSLContext configure(org.glassfish.admin.mbeanserver.ssl.SSLParams)
{
javax.net.ssl.SSLContext v, v, v;
java.util.logging.Level v, v;
java.security.SecureRandom v;
java.lang.String v, v, v, v;
org.glassfish.admin.mbeanserver.ssl.SSLParams v;
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
java.util.logging.Logger v, v;
java.lang.Exception v;
javax.net.ssl.TrustManager[] v;
java.security.NoSuchAlgorithmException v;
javax.net.ssl.KeyManager[] v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v := @parameter: org.glassfish.admin.mbeanserver.ssl.SSLParams;
v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams> = v;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getProtocol()>();
label:
v = staticinvoke <javax.net.ssl.SSLContext: javax.net.ssl.SSLContext getInstance(java.lang.String)>(v);
v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: javax.net.ssl.SSLContext sslContext> = v;
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level SEVERE>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, "NCLS-JMX-00014", v);
label:
specialinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: void configureCiphersAndProtocols()>();
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getTrustAlgorithm()>();
if v != null goto label;
v = staticinvoke <javax.net.ssl.TrustManagerFactory: java.lang.String getDefaultAlgorithm()>();
label:
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getKeyAlgorithm()>();
if v != null goto label;
v = "SunX509";
label:
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getCertNickname()>();
if v != null goto label;
v = "s1as";
label:
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: javax.net.ssl.SSLContext sslContext>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: javax.net.ssl.KeyManager[] getKeyManagers(java.lang.String,java.lang.String)>(v, v);
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: javax.net.ssl.TrustManager[] getTrustManagers(java.lang.String)>(v);
v = new java.security.SecureRandom;
specialinvoke v.<java.security.SecureRandom: void <init>()>();
virtualinvoke v.<javax.net.ssl.SSLContext: void init(javax.net.ssl.KeyManager[],javax.net.ssl.TrustManager[],java.security.SecureRandom)>(v, v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level SEVERE>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, "NCLS-JMX-00014", v);
label:
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: javax.net.ssl.SSLContext sslContext>;
return v;
catch java.security.NoSuchAlgorithmException from label to label with label;
catch java.lang.Exception from label to label with label;
}
public java.lang.String[] getEnabledProtocols()
{
java.lang.String[] v, v;
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String[] enabledProtocols>;
if v != null goto label;
specialinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: void configureCiphersAndProtocols()>();
label:
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String[] enabledProtocols>;
return v;
}
public java.lang.String getEnabledProtocolsAsString()
{
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
int v;
java.lang.String[] v, v, v;
java.lang.String v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String[] getEnabledProtocols()>();
if v == null goto label;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String[] getEnabledProtocols()>();
v = lengthof v;
if v <= 0 goto label;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String[] getEnabledProtocols()>();
v = specialinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String toCommaSeparatedString(java.lang.String[])>(v);
return v;
label:
return null;
}
public java.lang.String[] getEnabledCipherSuites()
{
java.lang.String[] v, v;
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String[] enabledCipherSuites>;
if v != null goto label;
specialinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: void configureCiphersAndProtocols()>();
label:
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String[] enabledCipherSuites>;
return v;
}
public java.lang.String getEnabledCipherSuitesAsString()
{
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
int v;
java.lang.String[] v, v, v;
java.lang.String v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String[] getEnabledCipherSuites()>();
if v == null goto label;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String[] getEnabledCipherSuites()>();
v = lengthof v;
if v <= 0 goto label;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String[] getEnabledCipherSuites()>();
v = specialinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String toCommaSeparatedString(java.lang.String[])>(v);
return v;
label:
return null;
}
protected javax.net.ssl.KeyManager[] getKeyManagers(java.lang.String, java.lang.String) throws java.lang.Exception
{
java.util.logging.Level v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v;
org.glassfish.admin.mbeanserver.ssl.SSLParams v, v, v, v;
boolean v;
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
javax.net.ssl.KeyManagerFactory v;
java.security.KeyStore v;
java.util.logging.Logger v, v, v, v, v;
java.io.File v;
char[] v;
javax.net.ssl.KeyManager[] v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("javax.net.ssl.keyStore");
if v != null goto label;
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, "NCLS-JMX-00016");
return null;
label:
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object)>(v, "Algorithm ::{0}", v);
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object)>(v, "Key Alias ::{0}", v);
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getKeyStoreType()>();
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object)>(v, "KeyStore Type ::{0}", v);
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getKeyStorePassword()>();
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getKeyStoreType()>();
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.io.File getKeyStore()>();
v = virtualinvoke v.<java.io.File: java.lang.String getPath()>();
v = specialinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.security.KeyStore getStore(java.lang.String,java.lang.String,java.lang.String)>(v, v, v);
if v == null goto label;
v = virtualinvoke v.<java.security.KeyStore: boolean isKeyEntry(java.lang.String)>(v);
if v != 0 goto label;
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object)>(v, "NCLS-JMX-00015", v);
return null;
label:
v = staticinvoke <javax.net.ssl.KeyManagerFactory: javax.net.ssl.KeyManagerFactory getInstance(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.String: char[] toCharArray()>();
virtualinvoke v.<javax.net.ssl.KeyManagerFactory: void init(java.security.KeyStore,char[])>(v, v);
v = virtualinvoke v.<javax.net.ssl.KeyManagerFactory: javax.net.ssl.KeyManager[] getKeyManagers()>();
return v;
}
protected javax.net.ssl.TrustManager[] getTrustManagers(java.lang.String) throws java.lang.Exception
{
java.security.cert.CertPathParameters v;
java.lang.Object[] v;
javax.net.ssl.CertPathTrustManagerParameters v;
java.util.logging.Level v;
java.lang.String v, v, v, v, v, v, v, v;
org.glassfish.admin.mbeanserver.ssl.SSLParams v, v, v, v, v, v, v;
javax.net.ssl.TrustManagerFactory v, v;
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
java.security.KeyStore v;
java.util.logging.Logger v;
java.io.File v, v;
javax.net.ssl.TrustManager[] v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v := @parameter: java.lang.String;
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getCrlFile()>();
v = null;
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = newarray (java.lang.Object)[3];
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getTrustStoreType()>();
v[0] = v;
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.io.File getTrustStore()>();
v = virtualinvoke v.<java.io.File: java.lang.String getPath()>();
v[1] = v;
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getTrustStorePassword()>();
v[2] = v;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object[])>(v, "in getTrustManagers TrustManager type = {0} path = {1} password = {2}", v);
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getTrustStoreType()>();
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.io.File getTrustStore()>();
v = virtualinvoke v.<java.io.File: java.lang.String getPath()>();
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getTrustStorePassword()>();
v = specialinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.security.KeyStore getStore(java.lang.String,java.lang.String,java.lang.String)>(v, v, v);
if v == null goto label;
if v != null goto label;
v = staticinvoke <javax.net.ssl.TrustManagerFactory: javax.net.ssl.TrustManagerFactory getInstance(java.lang.String)>(v);
virtualinvoke v.<javax.net.ssl.TrustManagerFactory: void init(java.security.KeyStore)>(v);
v = virtualinvoke v.<javax.net.ssl.TrustManagerFactory: javax.net.ssl.TrustManager[] getTrustManagers()>();
goto label;
label:
v = staticinvoke <javax.net.ssl.TrustManagerFactory: javax.net.ssl.TrustManagerFactory getInstance(java.lang.String)>(v);
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.security.cert.CertPathParameters getParameters(java.lang.String,java.lang.String,java.security.KeyStore)>(v, v, v);
v = new javax.net.ssl.CertPathTrustManagerParameters;
specialinvoke v.<javax.net.ssl.CertPathTrustManagerParameters: void <init>(java.security.cert.CertPathParameters)>(v);
virtualinvoke v.<javax.net.ssl.TrustManagerFactory: void init(javax.net.ssl.ManagerFactoryParameters)>(v);
v = virtualinvoke v.<javax.net.ssl.TrustManagerFactory: javax.net.ssl.TrustManager[] getTrustManagers()>();
label:
return v;
}
protected java.security.cert.CertPathParameters getParameters(java.lang.String, java.lang.String, java.security.KeyStore) throws java.lang.Exception
{
java.util.logging.Level v;
int v;
java.lang.String v, v, v, v, v;
org.glassfish.admin.mbeanserver.ssl.SSLParams v;
boolean v;
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
java.security.cert.X509CertSelector v;
java.util.Collection v;
java.security.KeyStore v;
java.util.logging.Logger v;
java.lang.Exception v;
java.security.cert.CollectionCertStoreParameters v;
java.security.cert.PKIXBuilderParameters v;
java.security.cert.CertStore v;
java.security.cert.CRLException v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.security.KeyStore;
v = "PKIX";
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>(v);
if v == 0 goto label;
v = new java.security.cert.PKIXBuilderParameters;
v = new java.security.cert.X509CertSelector;
specialinvoke v.<java.security.cert.X509CertSelector: void <init>()>();
specialinvoke v.<java.security.cert.PKIXBuilderParameters: void <init>(java.security.KeyStore,java.security.cert.CertSelector)>(v, v);
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.Collection getCRLs(java.lang.String)>(v);
v = new java.security.cert.CollectionCertStoreParameters;
specialinvoke v.<java.security.cert.CollectionCertStoreParameters: void <init>(java.util.Collection)>(v);
v = staticinvoke <java.security.cert.CertStore: java.security.cert.CertStore getInstance(java.lang.String,java.security.cert.CertStoreParameters)>("Collection", v);
virtualinvoke v.<java.security.cert.PKIXBuilderParameters: void addCertStore(java.security.cert.CertStore)>(v);
virtualinvoke v.<java.security.cert.PKIXBuilderParameters: void setRevocationEnabled(boolean)>(1);
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getTrustMaxCertLength()>();
if v == null goto label;
label:
v = staticinvoke <java.lang.Integer: int parseInt(java.lang.String)>(v);
virtualinvoke v.<java.security.cert.PKIXBuilderParameters: void setMaxPathLength(int)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object)>(v, "NCLS-JMX-00017", v);
goto label;
label:
v = new java.security.cert.CRLException;
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[])>("CRLs not supported for type: \u0001");
specialinvoke v.<java.security.cert.CRLException: void <init>(java.lang.String)>(v);
throw v;
label:
return v;
catch java.lang.Exception from label to label with label;
}
protected java.util.Collection getCRLs(java.lang.String) throws java.io.IOException, java.security.cert.CRLException, java.security.cert.CertificateException
{
java.lang.Throwable v;
java.security.cert.CertificateFactory v;
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
java.util.Collection v;
java.io.IOException v;
java.io.FileInputStream v, v;
java.security.cert.CertificateException v;
java.io.File v, v, v;
java.lang.String v, v;
java.security.cert.CRLException v;
boolean v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v := @parameter: java.lang.String;
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = v;
v = virtualinvoke v.<java.io.File: boolean isAbsolute()>();
if v != 0 goto label;
v = new java.io.File;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("catalina.base");
specialinvoke v.<java.io.File: void <init>(java.lang.String,java.lang.String)>(v, v);
v = v;
label:
v = staticinvoke <java.security.cert.CertificateFactory: java.security.cert.CertificateFactory getInstance(java.lang.String)>("X.509");
v = new java.io.FileInputStream;
specialinvoke v.<java.io.FileInputStream: void <init>(java.io.File)>(v);
v = virtualinvoke v.<java.security.cert.CertificateFactory: java.util.Collection generateCRLs(java.io.InputStream)>(v);
label:
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
throw v;
label:
return v;
catch java.io.IOException from label to label with label;
catch java.security.cert.CRLException from label to label with label;
catch java.security.cert.CertificateException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private java.security.KeyStore getStore(java.lang.String, java.lang.String, java.lang.String) throws java.io.IOException
{
boolean v, v, v;
java.security.KeyStore v;
java.util.logging.Logger v, v, v;
java.io.FileNotFoundException v;
java.lang.Exception v;
java.lang.Throwable v;
java.lang.Object[] v, v, v;
java.util.logging.Level v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v;
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
java.io.IOException v, v;
java.io.FileInputStream v, v;
java.io.File v, v, v;
char[] v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = null;
label:
v = staticinvoke <java.security.KeyStore: java.security.KeyStore getInstance(java.lang.String)>(v);
v = "PKCS11";
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>(v);
if v != 0 goto label;
v = "";
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>(v);
if v != 0 goto label;
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = v;
v = virtualinvoke v.<java.io.File: boolean isAbsolute()>();
if v != 0 goto label;
v = new java.io.File;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("catalina.base");
specialinvoke v.<java.io.File: void <init>(java.lang.String,java.lang.String)>(v, v);
v = v;
label:
v = new java.io.FileInputStream;
specialinvoke v.<java.io.FileInputStream: void <init>(java.io.File)>(v);
v = v;
label:
v = virtualinvoke v.<java.lang.String: char[] toCharArray()>();
virtualinvoke v.<java.security.KeyStore: void load(java.io.InputStream,char[])>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level SEVERE>;
v = newarray (java.lang.Object)[3];
v[0] = v;
v[1] = v;
v = virtualinvoke v.<java.io.FileNotFoundException: java.lang.String getMessage()>();
v[2] = v;
v = staticinvoke <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String formatMessage(java.lang.String,java.lang.Object[])>("NCLS-JMX-00018", v);
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, v, v);
throw v;
label:
v := @caughtexception;
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level SEVERE>;
v = newarray (java.lang.Object)[3];
v[0] = v;
v[1] = v;
v = virtualinvoke v.<java.io.IOException: java.lang.String getMessage()>();
v[2] = v;
v = staticinvoke <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String formatMessage(java.lang.String,java.lang.Object[])>("NCLS-JMX-00018", v);
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, v, v);
throw v;
label:
v := @caughtexception;
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level SEVERE>;
v = newarray (java.lang.Object)[3];
v[0] = v;
v[1] = v;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
v[2] = v;
v = staticinvoke <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String formatMessage(java.lang.String,java.lang.Object[])>("NCLS-JMX-00018", v);
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, v, v);
v = new java.io.IOException;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
v := @caughtexception;
throw v;
label:
return v;
catch java.io.FileNotFoundException from label to label with label;
catch java.io.IOException from label to label with label;
catch java.lang.Exception from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private static transient java.lang.String formatMessage(java.lang.String, java.lang.Object[])
{
java.lang.Object[] v;
java.util.ResourceBundle v;
java.lang.String v, v, v;
java.util.logging.Logger v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Object[];
v = <org.glassfish.admin.mbeanserver.Util: java.util.logging.Logger JMX_LOGGER>;
v = virtualinvoke v.<java.util.logging.Logger: java.util.ResourceBundle getResourceBundle()>();
v = virtualinvoke v.<java.util.ResourceBundle: java.lang.String getString(java.lang.String)>(v);
v = staticinvoke <java.text.MessageFormat: java.lang.String format(java.lang.String,java.lang.Object[])>(v, v);
return v;
}
private void configureCiphersAndProtocols()
{
org.glassfish.admin.mbeanserver.ssl.SSLParams v, v, v, v, v, v, v, v, v, v, v;
boolean v, v, v, v, v, v, v, v, v;
java.util.logging.Logger v, v;
java.lang.String[] v, v, v, v;
java.util.logging.Level v, v;
int v, v, v, v, v, v, v, v;
java.lang.Boolean v, v, v, v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v;
java.util.LinkedList v;
java.io.PrintStream v;
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v = new java.util.LinkedList;
specialinvoke v.<java.util.LinkedList: void <init>()>();
v = <java.lang.System: java.io.PrintStream out>;
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.glassfish.admin.mbeanserver.ssl.SSLParams)>(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[])>("SSLParams =\u0001");
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.Boolean getSsl2Enabled()>();
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>("SSLv2");
label:
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.Boolean getSsl3Enabled()>();
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>("SSLv3");
label:
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.Boolean getTlsEnabled()>();
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>("TLSv1");
label:
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.Boolean getTls11Enabled()>();
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>("TLSv.1");
label:
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.Boolean getTls12Enabled()>();
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>("TLSv.2");
label:
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.Boolean getTls13Enabled()>();
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>("TLSv.3");
label:
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.Boolean getSsl3Enabled()>();
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v != 0 goto label;
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.Boolean getTlsEnabled()>();
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
label:
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>("SSLv2Hello");
label:
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, "NCLS-JMX-00019");
goto label;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (java.lang.String)[v];
interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String[] enabledProtocols> = v;
label:
interfaceinvoke v.<java.util.List: void clear()>();
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getSsl3TlsCiphers()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>(",");
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: org.glassfish.admin.mbeanserver.ssl.SSLParams sslParams>;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLParams: java.lang.String getSsl2Ciphers()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>(",");
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = specialinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String[] getJSSECiphers(java.util.List)>(v);
if v == null goto label;
v = lengthof v;
if v != 0 goto label;
label:
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, "NCLS-JMX-00020");
goto label;
label:
v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String[] enabledCipherSuites> = v;
label:
return;
}
private java.lang.String[] getJSSECiphers(java.util.List)
{
java.lang.Object[] v;
java.lang.String[] v;
java.util.logging.Level v;
java.util.HashSet v, v;
int v, v, v;
java.lang.String v;
boolean v;
java.util.Iterator v;
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
char v, v;
java.util.logging.Logger v;
java.util.List v;
java.lang.Object v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v := @parameter: java.util.List;
v = null;
v = interfaceinvoke v.<java.util.List: 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()>();
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
v = virtualinvoke v.<java.lang.String: char charAt(int)>(0);
if v == 45 goto label;
v = virtualinvoke v.<java.lang.String: char charAt(int)>(0);
if v != 43 goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(1);
label:
v = staticinvoke <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.lang.String getJSSECipher(java.lang.String)>(v);
if v != null goto label;
v = <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object)>(v, "NCLS-JMX-00021", v);
goto label;
label:
if v != null goto label;
v = new java.util.HashSet;
v = interfaceinvoke v.<java.util.List: int size()>();
specialinvoke v.<java.util.HashSet: void <init>(int)>(v);
v = v;
label:
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
goto label;
label:
if v == null goto label;
v = interfaceinvoke v.<java.util.Set: int size()>();
v = newarray (java.lang.String)[v];
v = interfaceinvoke v.<java.util.Set: java.lang.Object[] toArray(java.lang.Object[])>(v);
label:
return v;
}
private static java.lang.String getJSSECipher(java.lang.String)
{
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator$CipherInfo v;
java.lang.String v, v;
v := @parameter: java.lang.String;
v = staticinvoke <org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator$CipherInfo: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator$CipherInfo getCipherInfo(java.lang.String)>(v);
if v == null goto label;
v = virtualinvoke v.<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator$CipherInfo: java.lang.String getCipherName()>();
goto label;
label:
v = null;
label:
return v;
}
private java.lang.String toCommaSeparatedString(java.lang.String[])
{
org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator v;
java.lang.String[] v;
int v, v;
java.lang.StringBuilder v;
java.lang.String v, v, v;
v := @this: org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator;
v := @parameter: java.lang.String[];
v = new java.lang.StringBuilder;
v = v[0];
specialinvoke v.<java.lang.StringBuilder: void <init>(java.lang.String)>(v);
v = 1;
label:
v = lengthof v;
if v >= v goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(",");
v = v[v];
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
return v;
}
static void <clinit>()
{
java.util.logging.Logger v;
v = staticinvoke <org.glassfish.admin.mbeanserver.Util: java.util.logging.Logger getLogger()>();
<org.glassfish.admin.mbeanserver.ssl.SSLClientConfigurator: java.util.logging.Logger _logger> = v;
return;
}
}