All Downloads are FREE. Search and download functionalities are using the official Maven repository.

edu.vt.middleware.ldap.Ldap Maven / Gradle / Ivy

/*
  $Id: Ldap.java 1330 2010-05-23 22:10:53Z dfisher $

  Copyright (C) 2003-2010 Virginia Tech.
  All rights reserved.

  SEE LICENSE FOR MORE INFORMATION

  Author:  Middleware Services
  Email:   [email protected]
  Version: $Revision: 1330 $
  Updated: $Date: 2010-05-23 18:10:53 -0400 (Sun, 23 May 2010) $
*/
package edu.vt.middleware.ldap;

import java.io.InputStream;
import java.io.Serializable;
import java.util.Iterator;
import javax.naming.Binding;
import javax.naming.NameClassPair;
import javax.naming.NamingException;
import javax.naming.directory.Attribute;
import javax.naming.directory.Attributes;
import javax.naming.directory.DirContext;
import javax.naming.directory.ModificationItem;
import javax.naming.directory.SearchControls;
import javax.naming.directory.SearchResult;
import edu.vt.middleware.ldap.handler.AttributeHandler;
import edu.vt.middleware.ldap.handler.ExtendedAttributeHandler;
import edu.vt.middleware.ldap.handler.ExtendedSearchResultHandler;
import edu.vt.middleware.ldap.handler.SearchCriteria;
import edu.vt.middleware.ldap.handler.SearchResultHandler;

/**
 * Ldap contains functions for basic interaction with an LDAP.
 * Methods are provided for connecting, binding, querying and updating.
 *
 * @author  Middleware Services
 * @version  $Revision: 1330 $ $Date: 2010-05-23 18:10:53 -0400 (Sun, 23 May 2010) $
 */
public class Ldap extends AbstractLdap implements Serializable
{

  /** serial version uid. */
  private static final long serialVersionUID = -2715321533384426365L;

  /**
   * Enum to define the type of attribute modification. See {@link
   * javax.naming.directory.DirContext}.
   */
  public enum AttributeModification {

    /** add an attribute. */
    ADD(DirContext.ADD_ATTRIBUTE),

    /** replace an attribute. */
    REPLACE(DirContext.REPLACE_ATTRIBUTE),

    /** remove an attribute. */
    REMOVE(DirContext.REMOVE_ATTRIBUTE);


    /** underlying modification operation integer. */
    private int modOp;


    /**
     * Creates a new AttributeModification with the supplied
     * integer.
     *
     * @param  i  modification operation
     */
    AttributeModification(final int i)
    {
      this.modOp = i;
    }


    /**
     * Returns the modification operation integer.
     *
     * @return  int
     */
    public int modOp()
    {
      return this.modOp;
    }


    /**
     * Method to convert a JNDI constant value to an enum. Returns null if the
     * supplied constant does not match a valid value.
     *
     * @param  i  modification operation
     *
     * @return  attribute modification
     */
    public static AttributeModification parseModificationOperation(final int i)
    {
      AttributeModification am = null;
      if (ADD.modOp() == i) {
        am = ADD;
      } else if (REPLACE.modOp() == i) {
        am = REPLACE;
      } else if (REMOVE.modOp() == i) {
        am = REMOVE;
      }
      return am;
    }
  }

  /** Default constructor. */
  public Ldap() {}


  /**
   * This will create a new Ldap with the supplied 
   * LdapConfig.
   *
   * @param  ldapConfig  LdapConfig
   */
  public Ldap(final LdapConfig ldapConfig)
  {
    this.setLdapConfig(ldapConfig);
  }


  /** {@inheritDoc} */
  public void setLdapConfig(final LdapConfig ldapConfig)
  {
    super.setLdapConfig(ldapConfig);
  }


  /**
   * This returns the LdapConfig of the Ldap.
   *
   * @return  LdapConfig
   */
  public LdapConfig getLdapConfig()
  {
    return this.config;
  }


