public class org.apache.activemq.jaas.LDAPLoginModule extends java.lang.Object implements javax.security.auth.spi.LoginModule
{
private static final java.lang.String INITIAL_CONTEXT_FACTORY;
private static final java.lang.String CONNECTION_URL;
private static final java.lang.String CONNECTION_USERNAME;
private static final java.lang.String CONNECTION_PASSWORD;
private static final java.lang.String CONNECTION_PROTOCOL;
private static final java.lang.String AUTHENTICATION;
private static final java.lang.String USER_BASE;
private static final java.lang.String USER_SEARCH_MATCHING;
private static final java.lang.String USER_SEARCH_SUBTREE;
private static final java.lang.String ROLE_BASE;
private static final java.lang.String ROLE_NAME;
private static final java.lang.String ROLE_SEARCH_MATCHING;
private static final java.lang.String ROLE_SEARCH_SUBTREE;
private static final java.lang.String USER_ROLE_NAME;
private static final java.lang.String EXPAND_ROLES;
private static final java.lang.String EXPAND_ROLES_MATCHING;
private static org.slf4j.Logger log;
protected javax.naming.directory.DirContext context;
private javax.security.auth.Subject subject;
private javax.security.auth.callback.CallbackHandler handler;
private org.apache.activemq.jaas.LDAPLoginProperty[] config;
private java.security.Principal user;
private java.util.Set groups;
private boolean succeeded;
private boolean commitSucceeded;
public void <init>()
{
java.util.HashSet v;
org.apache.activemq.jaas.LDAPLoginModule v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
v.<org.apache.activemq.jaas.LDAPLoginModule: java.util.Set groups> = v;
v.<org.apache.activemq.jaas.LDAPLoginModule: boolean succeeded> = 0;
v.<org.apache.activemq.jaas.LDAPLoginModule: boolean commitSucceeded> = 0;
return;
}
public void initialize(javax.security.auth.Subject, javax.security.auth.callback.CallbackHandler, java.util.Map, java.util.Map)
{
javax.security.auth.callback.CallbackHandler v;
org.apache.activemq.jaas.LDAPLoginProperty[] v;
java.util.Map v, v;
org.apache.activemq.jaas.LDAPLoginModule v;
org.apache.activemq.jaas.LDAPLoginProperty v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
javax.security.auth.Subject v;
java.lang.Object v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v := @parameter: javax.security.auth.Subject;
v := @parameter: javax.security.auth.callback.CallbackHandler;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v.<org.apache.activemq.jaas.LDAPLoginModule: javax.security.auth.Subject subject> = v;
v.<org.apache.activemq.jaas.LDAPLoginModule: javax.security.auth.callback.CallbackHandler handler> = v;
v = newarray (org.apache.activemq.jaas.LDAPLoginProperty)[16];
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("initialContextFactory");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("initialContextFactory", v);
v[0] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("connectionURL");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("connectionURL", v);
v[1] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("connectionUsername");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("connectionUsername", v);
v[2] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("connectionPassword");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("connectionPassword", v);
v[3] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("connectionProtocol");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("connectionProtocol", v);
v[4] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("authentication");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("authentication", v);
v[5] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("userBase");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("userBase", v);
v[6] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("userSearchMatching");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("userSearchMatching", v);
v[7] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("userSearchSubtree");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("userSearchSubtree", v);
v[8] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("roleBase");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("roleBase", v);
v[9] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("roleName");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("roleName", v);
v[10] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("roleSearchMatching");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("roleSearchMatching", v);
v[11] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("roleSearchSubtree");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("roleSearchSubtree", v);
v[12] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("userRoleName");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("userRoleName", v);
v[13] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("expandRoles");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("expandRoles", v);
v[14] = v;
v = new org.apache.activemq.jaas.LDAPLoginProperty;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("expandRolesMatching");
specialinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: void <init>(java.lang.String,java.lang.String)>("expandRolesMatching", v);
v[15] = v;
v.<org.apache.activemq.jaas.LDAPLoginModule: org.apache.activemq.jaas.LDAPLoginProperty[] config> = v;
return;
}
public boolean login() throws javax.security.auth.login.LoginException
{
java.lang.Throwable v;
javax.security.auth.login.LoginException v;
org.apache.activemq.jaas.LDAPLoginModule v;
javax.security.auth.callback.Callback[] v;
javax.security.auth.callback.CallbackHandler v;
java.lang.String v, v, v;
javax.security.auth.callback.PasswordCallback v;
java.lang.Exception v;
org.apache.activemq.jaas.UserPrincipal v;
javax.security.auth.callback.NameCallback v;
char[] v, v;
javax.security.auth.callback.Callback v, v, v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v = newarray (javax.security.auth.callback.Callback)[2];
v = new javax.security.auth.callback.NameCallback;
specialinvoke v.<javax.security.auth.callback.NameCallback: void <init>(java.lang.String)>("User name");
v[0] = v;
v = new javax.security.auth.callback.PasswordCallback;
specialinvoke v.<javax.security.auth.callback.PasswordCallback: void <init>(java.lang.String,boolean)>("Password", 0);
v[1] = v;
label:
v = v.<org.apache.activemq.jaas.LDAPLoginModule: javax.security.auth.callback.CallbackHandler handler>;
interfaceinvoke v.<javax.security.auth.callback.CallbackHandler: void handle(javax.security.auth.callback.Callback[])>(v);
label:
goto label;
label:
v := @caughtexception;
v = new javax.security.auth.login.LoginException;
specialinvoke v.<javax.security.auth.login.LoginException: void <init>()>();
v = virtualinvoke v.<javax.security.auth.login.LoginException: java.lang.Throwable initCause(java.lang.Throwable)>(v);
throw v;
label:
v = v[0];
v = virtualinvoke v.<javax.security.auth.callback.NameCallback: java.lang.String getName()>();
if v != null goto label;
return 0;
label:
v = v[1];
v = virtualinvoke v.<javax.security.auth.callback.PasswordCallback: char[] getPassword()>();
if v == null goto label;
v = new java.lang.String;
v = v[1];
v = virtualinvoke v.<javax.security.auth.callback.PasswordCallback: char[] getPassword()>();
specialinvoke v.<java.lang.String: void <init>(char[])>(v);
v = v;
goto label;
label:
v = "";
label:
virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: boolean authenticate(java.lang.String,java.lang.String)>(v, v);
v = new org.apache.activemq.jaas.UserPrincipal;
specialinvoke v.<org.apache.activemq.jaas.UserPrincipal: void <init>(java.lang.String)>(v);
v.<org.apache.activemq.jaas.LDAPLoginModule: java.security.Principal user> = v;
v.<org.apache.activemq.jaas.LDAPLoginModule: boolean succeeded> = 1;
return 1;
catch java.io.IOException from label to label with label;
catch javax.security.auth.callback.UnsupportedCallbackException from label to label with label;
}
public boolean logout() throws javax.security.auth.login.LoginException
{
org.apache.activemq.jaas.LDAPLoginModule v;
java.util.Set v, v, v, v;
javax.security.auth.Subject v, v;
java.security.Principal v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v = v.<org.apache.activemq.jaas.LDAPLoginModule: javax.security.auth.Subject subject>;
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPrincipals()>();
v = v.<org.apache.activemq.jaas.LDAPLoginModule: java.security.Principal user>;
interfaceinvoke v.<java.util.Set: boolean remove(java.lang.Object)>(v);
v = v.<org.apache.activemq.jaas.LDAPLoginModule: javax.security.auth.Subject subject>;
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPrincipals()>();
v = v.<org.apache.activemq.jaas.LDAPLoginModule: java.util.Set groups>;
interfaceinvoke v.<java.util.Set: boolean removeAll(java.util.Collection)>(v);
v.<org.apache.activemq.jaas.LDAPLoginModule: java.security.Principal user> = null;
v = v.<org.apache.activemq.jaas.LDAPLoginModule: java.util.Set groups>;
interfaceinvoke v.<java.util.Set: void clear()>();
v.<org.apache.activemq.jaas.LDAPLoginModule: boolean succeeded> = 0;
v.<org.apache.activemq.jaas.LDAPLoginModule: boolean commitSucceeded> = 0;
return 1;
}
public boolean commit() throws javax.security.auth.login.LoginException
{
java.security.Principal v;
org.apache.activemq.jaas.LDAPLoginModule v;
java.util.Set v, v, v;
javax.security.auth.Subject v;
boolean v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v = v.<org.apache.activemq.jaas.LDAPLoginModule: boolean succeeded>;
if v != 0 goto label;
v.<org.apache.activemq.jaas.LDAPLoginModule: java.security.Principal user> = null;
v = v.<org.apache.activemq.jaas.LDAPLoginModule: java.util.Set groups>;
interfaceinvoke v.<java.util.Set: void clear()>();
return 0;
label:
v = v.<org.apache.activemq.jaas.LDAPLoginModule: javax.security.auth.Subject subject>;
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPrincipals()>();
v = v.<org.apache.activemq.jaas.LDAPLoginModule: java.security.Principal user>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = v.<org.apache.activemq.jaas.LDAPLoginModule: java.util.Set groups>;
interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
v.<org.apache.activemq.jaas.LDAPLoginModule: boolean commitSucceeded> = 1;
return 1;
}
public boolean abort() throws javax.security.auth.login.LoginException
{
org.apache.activemq.jaas.LDAPLoginModule v;
java.util.Set v;
boolean v, v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v = v.<org.apache.activemq.jaas.LDAPLoginModule: boolean succeeded>;
if v != 0 goto label;
return 0;
label:
v = v.<org.apache.activemq.jaas.LDAPLoginModule: boolean commitSucceeded>;
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: boolean logout()>();
goto label;
label:
v.<org.apache.activemq.jaas.LDAPLoginModule: java.security.Principal user> = null;
v = v.<org.apache.activemq.jaas.LDAPLoginModule: java.util.Set groups>;
interfaceinvoke v.<java.util.Set: void clear()>();
v.<org.apache.activemq.jaas.LDAPLoginModule: boolean succeeded> = 0;
label:
return 1;
}
protected void closeContext()
{
java.lang.Throwable v;
org.apache.activemq.jaas.LDAPLoginModule v;
org.slf4j.Logger v;
javax.naming.directory.DirContext v, v;
java.lang.String v;
java.lang.Exception v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v = v.<org.apache.activemq.jaas.LDAPLoginModule: javax.naming.directory.DirContext context>;
if v != null goto label;
return;
label:
v = v.<org.apache.activemq.jaas.LDAPLoginModule: javax.naming.directory.DirContext context>;
interfaceinvoke v.<javax.naming.directory.DirContext: void close()>();
label:
v.<org.apache.activemq.jaas.LDAPLoginModule: javax.naming.directory.DirContext context> = null;
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String toString()>();
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>(v);
label:
v.<org.apache.activemq.jaas.LDAPLoginModule: javax.naming.directory.DirContext context> = null;
goto label;
label:
v := @caughtexception;
v.<org.apache.activemq.jaas.LDAPLoginModule: javax.naming.directory.DirContext context> = null;
throw v;
label:
return;
catch java.lang.Exception from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
protected boolean authenticate(java.lang.String, java.lang.String) throws javax.security.auth.login.LoginException
{
org.apache.activemq.jaas.GroupPrincipal v;
java.util.Set v;
javax.naming.directory.Attributes v;
java.lang.Throwable v;
org.apache.activemq.jaas.LDAPLoginModule v;
java.util.ArrayList v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
javax.naming.directory.DirContext v, v, v, v, v;
java.net.URISyntaxException v;
javax.naming.NamingException v, v;
javax.security.auth.login.FailedLoginException v, v, v, v, v, v, v;
java.net.URI v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v;
java.util.List v, v;
javax.naming.NamingEnumeration v;
java.lang.String[] v, v;
javax.naming.NameParser v;
javax.naming.directory.SearchControls v;
java.text.MessageFormat v;
int v, v, v;
java.lang.Boolean v;
org.slf4j.Logger v, v, v, v, v, v, v, v, v, v, v, v, v, v;
javax.naming.Name v, v, v, v, v;
java.lang.Object v, v;
javax.naming.CommunicationException v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Create the LDAP initial context.");
label:
virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: void openContext()>();
label:
goto label;
label:
v := @caughtexception;
v = new javax.security.auth.login.FailedLoginException;
specialinvoke v.<javax.security.auth.login.FailedLoginException: void <init>(java.lang.String)>("Error opening LDAP connection");
virtualinvoke v.<javax.security.auth.login.FailedLoginException: java.lang.Throwable initCause(java.lang.Throwable)>(v);
throw v;
label:
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: boolean isLoginPropertySet(java.lang.String)>("userSearchMatching");
if v != 0 goto label;
return 0;
label:
v = new java.text.MessageFormat;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("userSearchMatching");
specialinvoke v.<java.text.MessageFormat: void <init>(java.lang.String)>(v);
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("userSearchSubtree");
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
label:
v = newarray (java.lang.String)[1];
v = virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String doRFC2254Encoding(java.lang.String)>(v);
v[0] = v;
v = virtualinvoke v.<java.text.MessageFormat: java.lang.String format(java.lang.Object)>(v);
v = new javax.naming.directory.SearchControls;
specialinvoke v.<javax.naming.directory.SearchControls: void <init>()>();
if v == 0 goto label;
virtualinvoke v.<javax.naming.directory.SearchControls: void setSearchScope(int)>(2);
goto label;
label:
virtualinvoke v.<javax.naming.directory.SearchControls: void setSearchScope(int)>(1);
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: boolean isLoginPropertySet(java.lang.String)>("userRoleName");
if v == 0 goto label;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("userRoleName");
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (java.lang.String)[v];
interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
virtualinvoke v.<javax.naming.directory.SearchControls: void setReturningAttributes(java.lang.String[])>(v);
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Get the user DN.");
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Looking for the user in LDAP with ");
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("userBase");
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[])>("  base DN: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
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[])>("  filter: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
v = v.<org.apache.activemq.jaas.LDAPLoginModule: javax.naming.directory.DirContext context>;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("userBase");
v = interfaceinvoke v.<javax.naming.directory.DirContext: javax.naming.NamingEnumeration search(java.lang.String,java.lang.String,javax.naming.directory.SearchControls)>(v, v, v);
if v == null goto label;
v = interfaceinvoke v.<javax.naming.NamingEnumeration: boolean hasMore()>();
if v != 0 goto label;
label:
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
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[])>("User \u not found in LDAP.");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
v = new javax.security.auth.login.FailedLoginException;
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[])>("User \u not found in LDAP.");
specialinvoke v.<javax.security.auth.login.FailedLoginException: void <init>(java.lang.String)>(v);
throw v;
label:
v = interfaceinvoke v.<javax.naming.NamingEnumeration: java.lang.Object next()>();
interfaceinvoke v.<javax.naming.NamingEnumeration: boolean hasMore()>();
v = virtualinvoke v.<javax.naming.directory.SearchResult: boolean isRelative()>();
if v == 0 goto label;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = virtualinvoke v.<javax.naming.directory.SearchResult: java.lang.String getName()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("LDAP returned a relative name: {}", v);
v = v.<org.apache.activemq.jaas.LDAPLoginModule: javax.naming.directory.DirContext context>;
v = interfaceinvoke v.<javax.naming.directory.DirContext: javax.naming.NameParser getNameParser(java.lang.String)>("");
v = v.<org.apache.activemq.jaas.LDAPLoginModule: javax.naming.directory.DirContext context>;
v = interfaceinvoke v.<javax.naming.directory.DirContext: java.lang.String getNameInNamespace()>();
v = interfaceinvoke v.<javax.naming.NameParser: javax.naming.Name parse(java.lang.String)>(v);
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("userBase");
v = interfaceinvoke v.<javax.naming.NameParser: javax.naming.Name parse(java.lang.String)>(v);
v = virtualinvoke v.<javax.naming.directory.SearchResult: java.lang.String getName()>();
v = interfaceinvoke v.<javax.naming.NameParser: javax.naming.Name parse(java.lang.String)>(v);
v = interfaceinvoke v.<javax.naming.Name: javax.naming.Name addAll(javax.naming.Name)>(v);
v = interfaceinvoke v.<javax.naming.Name: javax.naming.Name addAll(javax.naming.Name)>(v);
v = virtualinvoke v.<java.lang.Object: java.lang.String toString()>();
goto label;
label:
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = virtualinvoke v.<javax.naming.directory.SearchResult: java.lang.String getName()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("LDAP returned an absolute name: {}", v);
label:
v = new java.net.URI;
v = virtualinvoke v.<javax.naming.directory.SearchResult: java.lang.String getName()>();
specialinvoke v.<java.net.URI: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<java.net.URI: java.lang.String getPath()>();
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("/");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(1);
goto label;
label:
v = v;
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: void closeContext()>();
v = new javax.security.auth.login.FailedLoginException;
specialinvoke v.<javax.security.auth.login.FailedLoginException: void <init>(java.lang.String)>("Error parsing absolute name as URI.");
virtualinvoke v.<javax.security.auth.login.FailedLoginException: java.lang.Throwable initCause(java.lang.Throwable)>(v);
throw v;
label:
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
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[])>("Using DN [\u] for binding.");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
v = virtualinvoke v.<javax.naming.directory.SearchResult: javax.naming.directory.Attributes getAttributes()>();
if v != null goto label;
v = new javax.security.auth.login.FailedLoginException;
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[])>("User found, but LDAP entry malformed: \u0001");
specialinvoke v.<javax.security.auth.login.FailedLoginException: void <init>(java.lang.String)>(v);
throw v;
label:
v = null;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: boolean isLoginPropertySet(java.lang.String)>("userRoleName");
if v == 0 goto label;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("userRoleName");
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.util.List addAttributeValues(java.lang.String,javax.naming.directory.Attributes,java.util.List)>(v, v, null);
label:
v = v.<org.apache.activemq.jaas.LDAPLoginModule: javax.naming.directory.DirContext context>;
v = virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: boolean bindUser(javax.naming.directory.DirContext,java.lang.String,java.lang.String)>(v, v, v);
if v == 0 goto label;
v = v.<org.apache.activemq.jaas.LDAPLoginModule: javax.naming.directory.DirContext context>;
v = virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.util.List getRoles(javax.naming.directory.DirContext,java.lang.String,java.lang.String,java.util.List)>(v, v, v, v);
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.List,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[])>("Roles \u for user \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
v = 0;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= v goto label;
v = v.<org.apache.activemq.jaas.LDAPLoginModule: java.util.Set groups>;
v = new org.apache.activemq.jaas.GroupPrincipal;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
specialinvoke v.<org.apache.activemq.jaas.GroupPrincipal: void <init>(java.lang.String)>(v);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = new javax.security.auth.login.FailedLoginException;
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[])>("Password does not match for user: \u0001");
specialinvoke v.<javax.security.auth.login.FailedLoginException: void <init>(java.lang.String)>(v);
throw v;
label:
virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: void closeContext()>();
goto label;
label:
v := @caughtexception;
v = new javax.security.auth.login.FailedLoginException;
specialinvoke v.<javax.security.auth.login.FailedLoginException: void <init>(java.lang.String)>("Error contacting LDAP");
virtualinvoke v.<javax.security.auth.login.FailedLoginException: java.lang.Throwable initCause(java.lang.Throwable)>(v);
throw v;
label:
v := @caughtexception;
v = new javax.security.auth.login.FailedLoginException;
specialinvoke v.<javax.security.auth.login.FailedLoginException: void <init>(java.lang.String)>("Error contacting LDAP");
virtualinvoke v.<javax.security.auth.login.FailedLoginException: java.lang.Throwable initCause(java.lang.Throwable)>(v);
throw v;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: void closeContext()>();
throw v;
label:
return 1;
catch javax.naming.NamingException from label to label with label;
catch java.net.URISyntaxException from label to label with label;
catch javax.naming.CommunicationException from label to label with label;
catch javax.naming.NamingException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
protected java.util.List getRoles(javax.naming.directory.DirContext, java.lang.String, java.lang.String, java.util.List) throws javax.naming.NamingException
{
boolean v, v, v, v, v, v, v, v;
java.util.List v, v;
javax.naming.directory.Attributes v, v;
javax.naming.NamingEnumeration v, v;
org.apache.activemq.jaas.LDAPLoginModule v;
java.lang.String[] v, v;
javax.naming.directory.SearchControls v;
java.text.MessageFormat v, v;
java.util.ArrayList v;
java.util.HashSet v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.util.LinkedList v;
org.slf4j.Logger v, v, v, v, v;
javax.naming.directory.DirContext v;
java.lang.Object v, v, v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v := @parameter: javax.naming.directory.DirContext;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.util.List;
v = v;
v = new java.text.MessageFormat;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("roleSearchMatching");
specialinvoke v.<java.text.MessageFormat: void <init>(java.lang.String)>(v);
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("roleSearchSubtree");
v = staticinvoke <java.lang.Boolean: boolean parseBoolean(java.lang.String)>(v);
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("expandRoles");
v = staticinvoke <java.lang.Boolean: boolean parseBoolean(java.lang.String)>(v);
if v != null goto label;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = v;
label:
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: boolean isLoginPropertySet(java.lang.String)>("roleName");
if v != 0 goto label;
return v;
label:
v = newarray (java.lang.String)[2];
v = virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String doRFC2254Encoding(java.lang.String)>(v);
v[0] = v;
v = virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String doRFC2254Encoding(java.lang.String)>(v);
v[1] = v;
v = virtualinvoke v.<java.text.MessageFormat: java.lang.String format(java.lang.Object)>(v);
v = new javax.naming.directory.SearchControls;
specialinvoke v.<javax.naming.directory.SearchControls: void <init>()>();
if v == 0 goto label;
virtualinvoke v.<javax.naming.directory.SearchControls: void setSearchScope(int)>(2);
goto label;
label:
virtualinvoke v.<javax.naming.directory.SearchControls: void setSearchScope(int)>(1);
label:
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Get user roles.");
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Looking for the user roles in LDAP with ");
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("roleBase");
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[])>("  base DN: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
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[])>("  filter: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
v = new java.util.LinkedList;
specialinvoke v.<java.util.LinkedList: void <init>()>();
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("roleBase");
v = interfaceinvoke v.<javax.naming.directory.DirContext: javax.naming.NamingEnumeration search(java.lang.String,java.lang.String,javax.naming.directory.SearchControls)>(v, v, v);
label:
v = interfaceinvoke v.<javax.naming.NamingEnumeration: boolean hasMore()>();
if v == 0 goto label;
v = interfaceinvoke v.<javax.naming.NamingEnumeration: java.lang.Object next()>();
v = virtualinvoke v.<javax.naming.directory.SearchResult: javax.naming.directory.Attributes getAttributes()>();
if v == 0 goto label;
v = virtualinvoke v.<javax.naming.directory.SearchResult: java.lang.String getNameInNamespace()>();
virtualinvoke v.<java.util.HashSet: boolean add(java.lang.Object)>(v);
v = virtualinvoke v.<javax.naming.directory.SearchResult: java.lang.String getNameInNamespace()>();
interfaceinvoke v.<java.util.Queue: boolean add(java.lang.Object)>(v);
label:
if v == null goto label;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("roleName");
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.util.List addAttributeValues(java.lang.String,javax.naming.directory.Attributes,java.util.List)>(v, v, v);
goto label;
label:
if v == 0 goto label;
v = new java.text.MessageFormat;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("expandRolesMatching");
specialinvoke v.<java.text.MessageFormat: void <init>(java.lang.String)>(v);
label:
v = interfaceinvoke v.<java.util.Queue: boolean isEmpty()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.Queue: java.lang.Object remove()>();
v = newarray (java.lang.String)[1];
v[0] = v;
v = virtualinvoke v.<java.text.MessageFormat: java.lang.String format(java.lang.Object)>(v);
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("roleBase");
v = interfaceinvoke v.<javax.naming.directory.DirContext: javax.naming.NamingEnumeration search(java.lang.String,java.lang.String,javax.naming.directory.SearchControls)>(v, v, v);
label:
v = interfaceinvoke v.<javax.naming.NamingEnumeration: boolean hasMore()>();
if v == 0 goto label;
v = interfaceinvoke v.<javax.naming.NamingEnumeration: java.lang.Object next()>();
v = virtualinvoke v.<javax.naming.directory.SearchResult: java.lang.String getNameInNamespace()>();
v = virtualinvoke v.<java.util.HashSet: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
v = virtualinvoke v.<javax.naming.directory.SearchResult: javax.naming.directory.Attributes getAttributes()>();
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("roleName");
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.util.List addAttributeValues(java.lang.String,javax.naming.directory.Attributes,java.util.List)>(v, v, v);
virtualinvoke v.<java.util.HashSet: boolean add(java.lang.Object)>(v);
interfaceinvoke v.<java.util.Queue: boolean add(java.lang.Object)>(v);
goto label;
label:
return v;
}
protected java.lang.String doRFC2254Encoding(java.lang.String)
{
org.apache.activemq.jaas.LDAPLoginModule v;
char v;
java.lang.StringBuffer v;
int v, v, v;
java.lang.String v, v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v := @parameter: java.lang.String;
v = new java.lang.StringBuffer;
v = virtualinvoke v.<java.lang.String: int length()>();
specialinvoke v.<java.lang.StringBuffer: void <init>(int)>(v);
v = 0;
label:
v = virtualinvoke v.<java.lang.String: int length()>();
if v >= v goto label;
v = virtualinvoke v.<java.lang.String: char charAt(int)>(v);
lookupswitch(v)
{
case 0: goto label;
case 40: goto label;
case 41: goto label;
case 42: goto label;
case 92: goto label;
default: goto label;
};
label:
virtualinvoke v.<java.lang.StringBuffer: java.lang.StringBuffer append(java.lang.String)>("\\5c");
goto label;
label:
virtualinvoke v.<java.lang.StringBuffer: java.lang.StringBuffer append(java.lang.String)>("\\2a");
goto label;
label:
virtualinvoke v.<java.lang.StringBuffer: java.lang.StringBuffer append(java.lang.String)>("\\28");
goto label;
label:
virtualinvoke v.<java.lang.StringBuffer: java.lang.StringBuffer append(java.lang.String)>("\\29");
goto label;
label:
virtualinvoke v.<java.lang.StringBuffer: java.lang.StringBuffer append(java.lang.String)>("\\00");
goto label;
label:
virtualinvoke v.<java.lang.StringBuffer: java.lang.StringBuffer append(char)>(v);
label:
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.lang.StringBuffer: java.lang.String toString()>();
return v;
}
protected boolean bindUser(javax.naming.directory.DirContext, java.lang.String, java.lang.String) throws javax.naming.NamingException
{
org.apache.activemq.jaas.LDAPLoginModule v;
javax.naming.AuthenticationException v;
java.lang.String v, v, v, v, v, v, v;
boolean v, v, v, v, v, v;
org.slf4j.Logger v, v, v, v, v, v;
javax.naming.directory.DirContext v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v := @parameter: javax.naming.directory.DirContext;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = 0;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Binding the user.");
label:
interfaceinvoke v.<javax.naming.directory.DirContext: java.lang.Object addToEnvironment(java.lang.String,java.lang.Object)>("java.naming.security.authentication", "simple");
interfaceinvoke v.<javax.naming.directory.DirContext: java.lang.Object addToEnvironment(java.lang.String,java.lang.Object)>("java.naming.security.principal", v);
interfaceinvoke v.<javax.naming.directory.DirContext: java.lang.Object addToEnvironment(java.lang.String,java.lang.Object)>("java.naming.security.credentials", v);
label:
interfaceinvoke v.<javax.naming.directory.DirContext: javax.naming.directory.Attributes getAttributes(java.lang.String,java.lang.String[])>("", null);
v = 1;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
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[])>("User \u successfully bound.");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
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[])>("Authentication failed for dn=\u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: boolean isLoginPropertySet(java.lang.String)>("connectionUsername");
if v == 0 goto label;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("connectionUsername");
interfaceinvoke v.<javax.naming.directory.DirContext: java.lang.Object addToEnvironment(java.lang.String,java.lang.Object)>("java.naming.security.principal", v);
goto label;
label:
interfaceinvoke v.<javax.naming.directory.DirContext: java.lang.Object removeFromEnvironment(java.lang.String)>("java.naming.security.principal");
label:
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: boolean isLoginPropertySet(java.lang.String)>("connectionPassword");
if v == 0 goto label;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("connectionPassword");
interfaceinvoke v.<javax.naming.directory.DirContext: java.lang.Object addToEnvironment(java.lang.String,java.lang.Object)>("java.naming.security.credentials", v);
goto label;
label:
interfaceinvoke v.<javax.naming.directory.DirContext: java.lang.Object removeFromEnvironment(java.lang.String)>("java.naming.security.credentials");
label:
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("authentication");
interfaceinvoke v.<javax.naming.directory.DirContext: java.lang.Object addToEnvironment(java.lang.String,java.lang.Object)>("java.naming.security.authentication", v);
return v;
catch javax.naming.AuthenticationException from label to label with label;
}
private java.util.List addAttributeValues(java.lang.String, javax.naming.directory.Attributes, java.util.List) throws javax.naming.NamingException
{
org.apache.activemq.jaas.LDAPLoginModule v;
java.util.ArrayList v;
javax.naming.directory.Attribute v;
java.util.List v;
javax.naming.directory.Attributes v;
javax.naming.NamingEnumeration v;
java.lang.Object v;
java.lang.String v;
boolean v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v := @parameter: java.lang.String;
v := @parameter: javax.naming.directory.Attributes;
v := @parameter: java.util.List;
if v == null goto label;
if v != null goto label;
label:
return v;
label:
if v != null goto label;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = v;
label:
v = interfaceinvoke v.<javax.naming.directory.Attributes: javax.naming.directory.Attribute get(java.lang.String)>(v);
if v != null goto label;
return v;
label:
v = interfaceinvoke v.<javax.naming.directory.Attribute: javax.naming.NamingEnumeration getAll()>();
label:
v = interfaceinvoke v.<javax.naming.NamingEnumeration: boolean hasMore()>();
if v == 0 goto label;
v = interfaceinvoke v.<javax.naming.NamingEnumeration: java.lang.Object next()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
return v;
}
protected void openContext() throws javax.naming.NamingException
{
org.apache.activemq.jaas.LDAPLoginModule v;
javax.naming.NamingException v, v, v;
javax.naming.directory.InitialDirContext v;
java.lang.String v, v, v, v, v, v, v;
java.util.Hashtable v;
boolean v, v;
org.slf4j.Logger v;
javax.naming.directory.DirContext v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v = v.<org.apache.activemq.jaas.LDAPLoginModule: javax.naming.directory.DirContext context>;
if v == null goto label;
return;
label:
v = new java.util.Hashtable;
specialinvoke v.<java.util.Hashtable: void <init>()>();
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("initialContextFactory");
virtualinvoke v.<java.util.Hashtable: java.lang.Object put(java.lang.Object,java.lang.Object)>("java.naming.factory.initial", v);
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: boolean isLoginPropertySet(java.lang.String)>("connectionUsername");
if v == 0 goto label;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("connectionUsername");
virtualinvoke v.<java.util.Hashtable: java.lang.Object put(java.lang.Object,java.lang.Object)>("java.naming.security.principal", v);
goto label;
label:
v = new javax.naming.NamingException;
specialinvoke v.<javax.naming.NamingException: void <init>(java.lang.String)>("Empty username is not allowed");
throw v;
label:
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: boolean isLoginPropertySet(java.lang.String)>("connectionPassword");
if v == 0 goto label;
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("connectionPassword");
virtualinvoke v.<java.util.Hashtable: java.lang.Object put(java.lang.Object,java.lang.Object)>("java.naming.security.credentials", v);
goto label;
label:
v = new javax.naming.NamingException;
specialinvoke v.<javax.naming.NamingException: void <init>(java.lang.String)>("Empty password is not allowed");
throw v;
label:
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("connectionProtocol");
virtualinvoke v.<java.util.Hashtable: java.lang.Object put(java.lang.Object,java.lang.Object)>("java.naming.security.protocol", v);
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("connectionURL");
virtualinvoke v.<java.util.Hashtable: java.lang.Object put(java.lang.Object,java.lang.Object)>("java.naming.provider.url", v);
v = specialinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: java.lang.String getLDAPPropertyValue(java.lang.String)>("authentication");
virtualinvoke v.<java.util.Hashtable: java.lang.Object put(java.lang.Object,java.lang.Object)>("java.naming.security.authentication", v);
v = new javax.naming.directory.InitialDirContext;
specialinvoke v.<javax.naming.directory.InitialDirContext: void <init>(java.util.Hashtable)>(v);
v.<org.apache.activemq.jaas.LDAPLoginModule: javax.naming.directory.DirContext context> = v;
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginModule: void closeContext()>();
v = <org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log>;
v = virtualinvoke v.<javax.naming.NamingException: java.lang.String toString()>();
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>(v);
throw v;
label:
return;
catch javax.naming.NamingException from label to label with label;
}
private java.lang.String getLDAPPropertyValue(java.lang.String)
{
org.apache.activemq.jaas.LDAPLoginModule v;
org.apache.activemq.jaas.LDAPLoginProperty v;
org.apache.activemq.jaas.LDAPLoginProperty[] v;
int v, v;
java.lang.String v, v, v;
boolean v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v := @parameter: java.lang.String;
v = v.<org.apache.activemq.jaas.LDAPLoginModule: org.apache.activemq.jaas.LDAPLoginProperty[] config>;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: java.lang.String getPropertyName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: java.lang.String getPropertyValue()>();
return v;
label:
v = v + 1;
goto label;
label:
return null;
}
private boolean isLoginPropertySet(java.lang.String)
{
org.apache.activemq.jaas.LDAPLoginModule v;
org.apache.activemq.jaas.LDAPLoginProperty v;
org.apache.activemq.jaas.LDAPLoginProperty[] v;
int v, v;
java.lang.String v, v, v, v, v;
boolean v, v;
v := @this: org.apache.activemq.jaas.LDAPLoginModule;
v := @parameter: java.lang.String;
v = v.<org.apache.activemq.jaas.LDAPLoginModule: org.apache.activemq.jaas.LDAPLoginProperty[] config>;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: java.lang.String getPropertyName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: java.lang.String getPropertyValue()>();
if v == null goto label;
v = "";
v = virtualinvoke v.<org.apache.activemq.jaas.LDAPLoginProperty: java.lang.String getPropertyValue()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
return 1;
label:
v = v + 1;
goto label;
label:
return 0;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/activemq/jaas/LDAPLoginModule;");
<org.apache.activemq.jaas.LDAPLoginModule: org.slf4j.Logger log> = v;
return;
}
}