public class org.apache.http.conn.ssl.SSLContextBuilder extends java.lang.Object
{
static final java.lang.String TLS;
static final java.lang.String SSL;
private java.lang.String protocol;
private final java.util.Set keymanagers;
private final java.util.Set trustmanagers;
private java.security.SecureRandom secureRandom;
public void <init>()
{
java.util.LinkedHashSet v, v;
org.apache.http.conn.ssl.SSLContextBuilder v;
v := @this: org.apache.http.conn.ssl.SSLContextBuilder;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>()>();
v.<org.apache.http.conn.ssl.SSLContextBuilder: java.util.Set keymanagers> = v;
v = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>()>();
v.<org.apache.http.conn.ssl.SSLContextBuilder: java.util.Set trustmanagers> = v;
return;
}
public org.apache.http.conn.ssl.SSLContextBuilder useTLS()
{
org.apache.http.conn.ssl.SSLContextBuilder v;
v := @this: org.apache.http.conn.ssl.SSLContextBuilder;
v.<org.apache.http.conn.ssl.SSLContextBuilder: java.lang.String protocol> = "TLS";
return v;
}
public org.apache.http.conn.ssl.SSLContextBuilder useSSL()
{
org.apache.http.conn.ssl.SSLContextBuilder v;
v := @this: org.apache.http.conn.ssl.SSLContextBuilder;
v.<org.apache.http.conn.ssl.SSLContextBuilder: java.lang.String protocol> = "SSL";
return v;
}
public org.apache.http.conn.ssl.SSLContextBuilder useProtocol(java.lang.String)
{
java.lang.String v;
org.apache.http.conn.ssl.SSLContextBuilder v;
v := @this: org.apache.http.conn.ssl.SSLContextBuilder;
v := @parameter: java.lang.String;
v.<org.apache.http.conn.ssl.SSLContextBuilder: java.lang.String protocol> = v;
return v;
}
public org.apache.http.conn.ssl.SSLContextBuilder setSecureRandom(java.security.SecureRandom)
{
java.security.SecureRandom v;
org.apache.http.conn.ssl.SSLContextBuilder v;
v := @this: org.apache.http.conn.ssl.SSLContextBuilder;
v := @parameter: java.security.SecureRandom;
v.<org.apache.http.conn.ssl.SSLContextBuilder: java.security.SecureRandom secureRandom> = v;
return v;
}
public org.apache.http.conn.ssl.SSLContextBuilder loadTrustMaterial(java.security.KeyStore, org.apache.http.conn.ssl.TrustStrategy) throws java.security.NoSuchAlgorithmException, java.security.KeyStoreException
{
javax.net.ssl.TrustManagerFactory v;
org.apache.http.conn.ssl.TrustStrategy v;
java.util.Set v;
javax.net.ssl.TrustManager v;
java.security.KeyStore v;
org.apache.http.conn.ssl.SSLContextBuilder v;
org.apache.http.conn.ssl.SSLContextBuilder$TrustManagerDelegate v;
javax.net.ssl.TrustManager[] v;
int v, v;
java.lang.String v;
boolean v;
v := @this: org.apache.http.conn.ssl.SSLContextBuilder;
v := @parameter: java.security.KeyStore;
v := @parameter: org.apache.http.conn.ssl.TrustStrategy;
v = staticinvoke <javax.net.ssl.TrustManagerFactory: java.lang.String getDefaultAlgorithm()>();
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()>();
if v == null goto label;
if v == null goto label;
v = 0;
label:
v = lengthof v;
if v >= v goto label;
v = v[v];
v = v instanceof javax.net.ssl.X509TrustManager;
if v == 0 goto label;
v = new org.apache.http.conn.ssl.SSLContextBuilder$TrustManagerDelegate;
specialinvoke v.<org.apache.http.conn.ssl.SSLContextBuilder$TrustManagerDelegate: void <init>(javax.net.ssl.X509TrustManager,org.apache.http.conn.ssl.TrustStrategy)>(v, v);
v[v] = v;
label:
v = v + 1;
goto label;
label:
v = v.<org.apache.http.conn.ssl.SSLContextBuilder: java.util.Set trustmanagers>;
staticinvoke <java.util.Collections: boolean addAll(java.util.Collection,java.lang.Object[])>(v, v);
label:
return v;
}
public org.apache.http.conn.ssl.SSLContextBuilder loadTrustMaterial(java.security.KeyStore) throws java.security.NoSuchAlgorithmException, java.security.KeyStoreException
{
java.security.KeyStore v;
org.apache.http.conn.ssl.SSLContextBuilder v, v;
v := @this: org.apache.http.conn.ssl.SSLContextBuilder;
v := @parameter: java.security.KeyStore;
v = virtualinvoke v.<org.apache.http.conn.ssl.SSLContextBuilder: org.apache.http.conn.ssl.SSLContextBuilder loadTrustMaterial(java.security.KeyStore,org.apache.http.conn.ssl.TrustStrategy)>(v, null);
return v;
}
public org.apache.http.conn.ssl.SSLContextBuilder loadKeyMaterial(java.security.KeyStore, char[]) throws java.security.NoSuchAlgorithmException, java.security.KeyStoreException, java.security.UnrecoverableKeyException
{
char[] v;
java.security.KeyStore v;
org.apache.http.conn.ssl.SSLContextBuilder v;
v := @this: org.apache.http.conn.ssl.SSLContextBuilder;
v := @parameter: java.security.KeyStore;
v := @parameter: char[];
virtualinvoke v.<org.apache.http.conn.ssl.SSLContextBuilder: org.apache.http.conn.ssl.SSLContextBuilder loadKeyMaterial(java.security.KeyStore,char[],org.apache.http.conn.ssl.PrivateKeyStrategy)>(v, v, null);
return v;
}
public org.apache.http.conn.ssl.SSLContextBuilder loadKeyMaterial(java.security.KeyStore, char[], org.apache.http.conn.ssl.PrivateKeyStrategy) throws java.security.NoSuchAlgorithmException, java.security.KeyStoreException, java.security.UnrecoverableKeyException
{
org.apache.http.conn.ssl.PrivateKeyStrategy v;
java.util.Set v;
javax.net.ssl.KeyManagerFactory v;
java.security.KeyStore v;
javax.net.ssl.KeyManager v;
org.apache.http.conn.ssl.SSLContextBuilder v;
org.apache.http.conn.ssl.SSLContextBuilder$KeyManagerDelegate v;
int v, v;
char[] v;
java.lang.String v;
boolean v;
javax.net.ssl.KeyManager[] v;
v := @this: org.apache.http.conn.ssl.SSLContextBuilder;
v := @parameter: java.security.KeyStore;
v := @parameter: char[];
v := @parameter: org.apache.http.conn.ssl.PrivateKeyStrategy;
v = staticinvoke <javax.net.ssl.KeyManagerFactory: java.lang.String getDefaultAlgorithm()>();
v = staticinvoke <javax.net.ssl.KeyManagerFactory: javax.net.ssl.KeyManagerFactory getInstance(java.lang.String)>(v);
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()>();
if v == null goto label;
if v == null goto label;
v = 0;
label:
v = lengthof v;
if v >= v goto label;
v = v[v];
v = v instanceof javax.net.ssl.X509KeyManager;
if v == 0 goto label;
v = new org.apache.http.conn.ssl.SSLContextBuilder$KeyManagerDelegate;
specialinvoke v.<org.apache.http.conn.ssl.SSLContextBuilder$KeyManagerDelegate: void <init>(javax.net.ssl.X509KeyManager,org.apache.http.conn.ssl.PrivateKeyStrategy)>(v, v);
v[v] = v;
label:
v = v + 1;
goto label;
label:
v = v.<org.apache.http.conn.ssl.SSLContextBuilder: java.util.Set keymanagers>;
staticinvoke <java.util.Collections: boolean addAll(java.util.Collection,java.lang.Object[])>(v, v);
label:
return v;
}
public javax.net.ssl.SSLContext build() throws java.security.NoSuchAlgorithmException, java.security.KeyManagementException
{
javax.net.ssl.SSLContext v;
java.lang.Object[] v, v;
java.security.SecureRandom v;
int v, v;
java.lang.String v, v;
boolean v, v;
java.util.Set v, v, v, v, v, v;
org.apache.http.conn.ssl.SSLContextBuilder v;
javax.net.ssl.TrustManager[] v;
javax.net.ssl.KeyManager[] v;
v := @this: org.apache.http.conn.ssl.SSLContextBuilder;
v = v.<org.apache.http.conn.ssl.SSLContextBuilder: java.lang.String protocol>;
if v == null goto label;
v = v.<org.apache.http.conn.ssl.SSLContextBuilder: java.lang.String protocol>;
goto label;
label:
v = "TLS";
label:
v = staticinvoke <javax.net.ssl.SSLContext: javax.net.ssl.SSLContext getInstance(java.lang.String)>(v);
v = v.<org.apache.http.conn.ssl.SSLContextBuilder: java.util.Set keymanagers>;
v = interfaceinvoke v.<java.util.Set: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.http.conn.ssl.SSLContextBuilder: java.util.Set keymanagers>;
v = v.<org.apache.http.conn.ssl.SSLContextBuilder: java.util.Set keymanagers>;
v = interfaceinvoke v.<java.util.Set: int size()>();
v = newarray (javax.net.ssl.KeyManager)[v];
v = interfaceinvoke v.<java.util.Set: java.lang.Object[] toArray(java.lang.Object[])>(v);
goto label;
label:
v = null;
label:
v = v.<org.apache.http.conn.ssl.SSLContextBuilder: java.util.Set trustmanagers>;
v = interfaceinvoke v.<java.util.Set: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.http.conn.ssl.SSLContextBuilder: java.util.Set trustmanagers>;
v = v.<org.apache.http.conn.ssl.SSLContextBuilder: java.util.Set trustmanagers>;
v = interfaceinvoke v.<java.util.Set: int size()>();
v = newarray (javax.net.ssl.TrustManager)[v];
v = interfaceinvoke v.<java.util.Set: java.lang.Object[] toArray(java.lang.Object[])>(v);
goto label;
label:
v = null;
label:
v = v.<org.apache.http.conn.ssl.SSLContextBuilder: java.security.SecureRandom secureRandom>;
virtualinvoke v.<javax.net.ssl.SSLContext: void init(javax.net.ssl.KeyManager[],javax.net.ssl.TrustManager[],java.security.SecureRandom)>(v, v, v);
return v;
}
}