  /**
   * This will set the config parameters of this Ldap using the
   * default properties file, which must be located in your classpath.
   */
  public void loadFromProperties()
  {
    this.setLdapConfig(LdapConfig.createFromProperties(null));
  }


  /**
   * This will set the config parameters of this Ldap using the
   * supplied input stream.
   *
   * @param  is  InputStream
   */
  public void loadFromProperties(final InputStream is)
  {
    this.setLdapConfig(LdapConfig.createFromProperties(is));
  }


  /**
   * This will perform an LDAP compare operation with the supplied filter.
   * {@link LdapConfig#getBaseDn()} is used as the dn to compare. See {@link
   * #compare(String, SearchFilter)}.
   *
   * @param  filter  SearchFilter expression to use for compare
   *
   * @return  boolean - result of compare operation
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public boolean compare(final SearchFilter filter)
    throws NamingException
  {
    return this.compare(this.config.getBaseDn(), filter);
  }


  /**
   * This will perform an LDAP compare operation with the supplied filter and
   * dn.
   *
   * @param  dn  String name to compare
   * @param  filter  SearchFilter expression to use for compare
   *
   * @return  boolean - result of compare operation
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public boolean compare(final String dn, final SearchFilter filter)
    throws NamingException
  {
    return
      super.compare(dn, filter.getFilter(), filter.getFilterArgs().toArray());
  }


  /**
   * This will query the LDAP with the supplied filter. All attributes will be
   * returned. {@link LdapConfig#getBaseDn()} is used as the start point for
   * searching. Search controls will be created from {@link
   * LdapConfig#getSearchControls(String[])}. See {@link
   * #search(String,SearchFilter,String[])}.
   *
   * @param  filter  SearchFilter expression to use for the search
   *
   * @return  Iterator - of LDAP search results
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Iterator search(final SearchFilter filter)
    throws NamingException
  {
    return
      this.search(
        this.config.getBaseDn(),
        filter,
        this.config.getSearchControls(null));
  }


  /**
   * This will query the LDAP with the supplied filter and return attributes.
   * {@link LdapConfig#getBaseDn()} is used as the start point for searching.
   * Search controls will be created from {@link
   * LdapConfig#getSearchControls(String[])}. See {@link
   * #search(String,SearchFilter,String[])}.
   *
   * @param  filter  SearchFilter expression to use for the search
   * @param  retAttrs  String[] attributes to return
   *
   * @return  Iterator - of LDAP search results
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Iterator search(
    final SearchFilter filter,
    final String[] retAttrs)
    throws NamingException
  {
    return
      this.search(
        this.config.getBaseDn(),
        filter,
        this.config.getSearchControls(retAttrs));
  }


  /**
   * This will query the LDAP with the supplied filter and search controls.
   * {@link LdapConfig#getBaseDn()} is used as the start point for searching.
   * See {@link #search(String,SearchFilter,SearchControls)}.
   *
   * @param  filter  SearchFilter expression to use for the search
   * @param  searchControls  SearchControls to search with
   *
   * @return  Iterator - of LDAP search results
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Iterator search(
    final SearchFilter filter,
    final SearchControls searchControls)
    throws NamingException
  {
    return this.search(this.config.getBaseDn(), filter, searchControls);
  }


  /**
   * This will query the LDAP with the supplied dn and filter. All attributes
   * will be returned. Search controls will be created from {@link
   * LdapConfig#getSearchControls(String[])}. See {@link
   * #search(String,SearchFilter,String[])}.
   *
   * @param  dn  String name to begin search at
   * @param  filter  SearchFilter expression to use for the search
   *
   * @return  Iterator - of LDAP search results
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Iterator search(
    final String dn,
    final SearchFilter filter)
    throws NamingException
  {
    return this.search(dn, filter, this.config.getSearchControls(null));
  }


  /**
   * This will query the LDAP with the supplied dn, filter, and return
   * attributes. Search controls will be created from {@link
   * LdapConfig#getSearchControls(String[])}. See {@link
   * #search(String,SearchFilter,SearchControls,SearchResultHandler[])}.
   *
   * @param  dn  String name to begin search at
   * @param  filter  SearchFilter expression to use for the search
   * @param  retAttrs  String[] attributes to return
   *
   * @return  Iterator - of LDAP search results
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Iterator search(
    final String dn,
    final SearchFilter filter,
    final String[] retAttrs)
    throws NamingException
  {
    return
      this.search(
        dn,
        filter,
        this.config.getSearchControls(retAttrs),
        this.config.getSearchResultHandlers());
  }


  /**
   * This will query the LDAP with the supplied dn, filter, and search controls.
   * See {@link
   * #search(String,SearchFilter,SearchControls,SearchResultHandler[])}.
   *
   * @param  dn  String name to begin search at
   * @param  filter  SearchFilter expression to use for the search
   * @param  searchControls  SearchControls to search with
   *
   * @return  Iterator - of LDAP search results
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Iterator search(
    final String dn,
    final SearchFilter filter,
    final SearchControls searchControls)
    throws NamingException
  {
    return
      this.search(
        dn,
        filter,
        searchControls,
        this.config.getSearchResultHandlers());
  }


  /**
   * This will query the LDAP with the supplied dn, filter, return attributes,
   * and search result handler. Search controls will be created from {@link
   * LdapConfig#getSearchControls(String[])}. See {@link #search(
   * String,SearchFilter,SearchControls,SearchResultHandler...)}.
   *
   * @param  dn  String name to begin search at
   * @param  filter  SearchFilter expression to use for the search
   * @param  retAttrs  String[] attributes to return
   * @param  handler  SearchResultHandler[] of handlers to execute
   *
   * @return  Iterator - of LDAP search results
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Iterator search(
    final String dn,
    final SearchFilter filter,
    final String[] retAttrs,
    final SearchResultHandler... handler)
    throws NamingException
  {
    return
      this.search(dn, filter, this.config.getSearchControls(retAttrs), handler);
  }


  /**
   * This will query the LDAP with the supplied dn, filter, search controls, and
   * search result handler. If {@link LdapConfig#getPagedResultsSize()} is
   * greater than 0, the PagedResultsControl will be invoked. See {@link
   * AbstractLdap
   * #search(String,String,Object[],SearchControls,SearchResultHandler[])}.
   *
   * @param  dn  String name to begin search at
   * @param  filter  SearchFilter expression to use for the search
   * @param  searchControls  SearchControls to search with
   * @param  handler  SearchResultHandler[] of handlers to execute
   *
   * @return  Iterator - of LDAP search results
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Iterator search(
    final String dn,
    final SearchFilter filter,
    final SearchControls searchControls,
    final SearchResultHandler... handler)
    throws NamingException
  {
    if (handler != null && handler.length > 0) {
      for (SearchResultHandler h : handler) {
        if (ExtendedSearchResultHandler.class.isInstance(h)) {
          ((ExtendedSearchResultHandler) h).setSearchResultLdap(this);
        }

        final AttributeHandler[] attrHandler = h.getAttributeHandler();
        if (attrHandler != null && attrHandler.length > 0) {
          for (AttributeHandler ah : attrHandler) {
            if (ExtendedAttributeHandler.class.isInstance(ah)) {
              ((ExtendedAttributeHandler) ah).setSearchResultLdap(this);
            }
          }
        }
      }
    }
    if (this.config.getPagedResultsSize() > 0) {
      return
        super.pagedSearch(
          dn,
          filter.getFilter(),
          filter.getFilterArgs().toArray(),
          searchControls,
          handler);
    } else {
      return
        super.search(
          dn,
          filter.getFilter(),
          filter.getFilterArgs().toArray(),
          searchControls,
          handler);
    }
  }


  /**
   * This will query the LDAP for the supplied matching attributes. All
   * attributes will be returned. {@link LdapConfig#getBaseDn()} is used as the
   * name to search.
   * See {@link #searchAttributes(String, Attributes, String[])}.
   *
   * @param  matchAttrs  Attributes attributes to match
   *
   * @return  Iterator - of LDAP search results
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Iterator searchAttributes(final Attributes matchAttrs)
    throws NamingException
  {
    return this.searchAttributes(this.config.getBaseDn(), matchAttrs, null);
  }


  /**
   * This will query the LDAP for the supplied matching attributes and return
   * attributes. {@link LdapConfig#getBaseDn()} is used as the name to search.
   * See {@link #searchAttributes(String, Attributes, String[])}.
   *
   * @param  matchAttrs  Attributes attributes to match
   * @param  retAttrs  String[] attributes to return
   *
   * @return  Iterator - of LDAP search results
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Iterator searchAttributes(
    final Attributes matchAttrs,
    final String[] retAttrs)
    throws NamingException
  {
    return this.searchAttributes(this.config.getBaseDn(), matchAttrs, retAttrs);
  }


  /**
   * This will query the LDAP for the supplied dn and matching attributes. All
   * attributes will be returned. See {@link #searchAttributes(String,
   * Attributes, String[])}.
   *
   * @param  dn  String name to search in
   * @param  matchAttrs  Attributes attributes to match
   *
   * @return  Iterator - of LDAP search results
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Iterator searchAttributes(
    final String dn,
    final Attributes matchAttrs)
    throws NamingException
  {
    return this.searchAttributes(dn, matchAttrs, null);
  }


  /**
   * This will query the LDAP for the supplied dn, matching attributes and
   * return attributes. See {@link #searchAttributes( String, Attributes,
   * String[], SearchResultHandler[])}. This method converts relative DNs to
   * fully qualified DNs, no post processing is required
   *
   * @param  dn  String name to search in
   * @param  matchAttrs  Attributes attributes to match
   * @param  retAttrs  String[] attributes to return
   *
   * @return  Iterator - of LDAP search results
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Iterator searchAttributes(
    final String dn,
    final Attributes matchAttrs,
    final String[] retAttrs)
    throws NamingException
  {
    return
      this.searchAttributes(
        dn,
        matchAttrs,
        retAttrs,
        this.config.getSearchResultHandlers());
  }


  /** {@inheritDoc} */
  public Iterator searchAttributes(
    final String dn,
    final Attributes matchAttrs,
    final String[] retAttrs,
    final SearchResultHandler... handler)
    throws NamingException
  {
    if (handler != null && handler.length > 0) {
      for (SearchResultHandler h : handler) {
        if (ExtendedSearchResultHandler.class.isInstance(h)) {
          ((ExtendedSearchResultHandler) h).setSearchResultLdap(this);
        }

        final AttributeHandler[] attrHandler = h.getAttributeHandler();
        if (attrHandler != null && attrHandler.length > 0) {
          for (AttributeHandler ah : attrHandler) {
            if (ExtendedAttributeHandler.class.isInstance(ah)) {
              ((ExtendedAttributeHandler) ah).setSearchResultLdap(this);
            }
          }
        }
      }
    }
    return super.searchAttributes(dn, matchAttrs, retAttrs, handler);
  }


