public class org.apache.nifi.processors.standard.http.HandleHttpRequestCertificateAttributesProvider extends java.lang.Object implements org.apache.nifi.processors.standard.http.CertificateAttributesProvider
{
protected static final java.lang.String REQUEST_CERTIFICATES_ATTRIBUTE_NAME;
private static final java.lang.String SAN_NAME_TYPE_FORMAT;
private static final java.lang.String SAN_NAME_FORMAT;
private final org.apache.nifi.security.cert.CertificateAttributeReader certificateAttributeReader;
public void <init>()
{
org.apache.nifi.processors.standard.http.HandleHttpRequestCertificateAttributesProvider v;
org.apache.nifi.security.cert.StandardCertificateAttributeReader v;
v := @this: org.apache.nifi.processors.standard.http.HandleHttpRequestCertificateAttributesProvider;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new org.apache.nifi.security.cert.StandardCertificateAttributeReader;
specialinvoke v.<org.apache.nifi.security.cert.StandardCertificateAttributeReader: void <init>()>();
v.<org.apache.nifi.processors.standard.http.HandleHttpRequestCertificateAttributesProvider: org.apache.nifi.security.cert.CertificateAttributeReader certificateAttributeReader> = v;
return;
}
public java.util.Map getCertificateAttributes(javax.servlet.http.HttpServletRequest)
{
java.security.cert.X509Certificate v;
org.apache.nifi.processors.standard.http.HandleHttpRequestCertificateAttributesProvider v;
javax.servlet.http.HttpServletRequest v;
java.util.Map v;
int v;
java.lang.Object v;
boolean v;
v := @this: org.apache.nifi.processors.standard.http.HandleHttpRequestCertificateAttributesProvider;
v := @parameter: javax.servlet.http.HttpServletRequest;
staticinvoke <java.util.Objects: java.lang.Object requireNonNull(java.lang.Object,java.lang.String)>(v, "HTTP Servlet Request required");
v = interfaceinvoke v.<javax.servlet.http.HttpServletRequest: java.lang.Object getAttribute(java.lang.String)>("javax.servlet.request.X509Certificate");
v = v instanceof java.security.cert.X509Certificate[];
if v == 0 goto label;
v = lengthof v;
if v != 0 goto label;
v = staticinvoke <java.util.Collections: java.util.Map emptyMap()>();
goto label;
label:
v = v[0];
v = specialinvoke v.<org.apache.nifi.processors.standard.http.HandleHttpRequestCertificateAttributesProvider: java.util.Map getCertificateAttributes(java.security.cert.X509Certificate)>(v);
goto label;
label:
v = staticinvoke <java.util.Collections: java.util.Map emptyMap()>();
label:
return v;
}
private java.util.Map getCertificateAttributes(java.security.cert.X509Certificate)
{
java.security.cert.X509Certificate v;
javax.security.auth.x.X500Principal v, v;
java.util.LinkedHashMap v;
org.apache.nifi.processors.standard.http.HandleHttpRequestCertificateAttributesProvider v;
org.apache.nifi.processors.standard.http.CertificateAttribute v, v;
java.util.Map v;
java.lang.String v, v, v, v;
v := @this: org.apache.nifi.processors.standard.http.HandleHttpRequestCertificateAttributesProvider;
v := @parameter: java.security.cert.X509Certificate;
v = new java.util.LinkedHashMap;
specialinvoke v.<java.util.LinkedHashMap: void <init>()>();
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()>();
v = virtualinvoke v.<java.security.cert.X509Certificate: javax.security.auth.x.X500Principal getIssuerX500Principal()>();
v = virtualinvoke v.<javax.security.auth.x.X500Principal: java.lang.String getName()>();
v = <org.apache.nifi.processors.standard.http.CertificateAttribute: org.apache.nifi.processors.standard.http.CertificateAttribute HTTP_SUBJECT_DN>;
v = virtualinvoke v.<org.apache.nifi.processors.standard.http.CertificateAttribute: java.lang.String getName()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = <org.apache.nifi.processors.standard.http.CertificateAttribute: org.apache.nifi.processors.standard.http.CertificateAttribute HTTP_ISSUER_DN>;
v = virtualinvoke v.<org.apache.nifi.processors.standard.http.CertificateAttribute: java.lang.String getName()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = specialinvoke v.<org.apache.nifi.processors.standard.http.HandleHttpRequestCertificateAttributesProvider: java.util.Map getSubjectAlternativeNameAttributes(java.security.cert.X509Certificate)>(v);
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
return v;
}
private java.util.Map getSubjectAlternativeNameAttributes(java.security.cert.X509Certificate)
{
java.security.cert.X509Certificate v;
java.lang.Object[] v, v;
org.apache.nifi.security.cert.CertificateAttributeReader v;
java.lang.Integer v, v;
java.util.LinkedHashMap v;
int v;
java.lang.String v, v, v, v, v, v;
boolean v;
java.util.Iterator v;
org.apache.nifi.processors.standard.http.HandleHttpRequestCertificateAttributesProvider v;
java.util.List v;
org.apache.nifi.processors.standard.http.CertificateAttribute v, v;
java.lang.Object v;
org.apache.nifi.security.cert.GeneralNameType v;
v := @this: org.apache.nifi.processors.standard.http.HandleHttpRequestCertificateAttributesProvider;
v := @parameter: java.security.cert.X509Certificate;
v = new java.util.LinkedHashMap;
specialinvoke v.<java.util.LinkedHashMap: void <init>()>();
v = 0;
v = v.<org.apache.nifi.processors.standard.http.HandleHttpRequestCertificateAttributesProvider: org.apache.nifi.security.cert.CertificateAttributeReader certificateAttributeReader>;
v = interfaceinvoke v.<org.apache.nifi.security.cert.CertificateAttributeReader: java.util.List getSubjectAlternativeNames(java.security.cert.X509Certificate)>(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 = newarray (java.lang.Object)[2];
v = <org.apache.nifi.processors.standard.http.CertificateAttribute: org.apache.nifi.processors.standard.http.CertificateAttribute HTTP_CERTIFICATE_SANS>;
v = virtualinvoke v.<org.apache.nifi.processors.standard.http.CertificateAttribute: java.lang.String getName()>();
v[0] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("%s.%d.nameType", v);
v = interfaceinvoke v.<org.apache.nifi.security.cert.SubjectAlternativeName: org.apache.nifi.security.cert.GeneralNameType getGeneralNameType()>();
v = virtualinvoke v.<org.apache.nifi.security.cert.GeneralNameType: java.lang.String getGeneralName()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = newarray (java.lang.Object)[2];
v = <org.apache.nifi.processors.standard.http.CertificateAttribute: org.apache.nifi.processors.standard.http.CertificateAttribute HTTP_CERTIFICATE_SANS>;
v = virtualinvoke v.<org.apache.nifi.processors.standard.http.CertificateAttribute: java.lang.String getName()>();
v[0] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("%s.%d.name", v);
v = interfaceinvoke v.<org.apache.nifi.security.cert.SubjectAlternativeName: java.lang.String getName()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v + 1;
goto label;
label:
return v;
}
}