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

edu.vt.middleware.ldap.handler.MergeSearchResultHandler Maven / Gradle / Ivy

/*
  $Id: MergeSearchResultHandler.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.handler;

import java.util.ArrayList;
import java.util.List;
import javax.naming.NamingEnumeration;
import javax.naming.NamingException;
import javax.naming.directory.Attribute;
import javax.naming.directory.SearchResult;

/**
 * MergeSearchResultHandler merges the attributes found in each
 * search result into the first search result.
 *
 * @author  Middleware Services
 * @version  $Revision: 1330 $ $Date: 2010-05-23 18:10:53 -0400 (Sun, 23 May 2010) $
 */
public class MergeSearchResultHandler extends CopySearchResultHandler
{

  /** Whether to allow duplicate attribute values. */
  private boolean allowDuplicates;


  /**
   * Returns whether to allow duplicate attribute values.
   *
   * @return  boolean
   */
  public boolean getAllowDuplicates()
  {
    return this.allowDuplicates;
  }


  /**
   * Sets whether to allow duplicate attribute values.
   *
   * @param  b  boolean
   */
  public void setAllowDuplicates(final boolean b)
  {
    this.allowDuplicates = b;
  }


  /** {@inheritDoc} */
  public List process(
    final SearchCriteria sc,
    final NamingEnumeration en,
    final Class[] ignore)
    throws NamingException
  {
    return this.mergeResults(super.process(sc, en, ignore));
  }


  /** {@inheritDoc} */
  public List process(
    final SearchCriteria sc,
    final List l)
    throws NamingException
  {
    return this.mergeResults(super.process(sc, l));
  }


  /**
   * Merges the search results in the supplied list into a single search result.
   * This method always returns a list of size zero or one.
   *
   * @param  results  List of search results to merge
   *
   * @return  List of merged search results
   *
   * @throws  NamingException  if an error occurs reading attribute values
   */
  protected List mergeResults(final List results)
    throws NamingException
  {
    final List mergedResults = new ArrayList();
    SearchResult mergedResult = null;
    for (SearchResult sr : results) {
      if (mergedResult == null) {
        mergedResult = sr;
      } else {
        final NamingEnumeration en = sr.getAttributes()
            .getAll();
        while (en.hasMore()) {
          final Attribute newAttr = en.next();
          final Attribute oldAttr = mergedResult.getAttributes().get(
            newAttr.getID());
          if (oldAttr == null) {
            mergedResult.getAttributes().put(newAttr);
          } else {
            final NamingEnumeration newValues = newAttr.getAll();
            while (newValues.hasMore()) {
              final Object newValue = newValues.next();
              if (this.allowDuplicates) {
                oldAttr.add(newValue);
              } else {
                boolean add = true;
                final NamingEnumeration existingValues = oldAttr.getAll();
                while (existingValues.hasMore()) {
                  final Object existingValue = existingValues.next();
                  if (existingValue.equals(newValue)) {
                    add = false;
                    break;
                  }
                }
                if (add) {
                  oldAttr.add(newValue);
                }
              }
            }
          }
        }
      }
    }
    if (mergedResult != null) {
      mergedResults.add(mergedResult);
    }
    return mergedResults;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy