Make template and search controls member variables.
This commit is contained in:
parent
d3e42c6f3f
commit
ce1c59e924
|
@ -123,11 +123,11 @@ public class DefaultLdapAuthoritiesPopulator implements LdapAuthoritiesPopulator
|
|||
/** The ID of the attribute which contains the role name for a group */
|
||||
private String groupRoleAttribute = "cn";
|
||||
|
||||
/** Whether group searches should be performed over the full sub-tree from the base DN */
|
||||
// private boolean searchSubtree = false;
|
||||
/** Controls used to determine whether group searches should be performed over the
|
||||
* full sub-tree from the base DN. Modified by searchSubTree property
|
||||
*/
|
||||
|
||||
/** Internal variable, tied to searchSubTree property */
|
||||
private int searchScope = SearchControls.ONELEVEL_SCOPE;
|
||||
private SearchControls searchControls = new SearchControls();
|
||||
|
||||
private boolean convertToUpperCase = true;
|
||||
|
||||
|
@ -137,6 +137,9 @@ public class DefaultLdapAuthoritiesPopulator implements LdapAuthoritiesPopulator
|
|||
/** An initial context factory is only required if searching for groups is required. */
|
||||
private InitialDirContextFactory initialDirContextFactory = null;
|
||||
|
||||
private LdapTemplate ldapTemplate;
|
||||
|
||||
|
||||
//~ Constructors ===========================================================
|
||||
|
||||
/**
|
||||
|
@ -157,6 +160,9 @@ public class DefaultLdapAuthoritiesPopulator implements LdapAuthoritiesPopulator
|
|||
logger.info("groupSearchBase is empty. Searches will be performed from the root: " +
|
||||
initialDirContextFactory.getRootDn());
|
||||
}
|
||||
|
||||
ldapTemplate = new LdapTemplate(initialDirContextFactory);
|
||||
ldapTemplate.setSearchControls(searchControls);
|
||||
}
|
||||
|
||||
//~ Methods ================================================================
|
||||
|
@ -216,11 +222,9 @@ public class DefaultLdapAuthoritiesPopulator implements LdapAuthoritiesPopulator
|
|||
+ " in search base '" + groupSearchBase + "'");
|
||||
}
|
||||
|
||||
LdapTemplate template = new LdapTemplate(initialDirContextFactory);
|
||||
|
||||
template.setSearchScope(searchScope);
|
||||
|
||||
Set userRoles = template.searchForSingleAttributeValues(groupSearchBase, groupSearchFilter, new String[]{userDn, username}, groupRoleAttribute);
|
||||
Set userRoles = ldapTemplate.searchForSingleAttributeValues(groupSearchBase, groupSearchFilter,
|
||||
new String[]{userDn, username}, groupRoleAttribute);
|
||||
|
||||
if (logger.isDebugEnabled()) {
|
||||
logger.debug("Roles from search: " + userRoles);
|
||||
|
@ -281,9 +285,9 @@ public class DefaultLdapAuthoritiesPopulator implements LdapAuthoritiesPopulator
|
|||
}
|
||||
|
||||
public void setSearchSubtree(boolean searchSubtree) {
|
||||
// this.searchSubtree = searchSubtree;
|
||||
this.searchScope = searchSubtree ?
|
||||
int searchScope = searchSubtree ?
|
||||
SearchControls.SUBTREE_SCOPE : SearchControls.ONELEVEL_SCOPE;
|
||||
searchControls.setSearchScope(searchScope);
|
||||
}
|
||||
|
||||
public void setConvertToUpperCase(boolean convertToUpperCase) {
|
||||
|
|
Loading…
Reference in New Issue