  /** {@inheritDoc} */
  public Iterator list(final String dn)
    throws NamingException
  {
    return super.list(dn);
  }


  /** {@inheritDoc} */
  public Iterator listBindings(final String dn)
    throws NamingException
  {
    return super.listBindings(dn);
  }


  /**
   * This will return all the attributes associated with the supplied dn. See
   * {@link #getAttributes(String, String[])}.
   *
   * @param  dn  String named object in the LDAP
   *
   * @return  Attributes
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Attributes getAttributes(final String dn)
    throws NamingException
  {
    return this.getAttributes(dn, null);
  }


  /**
   * This will return the matching attributes associated with the supplied dn.
   * If retAttrs is null then all attributes will be returned. If retAttrs is an
   * empty array then no attributes will be returned. See {@link
   * #getAttributes(String, String[], AttributeHandler[])}.
   *
   * @param  dn  String named object in the LDAP
   * @param  retAttrs  String[] attributes to return
   *
   * @return  Attributes
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public Attributes getAttributes(final String dn, final String[] retAttrs)
    throws NamingException
  {
    return this.getAttributes(dn, retAttrs, new AttributeHandler[0]);
  }


  /** {@inheritDoc} */
  public Attributes getAttributes(
    final String dn,
    final String[] retAttrs,
    final AttributeHandler... handler)
    throws NamingException
  {
    if (handler != null && handler.length > 0) {
      for (AttributeHandler h : handler) {
        if (ExtendedAttributeHandler.class.isInstance(h)) {
          ((ExtendedAttributeHandler) h).setSearchResultLdap(this);
        }
      }
    }
    return super.getAttributes(dn, retAttrs, handler);
  }


  /** {@inheritDoc} */
  public Iterator getSchema(final String dn)
    throws NamingException
  {
    return super.getSchema(dn);
  }


  /**
   * This will modify the supplied attributes for the supplied value given by
   * the modification operation. See {@link
   * AbstractLdap#modifyAttributes(String, int, Attributes)}.
   *
   * @param  dn  String named object in the LDAP
   * @param  mod  AttributeModification modification operation
   * @param  attrs  Attributes attributes to be used for the
   * operation, may be null
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public void modifyAttributes(
    final String dn,
    final AttributeModification mod,
    final Attributes attrs)
    throws NamingException
  {
    super.modifyAttributes(dn, mod.modOp(), attrs);
  }


  /** {@inheritDoc} */
  public void modifyAttributes(final String dn, final ModificationItem[] mods)
    throws NamingException
  {
    super.modifyAttributes(dn, mods);
  }


  /** {@inheritDoc} */
  public void create(final String dn, final Attributes attrs)
    throws NamingException
  {
    super.create(dn, attrs);
  }


  /** {@inheritDoc} */
  public void rename(final String oldDn, final String newDn)
    throws NamingException
  {
    super.rename(oldDn, newDn);
  }


  /** {@inheritDoc} */
  public void delete(final String dn)
    throws NamingException
  {
    super.delete(dn);
  }


  /**
   * This will return a list of SASL mechanisms that this LDAP supports.
   *
   * @return  String[] - supported SASL mechanisms
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public String[] getSaslMechanisms()
    throws NamingException
  {
    final Attributes attrs = this.getAttributes(
      "",
      new String[] {LdapConstants.SUPPORTED_SASL_MECHANISMS});

    String[] results = new String[0];
    if (attrs != null) {
      final Attribute attr = attrs.get(LdapConstants.SUPPORTED_SASL_MECHANISMS);
      if (attr != null) {
        results = (String[]) COPY_RESULT_HANDLER.process(
          new SearchCriteria(""),
          attr.getAll()).toArray(results);
      }
    }

    return results;
  }


  /**
   * This will return a list of controls that this LDAP supports.
   *
   * @return  String[] - supported controls
   *
   * @throws  NamingException  if the LDAP returns an error
   */
  public String[] getSupportedControls()
    throws NamingException
  {
    final Attributes attrs = this.getAttributes(
      "",
      new String[] {LdapConstants.SUPPORTED_CONTROL});

    String[] results = new String[0];
    if (attrs != null) {
      final Attribute attr = attrs.get(LdapConstants.SUPPORTED_CONTROL);
      if (attr != null) {
        results = (String[]) COPY_RESULT_HANDLER.process(
          new SearchCriteria(""),
          attr.getAll()).toArray(results);
      }
    }

    return results;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy