/*
 * Hibernate, Relational Persistence for Idiomatic Java
 *
 * Copyright (c) 2008-2011, Red Hat Inc. or third-party contributors as
 * indicated by the @author tags or express copyright attribution
 * statements applied by the authors.  All third-party contributions are
 * distributed under license by Red Hat Inc.
 *
 * This copyrighted material is made available to anyone wishing to use, modify,
 * copy, or redistribute it subject to the terms and conditions of the GNU
 * Lesser General Public License, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License
 * for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this distribution; if not, write to:
 * Free Software Foundation, Inc.
 * 51 Franklin Street, Fifth Floor
 * Boston, MA  02110-1301  USA
 */
package org.hibernate.engine.spi;

import java.io.Serializable;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;

import org.hibernate.type.Type;

A FilterDefinition defines the global attributes of a dynamic filter. This information includes its name as well as its defined parameters (name and type).
Author:Steve Ebersole
/** * A FilterDefinition defines the global attributes of a dynamic filter. This * information includes its name as well as its defined parameters (name and type). * * @author Steve Ebersole */
public class FilterDefinition implements Serializable { private final String filterName; private final String defaultFilterCondition; private final Map<String, Type> parameterTypes = new HashMap<String, Type>();
Construct a new FilterDefinition instance.
Params:
  • name – The name of the filter for which this configuration is in effect.
/** * Construct a new FilterDefinition instance. * * @param name The name of the filter for which this configuration is in effect. */
public FilterDefinition(String name, String defaultCondition, Map<String, Type> parameterTypes) { this.filterName = name; this.defaultFilterCondition = defaultCondition; this.parameterTypes.putAll( parameterTypes ); }
Get the name of the filter this configuration defines.
Returns:The filter name for this configuration.
/** * Get the name of the filter this configuration defines. * * @return The filter name for this configuration. */
public String getFilterName() { return filterName; }
Get a set of the parameters defined by this configuration.
Returns:The parameters named by this configuration.
/** * Get a set of the parameters defined by this configuration. * * @return The parameters named by this configuration. */
public Set<String> getParameterNames() { return parameterTypes.keySet(); }
Retrieve the type of the named parameter defined for this filter.
Params:
  • parameterName – The name of the filter parameter for which to return the type.
Returns:The type of the named parameter.
/** * Retrieve the type of the named parameter defined for this filter. * * @param parameterName The name of the filter parameter for which to return the type. * * @return The type of the named parameter. */
public Type getParameterType(String parameterName) { return parameterTypes.get( parameterName ); } public String getDefaultFilterCondition() { return defaultFilterCondition; } public Map<String, Type> getParameterTypes() { return parameterTypes; } }