Open Source Repository

Home /hibernate/hibernate-3.2.4.ga | Repository Home



org/hibernate/impl/FilterImpl.java
// $Id: FilterImpl.java 8754 2005-12-05 23:36:59Z steveebersole $
package org.hibernate.impl;

import java.io.Serializable;
import java.util.Arrays;
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;

import org.hibernate.Filter;
import org.hibernate.HibernateException;
import org.hibernate.engine.FilterDefinition;
import org.hibernate.type.Type;

/**
 * Implementation of FilterImpl.  FilterImpl implements the user's
 * view into enabled dynamic filters, allowing them to set filter parameter values.
 *
 @author Steve Ebersole
 */
public class FilterImpl implements Filter, Serializable {
  public static final String MARKER = "$FILTER_PLACEHOLDER$";

  private transient FilterDefinition definition;
  private String filterName;
  private Map parameters = new HashMap();
  
  void afterDeserialize(SessionFactoryImpl factory) {
    definition = factory.getFilterDefinition(filterName);
  }

  /**
   * Constructs a new FilterImpl.
   *
   @param configuration The filter's global configuration.
   */
  public FilterImpl(FilterDefinition configuration) {
    this.definition = configuration;
    filterName = definition.getFilterName();
  }

  public FilterDefinition getFilterDefinition() {
    return definition;
  }

  /**
   * Get the name of this filter.
   *
   @return This filter's name.
   */
  public String getName() {
    return definition.getFilterName();
  }
  
  public Map getParameters() {
    return parameters;
  }

  /**
   * Set the named parameter's value for this filter.
   *
   @param name The parameter's name.
   @param value The value to be applied.
   @return This FilterImpl instance (for method chaining).
   @throws IllegalArgumentException Indicates that either the parameter was undefined or that the type
   * of the passed value did not match the configured type.
   */
  public Filter setParameter(String name, Object valuethrows IllegalArgumentException {
    // Make sure this is a defined parameter and check the incoming value type
    // TODO: what should be the actual exception type here?
    Type type = definition.getParameterTypename );
    if type == null ) {
      throw new IllegalArgumentException"Undefined filter parameter [" + name + "]" );
    }
    if value != null && !type.getReturnedClass().isAssignableFromvalue.getClass() ) ) {
      throw new IllegalArgumentException"Incorrect type for parameter [" + name + "]" );
    }
    parameters.putname, value );
    return this;
  }

  /**
   * Set the named parameter's value list for this filter.  Used
   * in conjunction with IN-style filter criteria.
   *
   @param name   The parameter's name.
   @param values The values to be expanded into an SQL IN list.
   @return This FilterImpl instance (for method chaining).
   */
  public Filter setParameterList(String name, Collection valuesthrows HibernateException  {
    // Make sure this is a defined parameter and check the incoming value type
    if values == null ) {
      throw new IllegalArgumentException"Collection must be not null!" );
    }
    Type type = definition.getParameterTypename );
    if type == null ) {
      throw new HibernateException"Undefined filter parameter [" + name + "]" );
    }
    if values.size() ) {
      Class elementClass = values.iterator().next().getClass();
      if !type.getReturnedClass().isAssignableFromelementClass ) ) {
        throw new HibernateException"Incorrect type for parameter [" + name + "]" );
      }
    }
    parameters.putname, values );
    return this;
  }

  /**
   * Set the named parameter's value list for this filter.  Used
   * in conjunction with IN-style filter criteria.
   *
   @param name The parameter's name.
   @param values The values to be expanded into an SQL IN list.
   @return This FilterImpl instance (for method chaining).
   */
  public Filter setParameterList(String name, Object[] valuesthrows IllegalArgumentException {
    return setParameterListname, Arrays.asListvalues ) );
  }

  /**
   * Get the value of the named parameter for the current filter.
   *
   @param name The name of the parameter for which to return the value.
   @return The value of the named parameter.
   */
  public Object getParameter(String name) {
    return parameters.getname );
  }

  /**
   * Perform validation of the filter state.  This is used to verify the
   * state of the filter after its enablement and before its use.
   *
   @throws HibernateException If the state is not currently valid.
   */
  public void validate() throws HibernateException {
    // for each of the defined parameters, make sure its value
    // has been set
    Iterator itr = definition.getParameterNames().iterator();
    while itr.hasNext() ) {
      final String parameterName = (Stringitr.next();
      if parameters.getparameterName == null ) {
        throw new HibernateException(
            "Filter [" + getName() "] parameter [" + parameterName + "] value not set"
        );
      }
    }
  }
}