org.ldaptive.beans.persistence.DefaultLdapEntryManager Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ldaptive-beans Show documentation
Show all versions of ldaptive-beans Show documentation
Provides a mapping, persistence, and code generation API for reading and writing POJOs to an LDAP directory
/* See LICENSE for licensing and NOTICE for copyright. */
package org.ldaptive.beans.persistence;
import org.ldaptive.AddOperation;
import org.ldaptive.AddRequest;
import org.ldaptive.Connection;
import org.ldaptive.ConnectionFactory;
import org.ldaptive.DeleteOperation;
import org.ldaptive.DeleteRequest;
import org.ldaptive.LdapEntry;
import org.ldaptive.LdapException;
import org.ldaptive.LdapUtils;
import org.ldaptive.Response;
import org.ldaptive.ReturnAttributes;
import org.ldaptive.SearchOperation;
import org.ldaptive.SearchRequest;
import org.ldaptive.SearchResult;
import org.ldaptive.beans.LdapEntryMapper;
import org.ldaptive.ext.MergeOperation;
import org.ldaptive.ext.MergeRequest;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Default implementation of an ldap entry manager. Uses an {@link LdapEntryMapper} to convert objects to entries, then
* invokes LDAP operations with those objects. By default all attributes are requested using both the '*' and '+'
* syntaxes. For attributes that must be requested by name, use {@link #DefaultLdapEntryManager(LdapEntryMapper,
* ConnectionFactory, String[])}.
*
* @param type of object to manage
*
* @author Middleware Services
*/
public class DefaultLdapEntryManager implements LdapEntryManager
{
/** Logger for this class. */
protected final Logger logger = LoggerFactory.getLogger(getClass());
/** Mapper for converting ldap entry to object type. */
private final LdapEntryMapper ldapEntryMapper;
/** Connection factory for LDAP communication. */
private final ConnectionFactory connectionFactory;
/** Additional attributes to include in searches. */
private final String[] returnAttributes;
/**
* Creates a new default ldap entry manager.
*
* @param mapper for object conversion
* @param factory for LDAP communication
*/
public DefaultLdapEntryManager(final LdapEntryMapper mapper, final ConnectionFactory factory)
{
this(mapper, factory, null);
}
/**
* Creates a new default ldap entry manager. Use of attrs is for cases where a directory does not support either the
* '*' or '+' syntaxes for returning all attributes of a given type.
*
* @param mapper for object conversion
* @param factory for LDAP communication
* @param attrs additional return attributes
*/
public DefaultLdapEntryManager(final LdapEntryMapper mapper, final ConnectionFactory factory, final String[] attrs)
{
ldapEntryMapper = mapper;
connectionFactory = factory;
returnAttributes = attrs;
}
/**
* Returns the ldap entry mapper.
*
* @return ldap entry mapper
*/
public LdapEntryMapper getLdapEntryMapper()
{
return ldapEntryMapper;
}
/**
* Returns the connection factory.
*
* @return connection factory
*/
public ConnectionFactory getConnectionFactory()
{
return connectionFactory;
}
/**
* Returns the return attributes.
*
* @return additional attributes to include in searches.
*/
public String[] getReturnAttributes()
{
return returnAttributes;
}
@Override
public T find(final T object)
throws LdapException
{
final String dn = getLdapEntryMapper().mapDn(object);
String[] attrs = ReturnAttributes.ALL.value();
if (returnAttributes != null) {
attrs = LdapUtils.concatArrays(attrs, returnAttributes);
}
final SearchRequest request = SearchRequest.newObjectScopeSearchRequest(dn, attrs);
try (Connection conn = getConnectionFactory().getConnection()) {
conn.open();
final SearchOperation search = new SearchOperation(conn);
final Response response = search.execute(request);
if (response.getResult().size() == 0) {
throw new IllegalArgumentException(
String.format("Unable to find ldap entry %s, no entries returned: %s", dn, response));
}
if (response.getResult().size() > 1) {
throw new IllegalArgumentException(
String.format("Unable to find ldap entry %s, multiple entries returned: %s", dn, response));
}
getLdapEntryMapper().map(response.getResult().getEntry(), object);
}
return object;
}
@Override
public Response add(final T object)
throws LdapException
{
final LdapEntry entry = new LdapEntry();
getLdapEntryMapper().map(object, entry);
final AddRequest request = new AddRequest(entry.getDn(), entry.getAttributes());
try (Connection conn = getConnectionFactory().getConnection()) {
conn.open();
final AddOperation add = new AddOperation(conn);
return add.execute(request);
}
}
@Override
public Response merge(final T object)
throws LdapException
{
final LdapEntry entry = new LdapEntry();
getLdapEntryMapper().map(object, entry);
final MergeRequest request = new MergeRequest(entry);
try (Connection conn = getConnectionFactory().getConnection()) {
conn.open();
final MergeOperation merge = new MergeOperation(conn);
return merge.execute(request);
}
}
@Override
public Response delete(final T object)
throws LdapException
{
final String dn = getLdapEntryMapper().mapDn(object);
final DeleteRequest request = new DeleteRequest(dn);
try (Connection conn = getConnectionFactory().getConnection()) {
conn.open();
final DeleteOperation delete = new DeleteOperation(conn);
return delete.execute(request);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy