org.hibernate.search.cfg.EntityMapping Maven / Gradle / Ivy
/*
* Hibernate Search, full-text search for your domain model
*
* License: GNU Lesser General Public License (LGPL), version 2.1 or later
* See the lgpl.txt file in the root directory or .
*/
package org.hibernate.search.cfg;
import java.lang.annotation.ElementType;
import java.util.HashMap;
import java.util.Map;
import org.apache.lucene.analysis.util.TokenizerFactory;
import org.hibernate.search.analyzer.Discriminator;
import org.hibernate.search.bridge.FieldBridge;
import org.hibernate.search.engine.BoostStrategy;
/**
* @author Emmanuel Bernard
*/
public class EntityMapping {
private final SearchMapping mapping;
private final EntityDescriptor entity;
public EntityMapping(Class> entityType, SearchMapping mapping) {
this.mapping = mapping;
entity = mapping.getEntity( entityType );
}
public IndexedMapping indexed() {
return new IndexedMapping( mapping, entity );
}
public EntitySpatialMapping spatial() {
return new EntitySpatialMapping( mapping, entity );
}
public EntityMapping boost(float boost) {
final Map boostAnn = new HashMap();
boostAnn.put( "value", boost );
entity.setBoost( boostAnn );
return this;
}
/**
* @param impl The class for an implementation of {@link BoostStrategy}.
* @return this mapping, for chained calls.
*
* @deprecated Index-time boosting will not be possible anymore starting from Lucene 7.
* You should use query-time boosting instead, for instance by calling
* {@link org.hibernate.search.query.dsl.FieldCustomization#boostedTo(float) boostedTo(float)}
* when building queries with the Hibernate Search query DSL.
*/
@Deprecated
public EntityMapping dynamicBoost(Class extends BoostStrategy> impl) {
final Map dynamicBoost = new HashMap();
dynamicBoost.put( "impl", impl );
entity.setDynamicBoost( dynamicBoost );
return this;
}
public EntityMapping analyzerDiscriminator(Class extends Discriminator> discriminator) {
final Map discriminatorAnn = new HashMap();
discriminatorAnn.put( "impl", discriminator );
entity.setAnalyzerDiscriminator( discriminatorAnn );
return this;
}
public FullTextFilterDefMapping fullTextFilterDef(String name, Class> impl) {
return new FullTextFilterDefMapping( mapping, name, impl );
}
public PropertyMapping property(String name, ElementType type) {
return new PropertyMapping( name, type, entity, mapping );
}
public AnalyzerDefMapping analyzerDef(String name, Class extends TokenizerFactory> tokenizerFactory) {
return analyzerDef( name, "", tokenizerFactory );
}
public AnalyzerDefMapping analyzerDef(String name, String tokenizerName, Class extends TokenizerFactory> tokenizerFactory) {
return new AnalyzerDefMapping( name, tokenizerName, tokenizerFactory, mapping );
}
public NormalizerDefMapping normalizerDef(String name) {
return new NormalizerDefMapping( name, mapping );
}
public EntityMapping entity(Class> entityType) {
return new EntityMapping( entityType, mapping );
}
public ClassBridgeMapping classBridge(Class> impl) {
return new ClassBridgeMapping( mapping, entity, impl );
}
/**
* Registers the given class bridge for the currently configured entity type. Any subsequent analyzer, parameter
* etc. configurations apply to this class bridge.
*
* @param classBridge a class bridge instance
* @return a new {@link ClassBridgeMapping} following the method chaining pattern
* @hsearch.experimental This method is considered experimental and it may be altered or removed in future releases
* @throws org.hibernate.search.exception.SearchException in case the same bridge instance is passed more than once for the
* currently configured entity type
*/
public ClassBridgeMapping classBridgeInstance(FieldBridge classBridge) {
return new ClassBridgeMapping( mapping, entity, classBridge );
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy