public class org.apache.activemq.jaas.TextFileCertificateLoginModule extends org.apache.activemq.jaas.CertificateLoginModule
{
private static final java.lang.String USER_FILE_PROP_NAME;
private static final java.lang.String GROUP_FILE_PROP_NAME;
private java.util.Map groupsByUser;
private java.util.Map regexpByUser;
private java.util.Map usersByDn;
public void <init>()
{
org.apache.activemq.jaas.TextFileCertificateLoginModule v;
v := @this: org.apache.activemq.jaas.TextFileCertificateLoginModule;
specialinvoke v.<org.apache.activemq.jaas.CertificateLoginModule: void <init>()>();
return;
}
public void initialize(javax.security.auth.Subject, javax.security.auth.callback.CallbackHandler, java.util.Map, java.util.Map)
{
org.apache.activemq.jaas.ReloadableProperties v, v, v;
javax.security.auth.Subject v;
javax.security.auth.callback.CallbackHandler v;
java.util.Map v, v, v, v, v;
org.apache.activemq.jaas.TextFileCertificateLoginModule v;
v := @this: org.apache.activemq.jaas.TextFileCertificateLoginModule;
v := @parameter: javax.security.auth.Subject;
v := @parameter: javax.security.auth.callback.CallbackHandler;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
specialinvoke v.<org.apache.activemq.jaas.CertificateLoginModule: void initialize(javax.security.auth.Subject,javax.security.auth.callback.CallbackHandler,java.util.Map,java.util.Map)>(v, v, v, v);
v = virtualinvoke v.<org.apache.activemq.jaas.TextFileCertificateLoginModule: org.apache.activemq.jaas.ReloadableProperties load(java.lang.String,java.lang.String,java.util.Map)>("org.apache.activemq.jaas.textfiledn.user", "", v);
v = virtualinvoke v.<org.apache.activemq.jaas.ReloadableProperties: java.util.Map invertedPropertiesMap()>();
v.<org.apache.activemq.jaas.TextFileCertificateLoginModule: java.util.Map usersByDn> = v;
v = virtualinvoke v.<org.apache.activemq.jaas.TextFileCertificateLoginModule: org.apache.activemq.jaas.ReloadableProperties load(java.lang.String,java.lang.String,java.util.Map)>("org.apache.activemq.jaas.textfiledn.user", "", v);
v = virtualinvoke v.<org.apache.activemq.jaas.ReloadableProperties: java.util.Map regexpPropertiesMap()>();
v.<org.apache.activemq.jaas.TextFileCertificateLoginModule: java.util.Map regexpByUser> = v;
v = virtualinvoke v.<org.apache.activemq.jaas.TextFileCertificateLoginModule: org.apache.activemq.jaas.ReloadableProperties load(java.lang.String,java.lang.String,java.util.Map)>("org.apache.activemq.jaas.textfiledn.group", "", v);
v = virtualinvoke v.<org.apache.activemq.jaas.ReloadableProperties: java.util.Map invertedPropertiesValuesMap()>();
v.<org.apache.activemq.jaas.TextFileCertificateLoginModule: java.util.Map groupsByUser> = v;
return;
}
protected java.lang.String getUserNameForCertificates(java.security.cert.X509Certificate[]) throws javax.security.auth.login.LoginException
{
javax.security.auth.login.LoginException v;
java.util.Map v, v;
java.lang.Object v;
java.lang.String v;
java.security.cert.X509Certificate[] v;
org.apache.activemq.jaas.TextFileCertificateLoginModule v;
boolean v;
v := @this: org.apache.activemq.jaas.TextFileCertificateLoginModule;
v := @parameter: java.security.cert.X509Certificate[];
if v != null goto label;
v = new javax.security.auth.login.LoginException;
specialinvoke v.<javax.security.auth.login.LoginException: void <init>(java.lang.String)>("Client certificates not found. Cannot authenticate.");
throw v;
label:
v = virtualinvoke v.<org.apache.activemq.jaas.TextFileCertificateLoginModule: java.lang.String getDistinguishedName(java.security.cert.X509Certificate[])>(v);
v = v.<org.apache.activemq.jaas.TextFileCertificateLoginModule: java.util.Map usersByDn>;
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v == 0 goto label;
v = v.<org.apache.activemq.jaas.TextFileCertificateLoginModule: java.util.Map usersByDn>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
goto label;
label:
v = specialinvoke v.<org.apache.activemq.jaas.TextFileCertificateLoginModule: java.lang.String getUserByRegexp(java.lang.String)>(v);
label:
return v;
}
protected java.util.Set getUserGroups(java.lang.String) throws javax.security.auth.login.LoginException
{
java.util.Map v;
java.lang.Object v;
java.lang.String v;
org.apache.activemq.jaas.TextFileCertificateLoginModule v;
v := @this: org.apache.activemq.jaas.TextFileCertificateLoginModule;
v := @parameter: java.lang.String;
v = v.<org.apache.activemq.jaas.TextFileCertificateLoginModule: java.util.Map groupsByUser>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = staticinvoke <java.util.Collections: java.util.Set emptySet()>();
label:
return v;
}
private synchronized java.lang.String getUserByRegexp(java.lang.String)
{
java.util.Iterator v;
java.util.Set v;
java.util.regex.Matcher v;
java.util.Map v, v;
java.lang.Object v, v, v;
java.lang.String v;
org.apache.activemq.jaas.TextFileCertificateLoginModule v;
boolean v, v;
v := @this: org.apache.activemq.jaas.TextFileCertificateLoginModule;
v := @parameter: java.lang.String;
v = v.<org.apache.activemq.jaas.TextFileCertificateLoginModule: java.util.Map regexpByUser>;
v = interfaceinvoke v.<java.util.Map: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: 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.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<java.util.regex.Pattern: java.util.regex.Matcher matcher(java.lang.CharSequence)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: boolean matches()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
label:
v = v.<org.apache.activemq.jaas.TextFileCertificateLoginModule: java.util.Map usersByDn>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
return v;
}
}