Class LdapTemplate
- All Implemented Interfaces:
- org.springframework.beans.factory.InitializingBean,- LdapOperations
 Note for Active Directory (AD) users: AD servers are apparently unable to handle
 referrals automatically, which causes a PartialResultException to be
 thrown whenever a referral is encountered in a search. To avoid this, set the
 ignorePartialResultException property to true. There is
 currently no way of manually handling these referrals in the form of
 ReferralException, i.e. either you get the exception (and your results are
 lost) or all referrals are ignored (if the server is unable to handle them properly.
 Neither is there any simple way to get notified that a
 PartialResultException has been ignored (other than in the log).
- See Also:
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic final classANameClassPairCallbackHandlerthat passes the NameClassPairs found to a NameClassPairMapper and collects the results in a list.static final classDo-nothing implementation ofDirContextProcessor.
- 
Constructor SummaryConstructorsConstructorDescriptionConstructor for bean usage.LdapTemplate(ContextSource contextSource) Constructor to setup instance directly.
- 
Method SummaryModifier and TypeMethodDescriptionvoidbooleanauthenticate(String base, String filter, String password) Utility method to perform a simple LDAP 'bind' authentication.booleanauthenticate(String base, String filter, String password, AuthenticatedLdapEntryContextCallback callback) Utility method to perform a simple LDAP 'bind' authentication.booleanauthenticate(String base, String filter, String password, AuthenticatedLdapEntryContextCallback callback, AuthenticationErrorCallback errorCallback) Utility method to perform a simple LDAP 'bind' authentication.booleanauthenticate(String base, String filter, String password, AuthenticationErrorCallback errorCallback) Utility method to perform a simple LDAP 'bind' authentication.booleanauthenticate(Name base, String filter, String password) Utility method to perform a simple LDAP 'bind' authentication.booleanauthenticate(Name base, String filter, String password, AuthenticatedLdapEntryContextCallback callback) Utility method to perform a simple LDAP 'bind' authentication.booleanauthenticate(Name base, String filter, String password, AuthenticatedLdapEntryContextCallback callback, AuthenticationErrorCallback errorCallback) Utility method to perform a simple LDAP 'bind' authentication.booleanauthenticate(Name base, String filter, String password, AuthenticationErrorCallback errorCallback) Utility method to perform a simple LDAP 'bind' authentication.voidauthenticate(LdapQuery query, String password) Utility method to perform a simple LDAP 'bind' authentication.<T> Tauthenticate(LdapQuery query, String password, AuthenticatedLdapEntryContextMapper<T> mapper) Utility method to perform a simple LDAP 'bind' authentication.voidbind(String dn, Object obj, Attributes attributes) Create an entry in the LDAP tree.voidbind(Name dn, Object obj, Attributes attributes) Create an entry in the LDAP tree.voidbind(DirContextOperations ctx) Bind the data in the supplied context in the tree.voidCreate the given entry in the LDAP directory.voidDelete an entry from the LDAP directory.protected voiddeleteRecursively(DirContext ctx, Name name) Delete all subcontexts including the current one recursively.<T> TexecuteReadOnly(ContextExecutor<T> ce) Perform an operation (or series of operations) on a read-only context.<T> TexecuteReadWrite(ContextExecutor<T> ce) Perform an operation (or series of operations) on a read-write context.<T> List<T>find(Name base, Filter filter, SearchControls searchControls, Class<T> clazz) Find all entries in the LDAP directory of a given type that matches the specified filter.<T> List<T>Search for entries in the LDAP directory.<T> List<T>Find all entries in the LDAP directory of a given type.<T> List<T>findAll(Name base, SearchControls searchControls, Class<T> clazz) Find all entries in the LDAP directory of a given type.<T> TRead a named entry from the LDAP directory.<T> Stream<T>findForStream(LdapQuery query, Class<T> clazz) Search for entries in the LDAP directory.<T> TSearch for objects in the directory tree matching the specified LdapQuery, expecting to find exactly one match.Get the ContextSource.Get the configured ObjectDirectoryMapper.Perform a non-recursive listing of the children of the givenbase.voidlist(String base, NameClassPairCallbackHandler handler) Perform a non-recursive listing of the children of the givenbase.<T> List<T>list(String base, NameClassPairMapper<T> mapper) Perform a non-recursive listing of the children of the givenbase.Perform a non-recursive listing of the children of the givenbase.voidlist(Name base, NameClassPairCallbackHandler handler) Perform a non-recursive listing of the children of the givenbase.<T> List<T>list(Name base, NameClassPairMapper<T> mapper) Perform a non-recursive listing of the children of the givenbase.listBindings(String base) Perform a non-recursive listing of children of the givenbase.<T> List<T>listBindings(String base, ContextMapper<T> mapper) Perform a non-recursive listing of the children of the givenbase.voidlistBindings(String base, NameClassPairCallbackHandler handler) Perform a non-recursive listing of the children of the givenbase.<T> List<T>listBindings(String base, NameClassPairMapper<T> mapper) Perform a non-recursive listing of the children of the givenbase.listBindings(Name base) Perform a non-recursive listing of children of the givenbase.<T> List<T>listBindings(Name base, ContextMapper<T> mapper) Perform a non-recursive listing of the children of the givenbase.voidlistBindings(Name base, NameClassPairCallbackHandler handler) Perform a non-recursive listing of the children of the givenbase.<T> List<T>listBindings(Name base, NameClassPairMapper<T> mapper) Perform a non-recursive listing of the children of the givenbase.Lookup the supplied DN and return the found object.<T> Tlookup(String dn, String[] attributes, AttributesMapper<T> mapper) Convenience method to get the specified attributes of a specified DN and automatically pass them to anAttributesMapper.<T> Tlookup(String dn, String[] attributes, ContextMapper<T> mapper) Convenience method to get the specified attributes of a specified DN and automatically pass them to aContextMapper.<T> Tlookup(String dn, AttributesMapper<T> mapper) Convenience method to get the attributes of a specified DN and automatically pass them to anAttributesMapper.<T> Tlookup(String dn, ContextMapper<T> mapper) Convenience method to lookup a specified DN and automatically pass the found object to aContextMapper.Lookup the supplied DN and return the found object.<T> Tlookup(Name dn, String[] attributes, AttributesMapper<T> mapper) Convenience method to get the specified attributes of a specified DN and automatically pass them to anAttributesMapper.<T> Tlookup(Name dn, String[] attributes, ContextMapper<T> mapper) Convenience method to get the specified attributes of a specified DN and automatically pass them to aContextMapper.<T> Tlookup(Name dn, AttributesMapper<T> mapper) Convenience method to get the attributes of a specified DN and automatically pass them to anAttributesMapper.<T> Tlookup(Name dn, ContextMapper<T> mapper) Convenience method to lookup a specified DN and automatically pass the found object to aContextMapper.lookupContext(String dn) Convenience method to lookup the supplied DN and automatically cast it toDirContextOperations.lookupContext(Name dn) Convenience method to lookup the supplied DN and automatically cast it toDirContextOperations.voidmodifyAttributes(String dn, ModificationItem[] mods) Modify an entry in the LDAP tree using the suppliedModificationItems.voidmodifyAttributes(Name dn, ModificationItem[] mods) Modify an entry in the LDAP tree using the suppliedModificationItems.voidModify the attributes of the entry referenced by the suppliedDirContextOperationsinstance.voidrebind(String dn, Object obj, Attributes attributes) Remove an entry and replace it with a new one.voidrebind(Name dn, Object obj, Attributes attributes) Remove an entry and replace it with a new one.voidRemove an entry and replace it with a new one.voidMove an entry in the LDAP tree to a new location.voidMove an entry in the LDAP tree to a new location.voidsearch(String base, String filter, int searchScope, boolean returningObjFlag, NameClassPairCallbackHandler handler) Search for all objects matching the supplied filter.<T> List<T>search(String base, String filter, int searchScope, String[] attrs, AttributesMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(String base, String filter, int searchScope, String[] attrs, ContextMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(String base, String filter, int searchScope, AttributesMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(String base, String filter, int searchScope, ContextMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(String base, String filter, SearchControls controls, AttributesMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(String base, String filter, SearchControls controls, AttributesMapper<T> mapper, DirContextProcessor processor) Search for all objects matching the supplied filter.<T> List<T>search(String base, String filter, SearchControls controls, ContextMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(String base, String filter, SearchControls controls, ContextMapper<T> mapper, DirContextProcessor processor) Search for all objects matching the supplied filter.voidsearch(String base, String filter, SearchControls controls, NameClassPairCallbackHandler handler) Search for all objects matching the supplied filter.voidsearch(String base, String filter, SearchControls controls, NameClassPairCallbackHandler handler, DirContextProcessor processor) Search for all objects matching the supplied filter.<T> List<T>search(String base, String filter, AttributesMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(String base, String filter, ContextMapper<T> mapper) Search for all objects matching the supplied filter.voidsearch(String base, String filter, NameClassPairCallbackHandler handler) Search for all objects matching the supplied filter.voidsearch(Name base, String filter, int searchScope, boolean returningObjFlag, NameClassPairCallbackHandler handler) Search for all objects matching the supplied filter.<T> List<T>search(Name base, String filter, int searchScope, String[] attrs, AttributesMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(Name base, String filter, int searchScope, String[] attrs, ContextMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(Name base, String filter, int searchScope, AttributesMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(Name base, String filter, int searchScope, ContextMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(Name base, String filter, SearchControls controls, AttributesMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(Name base, String filter, SearchControls controls, AttributesMapper<T> mapper, DirContextProcessor processor) Search for all objects matching the supplied filter.<T> List<T>search(Name base, String filter, SearchControls controls, ContextMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(Name base, String filter, SearchControls controls, ContextMapper<T> mapper, DirContextProcessor processor) Search for all objects matching the supplied filter.voidsearch(Name base, String filter, SearchControls controls, NameClassPairCallbackHandler handler) Search for all objects matching the supplied filter.voidsearch(Name base, String filter, SearchControls controls, NameClassPairCallbackHandler handler, DirContextProcessor processor) Search for all objects matching the supplied filter.<T> List<T>search(Name base, String filter, AttributesMapper<T> mapper) Search for all objects matching the supplied filter.<T> List<T>search(Name base, String filter, ContextMapper<T> mapper) Search for all objects matching the supplied filter.voidsearch(Name base, String filter, NameClassPairCallbackHandler handler) Search for all objects matching the supplied filter.voidsearch(SearchExecutor se, NameClassPairCallbackHandler handler) Perform a search operation, such as a search(), list() or listBindings().voidsearch(SearchExecutor se, NameClassPairCallbackHandler handler, DirContextProcessor processor) Perform a search operation, such as a search(), list() or listBindings().<T> List<T>search(LdapQuery query, AttributesMapper<T> mapper) Perform a search with parameters from the specified LdapQuery.<T> List<T>search(LdapQuery query, ContextMapper<T> mapper) Perform a search with parameters from the specified LdapQuery.voidsearch(LdapQuery query, NameClassPairCallbackHandler callbackHandler) Perform a search with parameters from the specified LdapQuery.searchForContext(LdapQuery query) Perform a search for a unique entry matching the specified LDAP query and return the found entry as a DirContextOperation instance.<T> TsearchForObject(String base, String filter, SearchControls searchControls, ContextMapper<T> mapper) Perform a search for a unique entry matching the specified search criteria and return the found object.<T> TsearchForObject(String base, String filter, ContextMapper<T> mapper) Perform a search for a unique entry matching the specified search criteria and return the found object.<T> TsearchForObject(Name base, String filter, SearchControls searchControls, ContextMapper<T> mapper) Perform a search for a unique entry matching the specified search criteria and return the found object.<T> TsearchForObject(Name base, String filter, ContextMapper<T> mapper) Perform a search for a unique entry matching the specified search criteria and return the found object.<T> TsearchForObject(LdapQuery query, ContextMapper<T> mapper) Perform a search for a unique entry matching the specified LDAP query and return the found object.<T> Stream<T>searchForStream(LdapQuery query, AttributesMapper<T> attributesMapper) Perform a search with parameters from the specified LdapQuery.<T> Stream<T>searchForStream(LdapQuery query, ContextMapper<T> mapper) Perform a search with parameters from the specified LdapQuery.voidsetContextSource(ContextSource contextSource) Set the ContextSource.voidsetDefaultCountLimit(int defaultCountLimit) Set the default count limit be used in searches if not explicitly specified.voidsetDefaultSearchScope(int defaultSearchScope) Set the default scope to be used in searches if not explicitly specified.voidsetDefaultTimeLimit(int defaultTimeLimit) Set the default time limit be used in searches if not explicitly specified.voidsetIgnoreNameNotFoundException(boolean ignore) Specify whetherNameNotFoundExceptionshould be ignored in searches.voidsetIgnorePartialResultException(boolean ignore) Specify whetherPartialResultExceptionshould be ignored in searches.voidsetIgnoreSizeLimitExceededException(boolean ignore) Specify whetherSizeLimitExceededExceptionshould be ignored in searches.voidSet the ObjectDirectoryMapper instance to use.voidRemove an entry from the LDAP tree.voidRemove an entry from the LDAP tree, optionally removing all descendants in the process.voidRemove an entry from the LDAP tree.voidRemove an entry from the LDAP tree, optionally removing all descendants in the process.voidUpdate the given entry in the LDAP directory.
- 
Constructor Details- 
LdapTemplatepublic LdapTemplate()Constructor for bean usage.
- 
LdapTemplateConstructor to setup instance directly.- Parameters:
- contextSource- the ContextSource to use.
 
 
- 
- 
Method Details- 
setContextSourceSet the ContextSource. Call this method when the default constructor has been used.- Parameters:
- contextSource- the ContextSource.
 
- 
getObjectDirectoryMapperGet the configured ObjectDirectoryMapper. For internal use.- Specified by:
- getObjectDirectoryMapperin interface- LdapOperations
- Returns:
- the configured ObjectDirectoryMapper.
 
- 
setObjectDirectoryMapperSet the ObjectDirectoryMapper instance to use.- Parameters:
- odm- the ObejctDirectoryMapper to use.
- Since:
- 2.0
 
- 
getContextSourceGet the ContextSource.- Returns:
- the ContextSource.
 
- 
setIgnoreNameNotFoundExceptionpublic void setIgnoreNameNotFoundException(boolean ignore) Specify whetherNameNotFoundExceptionshould be ignored in searches. In previous version,NameNotFoundExceptioncaused by the search base not being found was silently ignored. The default behavior is now to treat this as an error (as it should), and to convert and re-throw the exception. The ability to revert to the previous behavior still exists. The only difference is that the incident is in that case no longer silently ignored, but logged as a warning.- Parameters:
- ignore-- trueif- NameNotFoundExceptionshould be ignored in searches,- falseotherwise. Default is- false.
- Since:
- 1.3
 
- 
setIgnorePartialResultExceptionpublic void setIgnorePartialResultException(boolean ignore) Specify whetherPartialResultExceptionshould be ignored in searches. AD servers typically have a problem with referrals. Normally a referral should be followed automatically, but this does not seem to work with AD servers. The problem manifests itself with aPartialResultExceptionbeing thrown when a referral is encountered by the server. Setting this property totruepresents a workaround to this problem by causingPartialResultExceptionto be ignored, so that the search method returns normally. Default value of this parameter isfalse.- Parameters:
- ignore-- trueif- PartialResultExceptionshould be ignored in searches,- falseotherwise. Default is- false.
 
- 
setIgnoreSizeLimitExceededExceptionpublic void setIgnoreSizeLimitExceededException(boolean ignore) Specify whetherSizeLimitExceededExceptionshould be ignored in searches. This is typically what you want if you specify count limit in your search controls.- Parameters:
- ignore-- trueif- SizeLimitExceededExceptionshould be ignored in searches,- falseotherwise. Default is- true.
- Since:
- 2.0
 
- 
setDefaultSearchScopepublic void setDefaultSearchScope(int defaultSearchScope) Set the default scope to be used in searches if not explicitly specified. Default isSearchControls.SUBTREE_SCOPE.- Parameters:
- defaultSearchScope- the default search scope to use in searches. One of- SearchControls.OBJECT_SCOPE,- SearchControls.ONELEVEL_SCOPE, or- SearchControls.SUBTREE_SCOPE
- Since:
- 2.0
 
- 
setDefaultTimeLimitpublic void setDefaultTimeLimit(int defaultTimeLimit) Set the default time limit be used in searches if not explicitly specified. Default is 0, indicating no time limit.- Parameters:
- defaultTimeLimit- the default time limit to use in searches.
- Since:
- 2.0
 
- 
setDefaultCountLimitpublic void setDefaultCountLimit(int defaultCountLimit) Set the default count limit be used in searches if not explicitly specified. Default is 0, indicating no count limit.- Parameters:
- defaultCountLimit- the default count limit to use in searches.
- Since:
- 2.0
 
- 
searchpublic void search(Name base, String filter, int searchScope, boolean returningObjFlag, NameClassPairCallbackHandler handler) Search for all objects matching the supplied filter. EachSearchResultis supplied to the specifiedNameClassPairCallbackHandler. Use the specified values for search scope and return objects flag.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- searchScope- The search scope to set in- SearchControls.
- returningObjFlag- Whether the bound object should be returned in search results. Must be set to- trueif a- ContextMapperis used.
- handler- The- NameClassPairCallbackHandlerto supply the- SearchResultsto.
 
- 
searchpublic void search(String base, String filter, int searchScope, boolean returningObjFlag, NameClassPairCallbackHandler handler) Search for all objects matching the supplied filter. EachSearchResultis supplied to the specifiedNameClassPairCallbackHandler. Use the specified values for search scope and return objects flag.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- searchScope- The search scope to set in- SearchControls.
- returningObjFlag- Whether the bound object should be returned in search results. Must be set to- trueif a- ContextMapperis used.
- handler- The- NameClassPairCallbackHandlerto supply the- SearchResultsto.
 
- 
searchpublic void search(Name base, String filter, SearchControls controls, NameClassPairCallbackHandler handler) Search for all objects matching the supplied filter. EachSearchResultis supplied to the specifiedNameClassPairCallbackHandler. TheSearchScopespecified in the suppliedSearchControlswill be used in the search. Note that if you are using aContextMapper, the returningObjFlag needs to be set to true in theSearchControls.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- controls- The- SearchControlsto use in the search.
- handler- The- NameClassPairCallbackHandlerto supply the- SearchResultto.
 
- 
searchpublic void search(String base, String filter, SearchControls controls, NameClassPairCallbackHandler handler) Search for all objects matching the supplied filter. SeeLdapOperations.search(Name, String, SearchControls, NameClassPairCallbackHandler)for details.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- controls- The- SearchControlsto use in the search.
- handler- The- NameClassPairCallbackHandlerto supply the- SearchResultto.
 
- 
searchpublic void search(Name base, String filter, SearchControls controls, NameClassPairCallbackHandler handler, DirContextProcessor processor) Search for all objects matching the supplied filter. EachSearchResultis supplied to the specifiedNameClassPairCallbackHandler. TheSearchScopespecified in the suppliedSearchControlswill be used in the search. Note that if you are using aContextMapper, the returningObjFlag needs to be set to true in theSearchControls. The givenDirContextProcessorwill be called before and after the search.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- controls- The- SearchControlsto use in the search.
- handler- The- NameClassPairCallbackHandlerto supply the- SearchResultto.
- processor- The- DirContextProcessorto use before and after the search.
 
- 
searchpublic void search(String base, String filter, SearchControls controls, NameClassPairCallbackHandler handler, DirContextProcessor processor) Search for all objects matching the supplied filter. SeeLdapOperations.search(Name, String, SearchControls, NameClassPairCallbackHandler, DirContextProcessor)for details.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- controls- The- SearchControlsto use in the search.
- handler- The- NameClassPairCallbackHandlerto supply the- SearchResultsto.
- processor- The- DirContextProcessorto use before and after the search.
 
- 
searchpublic void search(SearchExecutor se, NameClassPairCallbackHandler handler, DirContextProcessor processor) Perform a search operation, such as a search(), list() or listBindings(). This method handles all the plumbing; getting a readonly context; looping through the NamingEnumeration and closing the context and enumeration. It also calls the supplied DirContextProcessor before and after the search, respectively. This enables custom pre-processing and post-processing, like for example when handling paged results or other search controls.The actual list is delegated to the SearchExecutorand eachNameClassPair(this might be a NameClassPair or a subclass thereof) is passed to the CallbackHandler. Any encountered NamingException will be translated using the NamingExceptionTranslator.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- se- the SearchExecutor to use for performing the actual list.
- handler- the NameClassPairCallbackHandler to which each found entry will be passed.
- processor- DirContextProcessor for custom pre- and post-processing. Must not be- null. If no custom processing should take place, please use e.g.- search(SearchExecutor, NameClassPairCallbackHandler).
- Throws:
- NamingException- if any error occurs. Note that a NameNotFoundException will be ignored. Instead this is interpreted that no entries were found.
 
- 
searchPerform a search operation, such as a search(), list() or listBindings(). This method handles all the plumbing; getting a readonly context; looping through the NamingEnumeration and closing the context and enumeration.The actual list is delegated to the SearchExecutorand eachNameClassPair(this might be a NameClassPair or a subclass thereof) is passed to the CallbackHandler. Any encountered NamingException will be translated using the NamingExceptionTranslator.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- se- the SearchExecutor to use for performing the actual list.
- handler- the NameClassPairCallbackHandler to which each found entry will be passed.
- Throws:
- NamingException- if any error occurs. Note that a NameNotFoundException will be ignored. Instead this is interpreted that no entries were found.
- See Also:
 
- 
searchSearch for all objects matching the supplied filter. EachSearchResultis supplied to the specifiedNameClassPairCallbackHandler. The default Search scope (SearchControls.SUBTREE_SCOPE) will be used and the returnObjects flag will be set tofalse.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- handler- The- NameClassPairCallbackHandlerto supply the- SearchResultsto.
 
- 
searchSearch for all objects matching the supplied filter. EachSearchResultis supplied to the specifiedNameClassPairCallbackHandler. The default Search scope (SearchControls.SUBTREE_SCOPE) will be used and the returnObjects flag will be set tofalse.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- handler- The- NameClassPairCallbackHandlerto supply the- SearchResultsto.
 
- 
searchpublic <T> List<T> search(Name base, String filter, int searchScope, String[] attrs, AttributesMapper<T> mapper) Search for all objects matching the supplied filter. Only return any attributes mathing the specified attribute names. The Attributes in eachSearchResultis supplied to the specifiedAttributesMapper.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- searchScope- The search scope to set in- SearchControls.
- attrs- The attributes to return,- nullmeans returning all attributes.
- mapper- The- AttributesMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theAttributesMapper.
 
- 
searchpublic <T> List<T> search(String base, String filter, int searchScope, String[] attrs, AttributesMapper<T> mapper) Search for all objects matching the supplied filter. Only return any attributes mathing the specified attribute names. The Attributes in eachSearchResultis supplied to the specifiedAttributesMapper.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- searchScope- The search scope to set in- SearchControls.
- attrs- The attributes to return,- nullmeans returning all attributes.
- mapper- The- AttributesMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theAttributesMapper.
 
- 
searchSearch for all objects matching the supplied filter. The Attributes in eachSearchResultis supplied to the specifiedAttributesMapper.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- searchScope- The search scope to set in- SearchControls.
- mapper- The- AttributesMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theAttributesMapper.
 
- 
searchSearch for all objects matching the supplied filter. The Attributes in eachSearchResultis supplied to the specifiedAttributesMapper.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- searchScope- The search scope to set in- SearchControls.
- mapper- The- AttributesMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theAttributesMapper.
 
- 
searchSearch for all objects matching the supplied filter. The Attributes in eachSearchResultis supplied to the specifiedAttributesMapper. The default search scope will be used.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- mapper- The- AttributesMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theAttributesMapper.
 
- 
searchSearch for all objects matching the supplied filter. The Attributes in eachSearchResultis supplied to the specifiedAttributesMapper. The default search scope will be used.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- mapper- The- AttributesMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theAttributesMapper.
 
- 
searchpublic <T> List<T> search(Name base, String filter, int searchScope, String[] attrs, ContextMapper<T> mapper) Search for all objects matching the supplied filter. TheObjectreturned in eachSearchResultis supplied to the specifiedContextMapper. Only return the supplied attributes.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- searchScope- The search scope to set in- SearchControls.
- attrs- The attributes to return,- nullmeans all attributes.
- mapper- The- ContextMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
searchpublic <T> List<T> search(String base, String filter, int searchScope, String[] attrs, ContextMapper<T> mapper) Search for all objects matching the supplied filter. TheObjectreturned in eachSearchResultis supplied to the specifiedContextMapper. Only return the supplied attributes.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- searchScope- The search scope to set in- SearchControls.
- attrs- The attributes to return,- nullmeans all attributes.
- mapper- The- ContextMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
searchSearch for all objects matching the supplied filter. TheObjectreturned in eachSearchResultis supplied to the specifiedContextMapper.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- searchScope- The search scope to set in- SearchControls.
- mapper- The- ContextMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
searchSearch for all objects matching the supplied filter. TheObjectreturned in eachSearchResultis supplied to the specifiedContextMapper.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- searchScope- The search scope to set in- SearchControls.
- mapper- The- ContextMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
searchSearch for all objects matching the supplied filter. TheObjectreturned in eachSearchResultis supplied to the specifiedContextMapper. The default search scope (SearchControls.SUBTREE_SCOPE) will be used.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- mapper- The- ContextMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
searchSearch for all objects matching the supplied filter. TheObjectreturned in eachSearchResultis supplied to the specifiedContextMapper. The default search scope (SearchControls.SUBTREE_SCOPE) will be used.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- mapper- The- ContextMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
searchpublic <T> List<T> search(String base, String filter, SearchControls controls, ContextMapper<T> mapper) Search for all objects matching the supplied filter. TheObjectreturned in eachSearchResultis supplied to the specifiedContextMapper. The default search scope (SearchControls.SUBTREE_SCOPE) will be used.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- mapper- The- ContextMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
searchpublic <T> List<T> search(Name base, String filter, SearchControls controls, ContextMapper<T> mapper) Search for all objects matching the supplied filter. The Object returned in eachSearchResultis supplied to the specifiedContextMapper.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- controls- The- SearchControlsto use in the search. If the returnObjFlag is not set in the- SearchControls, this method will set it automatically, as this is required for the- ContextMapperto work.
- mapper- The- ContextMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
searchpublic <T> List<T> search(Name base, String filter, SearchControls controls, AttributesMapper<T> mapper) Search for all objects matching the supplied filter. The Attributes returned in eachSearchResultis supplied to the specifiedAttributesMapper.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- controls- The- SearchControlsto use in the search.
- mapper- The- AttributesMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
searchpublic <T> List<T> search(String base, String filter, SearchControls controls, AttributesMapper<T> mapper) Search for all objects matching the supplied filter. The Attributes returned in eachSearchResultis supplied to the specifiedAttributesMapper.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- controls- The- SearchControlsto use in the search.
- mapper- The- AttributesMapperto use for translating each entry.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
searchpublic <T> List<T> search(String base, String filter, SearchControls controls, AttributesMapper<T> mapper, DirContextProcessor processor) Search for all objects matching the supplied filter. The Attributes in eachSearchResultis supplied to the specifiedAttributesMapper. TheSearchScopespecified in the suppliedSearchControlswill be used in the search. The givenDirContextProcessorwill be called before and after the search.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- controls- The- SearchControlsto use in the search.
- mapper- The- AttributesMapperto use for translating each entry.
- processor- The- DirContextProcessorto use before and after the search.
- Returns:
- a Listcontaining all entries received from theAttributesMapper.
 
- 
searchpublic <T> List<T> search(Name base, String filter, SearchControls controls, AttributesMapper<T> mapper, DirContextProcessor processor) Search for all objects matching the supplied filter. The Attributes in eachSearchResultis supplied to the specifiedAttributesMapper. TheSearchScopespecified in the suppliedSearchControlswill be used in the search. The givenDirContextProcessorwill be called before and after the search.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- controls- The- SearchControlsto use in the search.
- mapper- The- AttributesMapperto use for translating each entry.
- processor- The- DirContextProcessorto use before and after the search.
- Returns:
- a Listcontaining all entries received from theAttributesMapper.
 
- 
searchpublic <T> List<T> search(String base, String filter, SearchControls controls, ContextMapper<T> mapper, DirContextProcessor processor) Search for all objects matching the supplied filter. The Object returned in eachSearchResultis supplied to the specifiedContextMapper. TheSearchScopespecified in the suppliedSearchControlswill be used in the search. The givenDirContextProcessorwill be called before and after the search.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- controls- The- SearchControlsto use in the search. If the returnObjFlag is not set in the- SearchControls, this method will set it automatically, as this is required for the- ContextMapperto work.
- mapper- The- ContextMapperto use for translating each entry.
- processor- The- DirContextProcessorto use before and after the search.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
searchpublic <T> List<T> search(Name base, String filter, SearchControls controls, ContextMapper<T> mapper, DirContextProcessor processor) Search for all objects matching the supplied filter. The Object returned in eachSearchResultis supplied to the specifiedContextMapper. TheSearchScopespecified in the suppliedSearchControlswill be used in the search. The givenDirContextProcessorwill be called before and after the search.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- base- The base DN where the search should begin.
- filter- The filter to use in the search.
- controls- The- SearchControlsto use in the search. If the returnObjFlag is not set in the- SearchControls, this method will set it automatically, as this is required for the- ContextMapperto work.
- mapper- The- ContextMapperto use for translating each entry.
- processor- The- DirContextProcessorto use before and after the search.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
listPerform a non-recursive listing of the children of the givenbase. Each resultingNameClassPairis supplied to the specifiedNameClassPairCallbackHandler.- Specified by:
- listin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- handler- The- NameClassPairCallbackHandlerto supply each- NameClassPairto.
 
- 
listPerform a non-recursive listing of the children of the givenbase. Each resultingNameClassPairis supplied to the specifiedNameClassPairCallbackHandler.- Specified by:
- listin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- handler- The- NameClassPairCallbackHandlerto supply each- NameClassPairto.
 
- 
listPerform a non-recursive listing of the children of the givenbase. Pass all the foundNameClassPairobjects to the suppliedNameClassPairMapperand return all the returned values as aList.- Specified by:
- listin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- mapper- The- NameClassPairMapperto supply each- NameClassPairto.
- Returns:
- a Listcontaining the Objects returned from the Mapper.
 
- 
listPerform a non-recursive listing of the children of the givenbase. Pass all the foundNameClassPairobjects to the suppliedNameClassPairMapperand return all the returned values as aList.- Specified by:
- listin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- mapper- The- NameClassPairMapperto supply each- NameClassPairto.
- Returns:
- a Listcontaining the Objects returned from the Mapper.
 
- 
listPerform a non-recursive listing of the children of the givenbase.- Specified by:
- listin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- Returns:
- a List containing the names of all the contexts bound to base.
 
- 
listPerform a non-recursive listing of the children of the givenbase.- Specified by:
- listin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- Returns:
- a List containing the names of all the contexts bound to base.
 
- 
listBindingsPerform a non-recursive listing of the children of the givenbase. Each resultingBindingis supplied to the specifiedNameClassPairCallbackHandler.- Specified by:
- listBindingsin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- handler- The- NameClassPairCallbackHandlerto supply each- Bindingto.
 
- 
listBindingsPerform a non-recursive listing of the children of the givenbase. Each resultingBindingis supplied to the specifiedNameClassPairCallbackHandler.- Specified by:
- listBindingsin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- handler- The- NameClassPairCallbackHandlerto supply each- Bindingto.
 
- 
listBindingsPerform a non-recursive listing of the children of the givenbase. Pass all the foundBindingobjects to the suppliedNameClassPairMapperand return all the returned values as aList.- Specified by:
- listBindingsin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- mapper- The- NameClassPairMapperto supply each- Bindingto.
- Returns:
- a Listcontaining the Objects returned from the Mapper.
 
- 
listBindingsPerform a non-recursive listing of the children of the givenbase. Pass all the foundBindingobjects to the suppliedNameClassPairMapperand return all the returned values as aList.- Specified by:
- listBindingsin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- mapper- The- NameClassPairMapperto supply each- Bindingto.
- Returns:
- a Listcontaining the Objects returned from the Mapper.
 
- 
listBindingsPerform a non-recursive listing of children of the givenbase.- Specified by:
- listBindingsin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- Returns:
- a Listcontaining the names of all the contexts bound tobase.
 
- 
listBindingsPerform a non-recursive listing of children of the givenbase.- Specified by:
- listBindingsin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- Returns:
- a Listcontaining the names of all the contexts bound tobase.
 
- 
listBindingsPerform a non-recursive listing of the children of the givenbase. The Object returned in eachBindingis supplied to the specifiedContextMapper.- Specified by:
- listBindingsin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- mapper- The- ContextMapperto use for mapping the found object.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
listBindingsPerform a non-recursive listing of the children of the givenbase. The Object returned in eachBindingis supplied to the specifiedContextMapper.- Specified by:
- listBindingsin interface- LdapOperations
- Parameters:
- base- The base DN where the list should be performed.
- mapper- The- ContextMapperto use for mapping the found object.
- Returns:
- a Listcontaining all entries received from theContextMapper.
 
- 
executeReadOnlyPerform an operation (or series of operations) on a read-only context. This method handles the plumbing - getting aDirContext, translating any Exceptions and closing the context afterwards. This method is not intended for searches; useLdapOperations.search(SearchExecutor, NameClassPairCallbackHandler)or any of the overloaded search methods for this.- Specified by:
- executeReadOnlyin interface- LdapOperations
- Parameters:
- ce- The- ContextExecutorto which the actual operation on the- DirContextwill be delegated.
- Returns:
- the result from the ContextExecutor's operation.
- See Also:
 
- 
executeReadWritePerform an operation (or series of operations) on a read-write context. This method handles the plumbing - getting aDirContext, translating any exceptions and closing the context afterwards. This method is intended only for very particular cases, where there is no suitable method in this interface to use.- Specified by:
- executeReadWritein interface- LdapOperations
- Parameters:
- ce- The- ContextExecutorto which the actual operation on the- DirContextwill be delegated.
- Returns:
- the result from the ContextExecutor's operation.
- See Also:
 
- 
lookupLookup the supplied DN and return the found object. This will typically be aDirContextAdapter, unless theDirObjectFactoryhas been modified in theContextSource.- Specified by:
- lookupin interface- LdapOperations
- Parameters:
- dn- The distinguished name of the object to find.
- Returns:
- the found object, typically a DirContextAdapterinstance.
- See Also:
 
- 
lookupLookup the supplied DN and return the found object. This will typically be aDirContextAdapter, unless theDirObjectFactoryhas been modified in theContextSource.- Specified by:
- lookupin interface- LdapOperations
- Parameters:
- dn- The distinguished name of the object to find.
- Returns:
- the found object, typically a DirContextAdapterinstance.
- See Also:
 
- 
lookupConvenience method to get the attributes of a specified DN and automatically pass them to anAttributesMapper.- Specified by:
- lookupin interface- LdapOperations
- Parameters:
- dn- The distinguished name to find.
- mapper- The- AttributesMapperto use for mapping the found object.
- Returns:
- the object returned from the mapper.
 
- 
lookupConvenience method to get the attributes of a specified DN and automatically pass them to anAttributesMapper.- Specified by:
- lookupin interface- LdapOperations
- Parameters:
- dn- The distinguished name to find.
- mapper- The- AttributesMapperto use for mapping the found object.
- Returns:
- the object returned from the mapper.
 
- 
lookupConvenience method to lookup a specified DN and automatically pass the found object to aContextMapper.- Specified by:
- lookupin interface- LdapOperations
- Parameters:
- dn- The distinguished name to find.
- mapper- The- ContextMapperto use for mapping the found object.
- Returns:
- the object returned from the mapper.
 
- 
lookupConvenience method to lookup a specified DN and automatically pass the found object to aContextMapper.- Specified by:
- lookupin interface- LdapOperations
- Parameters:
- dn- The distinguished name to find.
- mapper- The- ContextMapperto use for mapping the found object.
- Returns:
- the object returned from the mapper.
 
- 
lookupConvenience method to get the specified attributes of a specified DN and automatically pass them to anAttributesMapper.- Specified by:
- lookupin interface- LdapOperations
- Parameters:
- dn- The distinguished name to find.
- attributes- The names of the attributes to pass to the mapper.
- mapper- The- AttributesMapperto use for mapping the found object.
- Returns:
- the object returned from the mapper.
 
- 
lookupConvenience method to get the specified attributes of a specified DN and automatically pass them to anAttributesMapper.- Specified by:
- lookupin interface- LdapOperations
- Parameters:
- dn- The distinguished name to find.
- attributes- The names of the attributes to pass to the mapper.
- mapper- The- AttributesMapperto use for mapping the found object.
- Returns:
- the object returned from the mapper.
 
- 
lookupConvenience method to get the specified attributes of a specified DN and automatically pass them to aContextMapper.- Specified by:
- lookupin interface- LdapOperations
- Parameters:
- dn- The distinguished name to find.
- attributes- The names of the attributes to pass to the mapper.
- mapper- The- ContextMapperto use for mapping the found object.
- Returns:
- the object returned from the mapper.
 
- 
lookupConvenience method to get the specified attributes of a specified DN and automatically pass them to aContextMapper.- Specified by:
- lookupin interface- LdapOperations
- Parameters:
- dn- The distinguished name to find.
- attributes- The names of the attributes to pass to the mapper.
- mapper- The- ContextMapperto use for mapping the found object.
- Returns:
- the object returned from the mapper.
 
- 
modifyAttributesModify an entry in the LDAP tree using the suppliedModificationItems.- Specified by:
- modifyAttributesin interface- LdapOperations
- Parameters:
- dn- The distinguished name of the node to modify.
- mods- The modifications to perform.
- See Also:
 
- 
modifyAttributesModify an entry in the LDAP tree using the suppliedModificationItems.- Specified by:
- modifyAttributesin interface- LdapOperations
- Parameters:
- dn- The distinguished name of the node to modify.
- mods- The modifications to perform.
- See Also:
 
- 
bindCreate an entry in the LDAP tree. The attributes used to create the entry are either retrieved from theobjparameter or theattributesparameter (or both). One of these parameters may benullbut not both.- Specified by:
- bindin interface- LdapOperations
- Parameters:
- dn- The distinguished name to bind the object and attributes to.
- obj- The object to bind, may be- null. Typically a- DirContextimplementation.
- attributes- The attributes to bind, may be- null.
- See Also:
 
- 
bindCreate an entry in the LDAP tree. The attributes used to create the entry are either retrieved from theobjparameter or theattributesparameter (or both). One of these parameters may benullbut not both.- Specified by:
- bindin interface- LdapOperations
- Parameters:
- dn- The distinguished name to bind the object and attributes to.
- obj- The object to bind, may be- null. Typically a- DirContextimplementation.
- attributes- The attributes to bind, may be- null.
- See Also:
 
- 
unbindRemove an entry from the LDAP tree. The entry must not have any children - if you suspect that the entry might have descendants, useLdapOperations.unbind(Name, boolean)in stead.- Specified by:
- unbindin interface- LdapOperations
- Parameters:
- dn- The distinguished name of the entry to remove.
 
- 
unbindRemove an entry from the LDAP tree. The entry must not have any children - if you suspect that the entry might have descendants, useLdapOperations.unbind(Name, boolean)in stead.- Specified by:
- unbindin interface- LdapOperations
- Parameters:
- dn- The distinguished name to unbind.
 
- 
unbindRemove an entry from the LDAP tree, optionally removing all descendants in the process.- Specified by:
- unbindin interface- LdapOperations
- Parameters:
- dn- The distinguished name to unbind.
- recursive- Whether to unbind all subcontexts as well. If this parameter is- falseand the entry has children, the operation will fail.
 
- 
unbindRemove an entry from the LDAP tree, optionally removing all descendants in the process.- Specified by:
- unbindin interface- LdapOperations
- Parameters:
- dn- The distinguished name to unbind.
- recursive- Whether to unbind all subcontexts as well. If this parameter is- falseand the entry has children, the operation will fail.
 
- 
deleteRecursivelyDelete all subcontexts including the current one recursively.- Parameters:
- ctx- The context to use for deleting.
- name- The starting point to delete recursively.
- Throws:
- NamingException- if any error occurs
 
- 
rebindRemove an entry and replace it with a new one. The attributes used to create the entry are either retrieved from theobjparameter or theattributesparameter (or both). One of these parameters may benullbut not both. This method assumes that the specified context already exists - if not it will fail.- Specified by:
- rebindin interface- LdapOperations
- Parameters:
- dn- The distinguished name to rebind.
- obj- The object to bind to the DN, may be- null. Typically a- DirContextimplementation.
- attributes- The attributes to bind, may be- null.
- See Also:
 
- 
rebindRemove an entry and replace it with a new one. The attributes used to create the entry are either retrieved from theobjparameter or theattributesparameter (or both). One of these parameters may benullbut not both. This method assumes that the specified context already exists - if not it will fail.- Specified by:
- rebindin interface- LdapOperations
- Parameters:
- dn- The distinguished name to rebind.
- obj- The object to bind to the DN, may be- null. Typically a- DirContextimplementation.
- attributes- The attributes to bind, may be- null.
- See Also:
 
- 
renameMove an entry in the LDAP tree to a new location.- Specified by:
- renamein interface- LdapOperations
- Parameters:
- oldDn- The distinguished name of the entry to move; may not be- nullor empty.
- newDn- The distinguished name where the entry should be moved; may not be- nullor empty.
 
- 
renameMove an entry in the LDAP tree to a new location.- Specified by:
- renamein interface- LdapOperations
- Parameters:
- oldDn- The distinguished name of the entry to move; may not be- nullor empty.
- newDn- The distinguished name where the entry should be moved; may not be- nullor empty.
 
- 
afterPropertiesSet- Specified by:
- afterPropertiesSetin interface- org.springframework.beans.factory.InitializingBean
- Throws:
- Exception
 
- 
lookupContextConvenience method to lookup the supplied DN and automatically cast it toDirContextOperations.- Specified by:
- lookupContextin interface- LdapOperations
- Parameters:
- dn- The distinguished name of the object to find.
- Returns:
- The found object, cast to DirContextOperations.
- See Also:
 
- 
lookupContextConvenience method to lookup the supplied DN and automatically cast it toDirContextOperations.- Specified by:
- lookupContextin interface- LdapOperations
- Parameters:
- dn- The distinguished name of the object to find.
- Returns:
- The found object, cast to DirContextOperations.
- See Also:
 
- 
modifyAttributesModify the attributes of the entry referenced by the suppliedDirContextOperationsinstance. The DN to update will be the DN of theDirContextOperationsinstance, and theModificationItemarray is retrieved from theDirContextOperationsinstance using a call toAttributeModificationsAware.getModificationItems(). NB: The supplied instance needs to have been properly initialized; this means that if it hasn't been received from alookupoperation, its DN needs to be initialized and it must have been put in update mode (DirContextAdapter.setUpdateMode(boolean)).Typical use of this method would be as follows: public void update(Person person) { DirContextOperations ctx = ldapOperations.lookupContext(person.getDn()); ctx.setAttributeValue("description", person.getDescription()); ctx.setAttributeValue("telephoneNumber", person.getPhone()); // More modifications here ldapOperations.modifyAttributes(ctx); }- Specified by:
- modifyAttributesin interface- LdapOperations
- Parameters:
- ctx- the DirContextOperations instance to use in the update.
- See Also:
 
- 
bindBind the data in the supplied context in the tree. All specified attributesctxin will be bound to the DN set onctx.Example: 
 DirContextOperations ctx = new DirContextAdapter(dn); ctx.setAttributeValue("cn", "john doe"); ctx.setAttributeValue("description", "some description"); //More initialization here. ldapTemplate.bind(ctx);- Specified by:
- bindin interface- LdapOperations
- Parameters:
- ctx- the context to bind
 
- 
rebindRemove an entry and replace it with a new one. The attributes used to create the entry are retrieved from thectxparameter. This method assumes that the specified context already exists - if not it will fail. The entry will be bound to the DN set onctx.Example: 
 DirContextOperations ctx = new DirContextAdapter(dn); ctx.setAttributeValue("cn", "john doe"); ctx.setAttributeValue("description", "some description"); //More initialization here. ldapTemplate.rebind(ctx);- Specified by:
- rebindin interface- LdapOperations
- Parameters:
- ctx- the context to rebind
 
- 
authenticateUtility method to perform a simple LDAP 'bind' authentication. Search for the LDAP entry to authenticate using the supplied base DN and filter; use the DN of the found entry together with the password as input toContextSource.getContext(String, String), thus authenticating the entry.Example: 
 AndFilter filter = new AndFilter(); filter.and("objectclass", "person").and("uid", userId); boolean authenticated = ldapTemplate.authenticate(LdapUtils.emptyLdapName(), filter.toString(), password);- Specified by:
- authenticatein interface- LdapOperations
- Parameters:
- base- the DN to use as the base of the search.
- filter- the search filter - must result in a unique result.
- password- the password to use for authentication.
- Returns:
- trueif the authentication was successful,- falseotherwise.
 
- 
authenticateUtility method to perform a simple LDAP 'bind' authentication. Search for the LDAP entry to authenticate using the supplied base DN and filter; use the DN of the found entry together with the password as input toContextSource.getContext(String, String), thus authenticating the entry.Example: 
 AndFilter filter = new AndFilter(); filter.and("objectclass", "person").and("uid", userId); boolean authenticated = ldapTemplate.authenticate(LdapUtils.emptyLdapName(), filter.toString(), password);- Specified by:
- authenticatein interface- LdapOperations
- Parameters:
- base- the DN to use as the base of the search.
- filter- the search filter - must result in a unique result.
- password- the password to use for authentication.
- Returns:
- trueif the authentication was successful,- falseotherwise.
 
- 
authenticatepublic boolean authenticate(String base, String filter, String password, AuthenticatedLdapEntryContextCallback callback) Utility method to perform a simple LDAP 'bind' authentication. Search for the LDAP entry to authenticate using the supplied base DN and filter; use the DN of the found entry together with the password as input toContextSource.getContext(String, String), thus authenticating the entry. The resulting DirContext instance is then used as input to the suppliedAuthenticatedLdapEntryContextCallbackto perform any additional LDAP operations against the authenticated DirContext.- Specified by:
- authenticatein interface- LdapOperations
- Parameters:
- base- the DN to use as the base of the search.
- filter- the search filter - must result in a unique result.
- password- the password to use for authentication.
- callback- the callback to that will be called to perform operations on the DirContext authenticated with the found user.
- Returns:
- trueif the authentication was successful,- falseotherwise.
- See Also:
 
- 
authenticatepublic boolean authenticate(Name base, String filter, String password, AuthenticatedLdapEntryContextCallback callback) Utility method to perform a simple LDAP 'bind' authentication. Search for the LDAP entry to authenticate using the supplied base DN and filter; use the DN of the found entry together with the password as input toContextSource.getContext(String, String), thus authenticating the entry. The resulting DirContext instance is then used as input to the suppliedAuthenticatedLdapEntryContextCallbackto perform any additional LDAP operations against the authenticated DirContext.- Specified by:
- authenticatein interface- LdapOperations
- Parameters:
- base- the DN to use as the base of the search.
- filter- the search filter - must result in a unique result.
- password- the password to use for authentication.
- callback- the callback to that will be called to perform operations on the DirContext authenticated with the found user.
- Returns:
- trueif the authentication was successful,- falseotherwise.
- See Also:
 
- 
authenticatepublic boolean authenticate(String base, String filter, String password, AuthenticationErrorCallback errorCallback) Utility method to perform a simple LDAP 'bind' authentication. Search for the LDAP entry to authenticate using the supplied base DN and filter; use the DN of the found entry together with the password as input toContextSource.getContext(String, String), thus authenticating the entry. If an exception is caught, the same exception is passed on to the givenAuthenticationErrorCallback. This enables the caller to provide a callback that, for example, collects the exception for later processing.- Specified by:
- authenticatein interface- LdapOperations
- Parameters:
- base- the DN to use as the base of the search.
- filter- the search filter - must result in a unique result.
- password- the password to use for authentication.
- errorCallback- the callback that will be called if an exception is caught.
- Returns:
- trueif the authentication was successful,- falseotherwise.
 
- 
authenticatepublic boolean authenticate(Name base, String filter, String password, AuthenticationErrorCallback errorCallback) Utility method to perform a simple LDAP 'bind' authentication. Search for the LDAP entry to authenticate using the supplied base DN and filter; use the DN of the found entry together with the password as input toContextSource.getContext(String, String), thus authenticating the entry. If an exception is caught, the same exception is passed on to the givenAuthenticationErrorCallback. This enables the caller to provide a callback that, for example, collects the exception for later processing.- Specified by:
- authenticatein interface- LdapOperations
- Parameters:
- base- the DN to use as the base of the search.
- filter- the search filter - must result in a unique result.
- password- the password to use for authentication.
- errorCallback- the callback that will be called if an exception is caught.
- Returns:
- trueif the authentication was successful,- falseotherwise.
- See Also:
 
- 
authenticatepublic boolean authenticate(String base, String filter, String password, AuthenticatedLdapEntryContextCallback callback, AuthenticationErrorCallback errorCallback) Utility method to perform a simple LDAP 'bind' authentication. Search for the LDAP entry to authenticate using the supplied base DN and filter; use the DN of the found entry together with the password as input toContextSource.getContext(String, String), thus authenticating the entry. The resulting DirContext instance is then used as input to the suppliedAuthenticatedLdapEntryContextCallbackto perform any additional LDAP operations against the authenticated DirContext. If an exception is caught, the same exception is passed on to the givenAuthenticationErrorCallback. This enables the caller to provide a callback that, for example, collects the exception for later processing.- Specified by:
- authenticatein interface- LdapOperations
- Parameters:
- base- the DN to use as the base of the search.
- filter- the search filter - must result in a unique result.
- password- the password to use for authentication.
- callback- the callback that will be called to perform operations on the DirContext authenticated with the found user.
- errorCallback- the callback that will be called if an exception is caught.
- Returns:
- trueif the authentication was successful,- falseotherwise.
- See Also:
 
- 
authenticatepublic boolean authenticate(Name base, String filter, String password, AuthenticatedLdapEntryContextCallback callback, AuthenticationErrorCallback errorCallback) Utility method to perform a simple LDAP 'bind' authentication. Search for the LDAP entry to authenticate using the supplied base DN and filter; use the DN of the found entry together with the password as input toContextSource.getContext(String, String), thus authenticating the entry. The resulting DirContext instance is then used as input to the suppliedAuthenticatedLdapEntryContextCallbackto perform any additional LDAP operations against the authenticated DirContext. If an exception is caught, the same exception is passed on to the givenAuthenticationErrorCallback. This enables the caller to provide a callback that, for example, collects the exception for later processing.- Specified by:
- authenticatein interface- LdapOperations
- Parameters:
- base- the DN to use as the base of the search.
- filter- the search filter - must result in a unique result.
- password- the password to use for authentication.
- callback- the callback that will be called to perform operations on the DirContext authenticated with the found user.
- errorCallback- the callback that will be called if an exception is caught.
- Returns:
- trueif the authentication was successful,- falseotherwise.
- See Also:
 
- 
authenticatepublic <T> T authenticate(LdapQuery query, String password, AuthenticatedLdapEntryContextMapper<T> mapper) Utility method to perform a simple LDAP 'bind' authentication. Search for the LDAP entry to authenticate using the supplied LdapQuery; use the DN of the found entry together with the password as input toContextSource.getContext(String, String), thus authenticating the entry.Note: This method differs from the older authenticate methods in that encountered exceptions are thrown rather than supplied to a callback for handling. - Specified by:
- authenticatein interface- LdapOperations
- Parameters:
- query- the LdapQuery specifying the details of the search.
- password- the password to use for authentication.
- mapper- the callback that will be called to perform operations on the DirContext authenticated with the found user.- falseotherwise.
- Returns:
- the result from the callback.
- See Also:
 
- 
authenticateUtility method to perform a simple LDAP 'bind' authentication. Search for the LDAP entry to authenticate using the supplied base DN and filter; use the DN of the found entry together with the password as input toContextSource.getContext(String, String), thus authenticating the entry. If an exception is caught, the same exception is passed on to the givenAuthenticationErrorCallback. This enables the caller to provide a callback that, for example, collects the exception for later processing.Note: This method differs from the older authenticate methods in that encountered exceptions are thrown rather than supplied to a callback for handling. - Specified by:
- authenticatein interface- LdapOperations
- Parameters:
- query- the LdapQuery specifying the details of the search.
- password- the password to use for authentication.- falseotherwise.
- See Also:
 
- 
searchForObjectPerform a search for a unique entry matching the specified search criteria and return the found object. If no entry is found or if there are more than one matching entry, anIncorrectResultSizeDataAccessExceptionis thrown.- Specified by:
- searchForObjectin interface- LdapOperations
- Parameters:
- base- the DN to use as the base of the search.
- filter- the search filter.
- mapper- the mapper to use for the search.
- Returns:
- the single object returned by the mapper that matches the search criteria.
 
- 
searchForObjectPerform a search for a unique entry matching the specified search criteria and return the found object. If no entry is found or if there are more than one matching entry, anIncorrectResultSizeDataAccessExceptionis thrown.- Specified by:
- searchForObjectin interface- LdapOperations
- Parameters:
- base- the DN to use as the base of the search.
- filter- the search filter.
- mapper- the mapper to use for the search.
- Returns:
- the single object returned by the mapper that matches the search criteria.
 
- 
searchForObjectpublic <T> T searchForObject(Name base, String filter, SearchControls searchControls, ContextMapper<T> mapper) Perform a search for a unique entry matching the specified search criteria and return the found object. If no entry is found or if there are more than one matching entry, anIncorrectResultSizeDataAccessExceptionis thrown.- Specified by:
- searchForObjectin interface- LdapOperations
- Parameters:
- base- the DN to use as the base of the search.
- filter- the search filter.
- searchControls- the searchControls to use for the search.
- mapper- the mapper to use for the search.
- Returns:
- the single object returned by the mapper that matches the search criteria.
 
- 
searchForObjectpublic <T> T searchForObject(String base, String filter, SearchControls searchControls, ContextMapper<T> mapper) Perform a search for a unique entry matching the specified search criteria and return the found object. If no entry is found or if there are more than one matching entry, anIncorrectResultSizeDataAccessExceptionis thrown.- Specified by:
- searchForObjectin interface- LdapOperations
- Parameters:
- base- the DN to use as the base of the search.
- filter- the search filter.
- searchControls- the searchControls to use for the search.
- mapper- the mapper to use for the search.
- Returns:
- the single object returned by the mapper that matches the search criteria.
 
- 
searchPerform a search with parameters from the specified LdapQuery. All found objects will be supplied to theNameClassPairCallbackHandlerfor processing.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- query- the LDAP query specification.
- callbackHandler- the- NameClassPairCallbackHandlerto supply all found entries to.
- See Also:
 
- 
searchPerform a search with parameters from the specified LdapQuery. All found objects will be supplied to theContextMapperfor processing, and all returned objects will be collected in a list to be returned.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- query- the LDAP query specification.
- mapper- the- ContextMapperto supply all found entries to.
- Returns:
- a Listcontaining all entries received from theContextMapper.
- See Also:
 
- 
searchPerform a search with parameters from the specified LdapQuery. The Attributes of the found entries will be supplied to theAttributesMapperfor processing, and all returned objects will be collected in a list to be returned.- Specified by:
- searchin interface- LdapOperations
- Parameters:
- query- the LDAP query specification.
- mapper- the- Attributesto supply all found Attributes to.
- Returns:
- a Listcontaining all entries received from theAttributes.
- See Also:
 
- 
searchForContextPerform a search for a unique entry matching the specified LDAP query and return the found entry as a DirContextOperation instance. If no entry is found or if there are more than one matching entry, anIncorrectResultSizeDataAccessExceptionis thrown.- Specified by:
- searchForContextin interface- LdapOperations
- Parameters:
- query- the LDAP query specification.
- Returns:
- the single entry matching the query as a DirContextOperations instance.
- See Also:
 
- 
searchForObjectPerform a search for a unique entry matching the specified LDAP query and return the found object. If no entry is found or if there are more than one matching entry, anIncorrectResultSizeDataAccessExceptionis thrown.- Specified by:
- searchForObjectin interface- LdapOperations
- Parameters:
- query- the LDAP query specification.
- Returns:
- the single object returned by the mapper that matches the search criteria.
- See Also:
 
- 
searchForStreamPerform a search with parameters from the specified LdapQuery. The Attributes of the found entries will be supplied to theAttributesMapperfor processing, and all returned objects will be collected in a list to be returned.- Specified by:
- searchForStreamin interface- LdapOperations
- Parameters:
- query- the LDAP query specification.
- attributesMapper- the- Attributesto supply all found Attributes to.
- Returns:
- a Streamof all entries received from theAttributes.
- See Also:
 
- 
searchForStreamPerform a search with parameters from the specified LdapQuery. All found objects will be supplied to theContextMapperfor processing, and all returned objects will be collected in a list to be returned.- Specified by:
- searchForStreamin interface- LdapOperations
- Parameters:
- query- the LDAP query specification.
- mapper- the- ContextMapperto supply all found entries to.
- Returns:
- a Streamof all entries received from theContextMapper.
- See Also:
 
- 
findByDnRead a named entry from the LDAP directory. The referenced class must have object-directory mapping metadata specified usingEntryand associated annotations.- Specified by:
- findByDnin interface- LdapOperations
- Type Parameters:
- T- The Java type to return
- Parameters:
- dn- The distinguished name of the entry to read from the LDAP directory.
- clazz- The Java type to return
- Returns:
- The entry as read from the directory
 
- 
createCreate the given entry in the LDAP directory. The referenced class must have object-directory mapping metadata specified usingEntryand associated annotations. If the field annotated withIdis set in the object, this will be used as the distinguished name of the new entry. If no explicit DN is specified, an attempt will be made to calculate the name from fields annotated withDnAttribute. If an id can be calculated, this will be populated in the supplied object.- Specified by:
- createin interface- LdapOperations
- Parameters:
- entry- The entry to be create, it must not be null or already exist in the directory.
 
- 
updateUpdate the given entry in the LDAP directory. The referenced class must have object-directory mapping metadata specified usingEntryand associated annotations. If the distinguished name is not explicitly specified (i.e. if the field annotated withIdisnull), an attempt will be made to calculate the name from fields annotated withDnAttribute. If theIdfield and the calculated DN is different, the entry will be moved (i.e., anLdapOperations.unbind(javax.naming.Name)followed by aLdapOperations.bind(DirContextOperations). Otherwise the current data of the entry will be read from the directory and aLdapOperations.modifyAttributes(DirContextOperations)operation will be performed using theModificationItemsresulting from the changes of the entry compared to its current state in the directory. If the id of the entry has changed, i.e. if it wasn't specified from the beginning, or if it is calculated to have changed, the new value will be populated in the supplied object.- Specified by:
- updatein interface- LdapOperations
- Parameters:
- entry- The entry to update, it must already exist in the directory.
 
- 
deleteDelete an entry from the LDAP directory. The referenced class must have object-directory mapping metadata specified usingEntryand associated annotations. If the field annotated withIdis set in the object, this will be used as the distinguished name of the new entry. If no explicit DN is specified, an attempt will be made to calculate the name from fields annotated withDnAttribute.- Specified by:
- deletein interface- LdapOperations
- Parameters:
- entry- The entry to delete, it must already exist in the directory.
 
- 
findAllFind all entries in the LDAP directory of a given type. The referenced class must have object-directory mapping metadata specified usingEntryand associated annotations.- Specified by:
- findAllin interface- LdapOperations
- Type Parameters:
- T- The Java type to return
- Parameters:
- base- The root of the sub-tree at which to begin the search.
- searchControls- The search controls of the search. Note that the 'returned attributes' parameter should typically not be tampered with, since that may affect the attributes populated in returned entries.
- clazz- The Java type to return
- Returns:
- All entries that are of the type represented by the given Java class
 
- 
findAllFind all entries in the LDAP directory of a given type. The referenced class must have object-directory mapping metadata specified usingEntryand associated annotations.- Specified by:
- findAllin interface- LdapOperations
- Type Parameters:
- T- The Java type to return
- Parameters:
- clazz- The Java type to return
- Returns:
- All entries that are of the type represented by the given Java class
 
- 
findFind all entries in the LDAP directory of a given type that matches the specified filter. The referenced class must have object-directory mapping metadata specified usingEntryand associated annotations.- Specified by:
- findin interface- LdapOperations
- Type Parameters:
- T- The Java type to return
- Parameters:
- base- The root of the sub-tree at which to begin the search.
- filter- The search filter.
- searchControls- The search controls of the search. Note that the 'returned attributes' parameter should typically not be tampered with, since that may affect the attributes populated in returned entries.
- clazz- The Java type to return
- Returns:
- All entries that are of the type represented by the given Java class
 
- 
findSearch for entries in the LDAP directory. The referenced class must have object-directory mapping metadata specified usingEntryand associated annotations.Only those entries that both match the query search filter and are represented by the given Java class are returned. - Specified by:
- findin interface- LdapOperations
- Type Parameters:
- T- The Java type to return
- Parameters:
- query- the LDAP query specification
- clazz- The Java type to return
- Returns:
- All matching entries.
- See Also:
 
- 
findOneSearch for objects in the directory tree matching the specified LdapQuery, expecting to find exactly one match. The referenced class must have object-directory mapping metadata specified usingEntryand associated annotations.- Specified by:
- findOnein interface- LdapOperations
- Type Parameters:
- T- The Java type to return
- Parameters:
- query- the LDAP query specification
- clazz- The Java type to return
- Returns:
- The single entry matching the search specification.
 
- 
findForStreamSearch for entries in the LDAP directory. The referenced class must have object-directory mapping metadata specified usingEntryand associated annotations.Only those entries that both match the query search filter and are represented by the given Java class are returned. - Specified by:
- findForStreamin interface- LdapOperations
- Type Parameters:
- T- The Java type to return
- Parameters:
- query- the LDAP query specification
- clazz- The Java type to return
- Returns:
- All matching entries.
- See Also:
 
 
-