public final class org.apache.hc.client.http.ssl.DefaultHostnameVerifier extends java.lang.Object implements org.apache.hc.client.http.ssl.HttpClientHostnameVerifier
{
private static final org.slf4j.Logger LOG;
private final org.apache.hc.client.http.psl.PublicSuffixMatcher publicSuffixMatcher;
public void <init>(org.apache.hc.client.http.psl.PublicSuffixMatcher)
{
org.apache.hc.client.http.ssl.DefaultHostnameVerifier v;
org.apache.hc.client.http.psl.PublicSuffixMatcher v;
v := @this: org.apache.hc.client.http.ssl.DefaultHostnameVerifier;
v := @parameter: org.apache.hc.client.http.psl.PublicSuffixMatcher;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.hc.client.http.ssl.DefaultHostnameVerifier: org.apache.hc.client.http.psl.PublicSuffixMatcher publicSuffixMatcher> = v;
return;
}
public void <init>()
{
org.apache.hc.client.http.ssl.DefaultHostnameVerifier v;
v := @this: org.apache.hc.client.http.ssl.DefaultHostnameVerifier;
specialinvoke v.<org.apache.hc.client.http.ssl.DefaultHostnameVerifier: void <init>(org.apache.hc.client.http.psl.PublicSuffixMatcher)>(null);
return;
}
public boolean verify(java.lang.String, javax.net.ssl.SSLSession)
{
org.apache.hc.client.http.ssl.DefaultHostnameVerifier v;
org.slf4j.Logger v, v;
javax.net.ssl.SSLException v;
java.security.cert.Certificate v;
javax.net.ssl.SSLSession v;
java.security.cert.Certificate[] v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.hc.client.http.ssl.DefaultHostnameVerifier;
v := @parameter: java.lang.String;
v := @parameter: javax.net.ssl.SSLSession;
label:
v = interfaceinvoke v.<javax.net.ssl.SSLSession: java.security.cert.Certificate[] getPeerCertificates()>();
v = v[0];
virtualinvoke v.<org.apache.hc.client.http.ssl.DefaultHostnameVerifier: void verify(java.lang.String,java.security.cert.X509Certificate)>(v, v);
label:
return 1;
label:
v := @caughtexception;
v = <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: org.slf4j.Logger LOG>;
v = virtualinvoke v.<javax.net.ssl.SSLException: java.lang.String getMessage()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>(v, v);
label:
return 0;
catch javax.net.ssl.SSLException from label to label with label;
}
public void verify(java.lang.String, java.security.cert.X509Certificate) throws javax.net.ssl.SSLException
{
java.security.cert.X509Certificate v;
org.apache.hc.client.http.ssl.DefaultHostnameVerifier v;
org.apache.hc.client.http.psl.PublicSuffixMatcher v, v;
org.apache.hc.client.http.ssl.DefaultHostnameVerifier$HostNameType v;
java.util.List v, v, v;
int[] v;
int v, v;
java.lang.String v;
boolean v;
v := @this: org.apache.hc.client.http.ssl.DefaultHostnameVerifier;
v := @parameter: java.lang.String;
v := @parameter: java.security.cert.X509Certificate;
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: org.apache.hc.client.http.ssl.DefaultHostnameVerifier$HostNameType determineHostFormat(java.lang.String)>(v);
v = <org.apache.hc.client.http.ssl.DefaultHostnameVerifier$1: int[] $SwitchMap$org$apache$hc$client5$http$ssl$DefaultHostnameVerifier$HostNameType>;
v = virtualinvoke v.<org.apache.hc.client.http.ssl.DefaultHostnameVerifier$HostNameType: int ordinal()>();
v = v[v];
lookupswitch(v)
{
case 1: goto label;
case 2: goto label;
default: goto label;
};
label:
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: java.util.List getSubjectAltNames(java.security.cert.X509Certificate,int)>(v, 7);
staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: void matchIPAddress(java.lang.String,java.util.List)>(v, v);
goto label;
label:
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: java.util.List getSubjectAltNames(java.security.cert.X509Certificate,int)>(v, 7);
staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: void matchIPv6Address(java.lang.String,java.util.List)>(v, v);
goto label;
label:
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: java.util.List getSubjectAltNames(java.security.cert.X509Certificate,int)>(v, 2);
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
v = v.<org.apache.hc.client.http.ssl.DefaultHostnameVerifier: org.apache.hc.client.http.psl.PublicSuffixMatcher publicSuffixMatcher>;
staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: void matchCN(java.lang.String,java.security.cert.X509Certificate,org.apache.hc.client.http.psl.PublicSuffixMatcher)>(v, v, v);
goto label;
label:
v = v.<org.apache.hc.client.http.ssl.DefaultHostnameVerifier: org.apache.hc.client.http.psl.PublicSuffixMatcher publicSuffixMatcher>;
staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: void matchDNSName(java.lang.String,java.util.List,org.apache.hc.client.http.psl.PublicSuffixMatcher)>(v, v, v);
label:
return;
}
static void matchIPAddress(java.lang.String, java.util.List) throws javax.net.ssl.SSLException
{
java.util.List v;
int v, v, v;
java.lang.Object v;
java.lang.String v, v, v;
boolean v;
javax.net.ssl.SSLPeerUnverifiedException v;
v := @parameter: java.lang.String;
v := @parameter: java.util.List;
v = 0;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= v goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
v = virtualinvoke v.<org.apache.hc.client.http.ssl.SubjectName: int getType()>();
if v != 7 goto label;
v = virtualinvoke v.<org.apache.hc.client.http.ssl.SubjectName: java.lang.String getValue()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
return;
label:
v = v + 1;
goto label;
label:
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;
}
static void matchIPv6Address(java.lang.String, java.util.List) throws javax.net.ssl.SSLException
{
java.util.List v;
int v, v, v;
java.lang.Object v;
java.lang.String v, v, v, v, v;
boolean v;
javax.net.ssl.SSLPeerUnverifiedException v;
v := @parameter: java.lang.String;
v := @parameter: java.util.List;
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: java.lang.String normaliseAddress(java.lang.String)>(v);
v = 0;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= v goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
v = virtualinvoke v.<org.apache.hc.client.http.ssl.SubjectName: int getType()>();
if v != 7 goto label;
v = virtualinvoke v.<org.apache.hc.client.http.ssl.SubjectName: java.lang.String getValue()>();
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: java.lang.String normaliseAddress(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
return;
label:
v = v + 1;
goto label;
label:
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;
}
static void matchDNSName(java.lang.String, java.util.List, org.apache.hc.client.http.psl.PublicSuffixMatcher) throws javax.net.ssl.SSLException
{
org.apache.hc.client.http.psl.PublicSuffixMatcher v;
java.util.List v;
int v, v, v;
java.lang.Object v;
java.lang.String v, v, v, v, v;
boolean v;
javax.net.ssl.SSLPeerUnverifiedException v;
v := @parameter: java.lang.String;
v := @parameter: java.util.List;
v := @parameter: org.apache.hc.client.http.psl.PublicSuffixMatcher;
v = staticinvoke <org.apache.hc.client.http.utils.DnsUtils: java.lang.String normalize(java.lang.String)>(v);
v = 0;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= v goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
v = virtualinvoke v.<org.apache.hc.client.http.ssl.SubjectName: int getType()>();
if v != 2 goto label;
v = virtualinvoke v.<org.apache.hc.client.http.ssl.SubjectName: java.lang.String getValue()>();
v = staticinvoke <org.apache.hc.client.http.utils.DnsUtils: java.lang.String normalize(java.lang.String)>(v);
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: boolean matchIdentityStrict(java.lang.String,java.lang.String,org.apache.hc.client.http.psl.PublicSuffixMatcher)>(v, v, v);
if v == 0 goto label;
return;
label:
v = v + 1;
goto label;
label:
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;
}
static void matchCN(java.lang.String, java.security.cert.X509Certificate, org.apache.hc.client.http.psl.PublicSuffixMatcher) throws javax.net.ssl.SSLException
{
java.security.cert.X509Certificate v;
javax.security.auth.x.X500Principal v;
org.apache.hc.client.http.psl.PublicSuffixMatcher v;
java.lang.String v, v, v, v, v, v, v;
boolean v;
javax.net.ssl.SSLPeerUnverifiedException v, v;
v := @parameter: java.lang.String;
v := @parameter: java.security.cert.X509Certificate;
v := @parameter: org.apache.hc.client.http.psl.PublicSuffixMatcher;
v = virtualinvoke v.<java.security.cert.X509Certificate: javax.security.auth.x.X500Principal getSubjectX500Principal()>();
v = virtualinvoke v.<javax.security.auth.x.X500Principal: java.lang.String getName(java.lang.String)>("RFC2253");
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: java.lang.String extractCN(java.lang.String)>(v);
if v != null goto label;
v = new javax.net.ssl.SSLPeerUnverifiedException;
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[])>("Certificate subject for <\u0001> doesn\'t contain a common name and does not have alternative names");
specialinvoke v.<javax.net.ssl.SSLPeerUnverifiedException: void <init>(java.lang.String)>(v);
throw v;
label:
v = staticinvoke <org.apache.hc.client.http.utils.DnsUtils: java.lang.String normalize(java.lang.String)>(v);
v = staticinvoke <org.apache.hc.client.http.utils.DnsUtils: java.lang.String normalize(java.lang.String)>(v);
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: boolean matchIdentityStrict(java.lang.String,java.lang.String,org.apache.hc.client.http.psl.PublicSuffixMatcher)>(v, v, v);
if v != 0 goto label;
v = new javax.net.ssl.SSLPeerUnverifiedException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(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 common name of the certificate subject: \u0001");
specialinvoke v.<javax.net.ssl.SSLPeerUnverifiedException: void <init>(java.lang.String)>(v);
throw v;
label:
return;
}
static boolean matchDomainRoot(java.lang.String, java.lang.String)
{
char v;
int v, v, v, v, v, v;
java.lang.String v, v;
boolean v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
if v != null goto label;
return 0;
label:
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>(v);
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: int length()>();
if v == v goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: int length()>();
v = v - v;
v = v - 1;
v = virtualinvoke v.<java.lang.String: char charAt(int)>(v);
if v != 46 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private static boolean matchIdentity(java.lang.String, java.lang.String, org.apache.hc.client.http.psl.PublicSuffixMatcher, org.apache.hc.client.http.psl.DomainType, boolean)
{
int v, v, v, v, v, v, v;
java.lang.String v, v, v, v, v, v;
boolean v, v, v, v, v, v, v, v, v, v;
org.apache.hc.client.http.psl.DomainType v;
org.apache.hc.client.http.psl.PublicSuffixMatcher v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: org.apache.hc.client.http.psl.PublicSuffixMatcher;
v := @parameter: org.apache.hc.client.http.psl.DomainType;
v := @parameter: boolean;
if v == null goto label;
v = virtualinvoke v.<java.lang.String: boolean contains(java.lang.CharSequence)>(".");
if v == 0 goto label;
v = virtualinvoke v.<org.apache.hc.client.http.psl.PublicSuffixMatcher: java.lang.String getDomainRoot(java.lang.String,org.apache.hc.client.http.psl.DomainType)>(v, v);
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: boolean matchDomainRoot(java.lang.String,java.lang.String)>(v, v);
if v != 0 goto label;
return 0;
label:
v = virtualinvoke v.<java.lang.String: int indexOf(int)>(42);
v = (int) -1;
if v == v goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(0, v);
v = v + 1;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>(v);
if v != 0 goto label;
return 0;
label:
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>(v);
if v != 0 goto label;
return 0;
label:
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: int length()>();
v = v - v;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(v, v);
v = virtualinvoke v.<java.lang.String: boolean contains(java.lang.CharSequence)>(".");
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
label:
return 1;
label:
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>(v);
return v;
}
static boolean matchIdentity(java.lang.String, java.lang.String, org.apache.hc.client.http.psl.PublicSuffixMatcher)
{
org.apache.hc.client.http.psl.PublicSuffixMatcher v;
java.lang.String v, v;
boolean v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: org.apache.hc.client.http.psl.PublicSuffixMatcher;
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: boolean matchIdentity(java.lang.String,java.lang.String,org.apache.hc.client.http.psl.PublicSuffixMatcher,org.apache.hc.client.http.psl.DomainType,boolean)>(v, v, v, null, 0);
return v;
}
static boolean matchIdentity(java.lang.String, java.lang.String)
{
java.lang.String v, v;
boolean v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: boolean matchIdentity(java.lang.String,java.lang.String,org.apache.hc.client.http.psl.PublicSuffixMatcher,org.apache.hc.client.http.psl.DomainType,boolean)>(v, v, null, null, 0);
return v;
}
static boolean matchIdentityStrict(java.lang.String, java.lang.String, org.apache.hc.client.http.psl.PublicSuffixMatcher)
{
org.apache.hc.client.http.psl.PublicSuffixMatcher v;
java.lang.String v, v;
boolean v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: org.apache.hc.client.http.psl.PublicSuffixMatcher;
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: boolean matchIdentity(java.lang.String,java.lang.String,org.apache.hc.client.http.psl.PublicSuffixMatcher,org.apache.hc.client.http.psl.DomainType,boolean)>(v, v, v, null, 1);
return v;
}
static boolean matchIdentityStrict(java.lang.String, java.lang.String)
{
java.lang.String v, v;
boolean v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: boolean matchIdentity(java.lang.String,java.lang.String,org.apache.hc.client.http.psl.PublicSuffixMatcher,org.apache.hc.client.http.psl.DomainType,boolean)>(v, v, null, null, 1);
return v;
}
static boolean matchIdentity(java.lang.String, java.lang.String, org.apache.hc.client.http.psl.PublicSuffixMatcher, org.apache.hc.client.http.psl.DomainType)
{
org.apache.hc.client.http.psl.DomainType v;
org.apache.hc.client.http.psl.PublicSuffixMatcher v;
java.lang.String v, v;
boolean v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: org.apache.hc.client.http.psl.PublicSuffixMatcher;
v := @parameter: org.apache.hc.client.http.psl.DomainType;
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: boolean matchIdentity(java.lang.String,java.lang.String,org.apache.hc.client.http.psl.PublicSuffixMatcher,org.apache.hc.client.http.psl.DomainType,boolean)>(v, v, v, v, 0);
return v;
}
static boolean matchIdentityStrict(java.lang.String, java.lang.String, org.apache.hc.client.http.psl.PublicSuffixMatcher, org.apache.hc.client.http.psl.DomainType)
{
org.apache.hc.client.http.psl.DomainType v;
org.apache.hc.client.http.psl.PublicSuffixMatcher v;
java.lang.String v, v;
boolean v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: org.apache.hc.client.http.psl.PublicSuffixMatcher;
v := @parameter: org.apache.hc.client.http.psl.DomainType;
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: boolean matchIdentity(java.lang.String,java.lang.String,org.apache.hc.client.http.psl.PublicSuffixMatcher,org.apache.hc.client.http.psl.DomainType,boolean)>(v, v, v, v, 1);
return v;
}
static java.lang.String extractCN(java.lang.String) throws javax.net.ssl.SSLException
{
org.apache.hc.client.http.ssl.DistinguishedNameParser v;
java.util.Iterator v;
java.util.List v;
javax.net.ssl.SSLException v;
java.lang.Object v;
java.lang.String v, v, v, v, v, v;
boolean v, v, v;
v := @parameter: java.lang.String;
if v != null goto label;
return null;
label:
v = <org.apache.hc.client.http.ssl.DistinguishedNameParser: org.apache.hc.client.http.ssl.DistinguishedNameParser INSTANCE>;
v = virtualinvoke v.<org.apache.hc.client.http.ssl.DistinguishedNameParser: java.util.List parse(java.lang.String)>(v);
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 = interfaceinvoke v.<org.apache.hc.core.http.NameValuePair: java.lang.String getName()>();
v = staticinvoke <org.apache.hc.core.util.TextUtils: boolean isBlank(java.lang.CharSequence)>(v);
if v != 0 goto label;
v = interfaceinvoke v.<org.apache.hc.core.http.NameValuePair: java.lang.String getValue()>();
if v != null goto label;
label:
v = new javax.net.ssl.SSLException;
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 is not a valid X500 distinguished name");
specialinvoke v.<javax.net.ssl.SSLException: void <init>(java.lang.String)>(v);
throw v;
label:
v = interfaceinvoke v.<org.apache.hc.core.http.NameValuePair: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>("cn");
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.hc.core.http.NameValuePair: java.lang.String getValue()>();
return v;
label:
return null;
}
static org.apache.hc.client.http.ssl.DefaultHostnameVerifier$HostNameType determineHostFormat(java.lang.String)
{
org.apache.hc.client.http.ssl.DefaultHostnameVerifier$HostNameType v, v, v;
int v, v;
java.lang.String v, v;
boolean v, v, v, v;
v := @parameter: java.lang.String;
v = staticinvoke <org.apache.hc.core.net.InetAddressUtils: boolean isIPv4Address(java.lang.String)>(v);
if v == 0 goto label;
v = <org.apache.hc.client.http.ssl.DefaultHostnameVerifier$HostNameType: org.apache.hc.client.http.ssl.DefaultHostnameVerifier$HostNameType IPv4>;
return v;
label:
v = v;
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("[");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>("]");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
v = v - 1;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(1, v);
label:
v = staticinvoke <org.apache.hc.core.net.InetAddressUtils: boolean isIPv6Address(java.lang.String)>(v);
if v == 0 goto label;
v = <org.apache.hc.client.http.ssl.DefaultHostnameVerifier$HostNameType: org.apache.hc.client.http.ssl.DefaultHostnameVerifier$HostNameType IPv6>;
return v;
label:
v = <org.apache.hc.client.http.ssl.DefaultHostnameVerifier$HostNameType: org.apache.hc.client.http.ssl.DefaultHostnameVerifier$HostNameType DNS>;
return v;
}
static java.util.List getSubjectAltNames(java.security.cert.X509Certificate)
{
int v;
java.security.cert.X509Certificate v;
java.util.List v;
v := @parameter: java.security.cert.X509Certificate;
v = (int) -1;
v = staticinvoke <org.apache.hc.client.http.ssl.DefaultHostnameVerifier: java.util.List getSubjectAltNames(java.security.cert.X509Certificate,int)>(v, v);
return v;
}
static java.util.List getSubjectAltNames(java.security.cert.X509Certificate, int)
{
java.security.cert.X509Certificate v;
java.security.cert.CertificateParsingException v;
java.lang.Integer v;
java.util.ArrayList v;
int v, v, v, v, v;
org.apache.hc.client.http.ssl.SubjectName v;
boolean v, v, v;
java.util.Iterator v;
java.util.Collection v;
java.util.List v, v;
java.lang.Object v, v, v;
v := @parameter: java.security.cert.X509Certificate;
v := @parameter: int;
label:
v = virtualinvoke v.<java.security.cert.X509Certificate: java.util.Collection getSubjectAlternativeNames()>();
if v != null goto label;
v = staticinvoke <java.util.Collections: java.util.List emptyList()>();
label:
return v;
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: int size()>();
if v < 2 goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
goto label;
label:
v = null;
label:
v = v;
if v == null goto label;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
if v == v goto label;
v = (int) -1;
if v != v goto label;
label:
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(1);
v = v instanceof java.lang.String;
if v == 0 goto label;
v = new org.apache.hc.client.http.ssl.SubjectName;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
specialinvoke v.<org.apache.hc.client.http.ssl.SubjectName: void <init>(java.lang.String,int)>(v, v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
goto label;
label:
return v;
label:
v := @caughtexception;
v = staticinvoke <java.util.Collections: java.util.List emptyList()>();
return v;
catch java.security.cert.CertificateParsingException from label to label with label;
catch java.security.cert.CertificateParsingException from label to label with label;
}
static java.lang.String normaliseAddress(java.lang.String)
{
java.net.InetAddress v;
java.lang.String v, v;
java.net.UnknownHostException v;
v := @parameter: java.lang.String;
if v != null goto label;
return v;
label:
v = staticinvoke <java.net.InetAddress: java.net.InetAddress getByName(java.lang.String)>(v);
v = virtualinvoke v.<java.net.InetAddress: java.lang.String getHostAddress()>();
label:
return v;
label:
v := @caughtexception;
return v;
catch java.net.UnknownHostException from label to label with label;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/hc/client5/http/ssl/DefaultHostnameVerifier;");
<org.apache.hc.client.http.ssl.DefaultHostnameVerifier: org.slf4j.Logger LOG> = v;
return;
}
}