final class org.apache.hc.client.http.ssl.TlsSessionValidator extends java.lang.Object
{
private final org.slf4j.Logger log;
void <init>(org.slf4j.Logger)
{
org.apache.hc.client.http.ssl.TlsSessionValidator v;
org.slf4j.Logger v;
v := @this: org.apache.hc.client.http.ssl.TlsSessionValidator;
v := @parameter: org.slf4j.Logger;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.hc.client.http.ssl.TlsSessionValidator: org.slf4j.Logger log> = v;
return;
}
void verifySession(java.lang.String, javax.net.ssl.SSLSession, javax.net.ssl.HostnameVerifier) throws javax.net.ssl.SSLException
{
javax.net.ssl.HostnameVerifier v;
boolean v, v, v, v, v, v, v, v, v;
java.util.Collection v, v;
org.apache.hc.client.http.ssl.TlsSessionValidator v;
java.lang.Exception v;
java.util.List v;
java.security.cert.Certificate v, v;
java.security.cert.Certificate[] v, v;
javax.security.auth.x.X500Principal v, v;
java.util.ArrayList v, v;
javax.net.ssl.SSLSession v;
int v;
java.lang.String v, v, v, v, v, v;
org.slf4j.Logger v, v, v, v, v, v, v, v;
java.util.Iterator v, v;
java.lang.Object v, v, v, v;
javax.net.ssl.SSLPeerUnverifiedException v, v, v;
v := @this: org.apache.hc.client.http.ssl.TlsSessionValidator;
v := @parameter: java.lang.String;
v := @parameter: javax.net.ssl.SSLSession;
v := @parameter: javax.net.ssl.HostnameVerifier;
v = v.<org.apache.hc.client.http.ssl.TlsSessionValidator: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = v.<org.apache.hc.client.http.ssl.TlsSessionValidator: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Secure session established");
v = v.<org.apache.hc.client.http.ssl.TlsSessionValidator: org.slf4j.Logger log>;
v = interfaceinvoke v.<javax.net.ssl.SSLSession: java.lang.String getProtocol()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>(" negotiated protocol: {}", v);
v = v.<org.apache.hc.client.http.ssl.TlsSessionValidator: org.slf4j.Logger log>;
v = interfaceinvoke v.<javax.net.ssl.SSLSession: java.lang.String getCipherSuite()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>(" negotiated cipher suite: {}", v);
label:
v = interfaceinvoke v.<javax.net.ssl.SSLSession: java.security.cert.Certificate[] getPeerCertificates()>();
v = v[0];
v = v instanceof java.security.cert.X509Certificate;
if v == 0 goto label;
v = virtualinvoke v.<java.security.cert.X509Certificate: javax.security.auth.x.X500Principal getSubjectX500Principal()>();
v = v.<org.apache.hc.client.http.ssl.TlsSessionValidator: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>(" peer principal: {}", v);
v = virtualinvoke v.<java.security.cert.X509Certificate: java.util.Collection getSubjectAlternativeNames()>();
if v == null goto label;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = interfaceinvoke v.<java.util.Collection: 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 = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(1);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = v.<org.apache.hc.client.http.ssl.TlsSessionValidator: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>(" peer alternative names: {}", v);
label:
v = virtualinvoke v.<java.security.cert.X509Certificate: javax.security.auth.x.X500Principal getIssuerX500Principal()>();
v = v.<org.apache.hc.client.http.ssl.TlsSessionValidator: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>(" issuer principal: {}", v);
v = virtualinvoke v.<java.security.cert.X509Certificate: java.util.Collection getIssuerAlternativeNames()>();
if v == null goto label;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = interfaceinvoke v.<java.util.Collection: 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 = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(1);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = v.<org.apache.hc.client.http.ssl.TlsSessionValidator: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>(" issuer alternative names: {}", v);
label:
goto label;
label:
v := @caughtexception;
label:
if v == null goto label;
v = interfaceinvoke v.<javax.net.ssl.SSLSession: java.security.cert.Certificate[] getPeerCertificates()>();
v = lengthof v;
if v >= 1 goto label;
v = new javax.net.ssl.SSLPeerUnverifiedException;
specialinvoke v.<javax.net.ssl.SSLPeerUnverifiedException: void <init>(java.lang.String)>("Peer certificate chain is empty");
throw v;
label:
v = v[0];
v = v instanceof java.security.cert.X509Certificate;
if v != 0 goto label;
v = new javax.net.ssl.SSLPeerUnverifiedException;
v = virtualinvoke v.<java.security.cert.Certificate: java.lang.String getType()>();
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[])>("Unexpected certificate type: \u0001");
specialinvoke v.<javax.net.ssl.SSLPeerUnverifiedException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v instanceof org.apache.hc.client.http.ssl.HttpClientHostnameVerifier;
if v == 0 goto label;
interfaceinvoke v.<org.apache.hc.client.http.ssl.HttpClientHostnameVerifier: void verify(java.lang.String,java.security.cert.X509Certificate)>(v, v);
goto label;
label:
v = interfaceinvoke v.<javax.net.ssl.HostnameVerifier: boolean verify(java.lang.String,javax.net.ssl.SSLSession)>(v, v);
if v != 0 goto label;
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: java.util.List getSubjectAltNames(java.security.cert.X509Certificate)>(v);
v = new javax.net.ssl.SSLPeerUnverifiedException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.util.List)>(v, 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[])>("Certificate for <\u0001> doesn\'t match any of the subject alternative names: \u0001");
specialinvoke v.<javax.net.ssl.SSLPeerUnverifiedException: void <init>(java.lang.String)>(v);
throw v;
label:
return;
catch java.lang.Exception from label to label with label;
}
}