/*
* 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 <http://www.gnu.org/licenses/lgpl-2.1.html>.
*/
package org.hibernate.search.test.bridge;
import java.util.Date;
import javax.persistence.CollectionTable;
import javax.persistence.Column;
import javax.persistence.ElementCollection;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OrderColumn;
import javax.persistence.Table;
import org.hibernate.search.annotations.Analyze;
import org.hibernate.search.annotations.DateBridge;
import org.hibernate.search.annotations.Field;
import org.hibernate.search.annotations.Indexed;
import org.hibernate.search.annotations.IndexedEmbedded;
import org.hibernate.search.annotations.Resolution;
import org.hibernate.search.annotations.Store;
/**
* @author Davide D'Alto
*/
@Entity
@Indexed
@Table(name = "ABT_Entity")
public class ArrayBridgeTestEntity {
static final String NULL_TOKEN = "NULL_MARKER";
static final String NULL_NUMERIC_TOKEN = "-555";
private Long id;
private String name;
private Language[] nullIndexed = new Language[0];
private String[] nullNotIndexed = new String[0];
private Integer[] numericNullIndexed = new Integer[0];
private Long[] numericNullNotIndexed = new Long[0];
private float[] primitive = new float[0];
private Date[] dates = new Date[0];
public enum Language {
ITALIAN, ENGLISH, PIRATE, KLINGON
}
@Id
@GeneratedValue
@Column(name = "array_id")
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
@Column(name = "name")
@Field(store = Store.YES)
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Field(indexNullAs = NULL_TOKEN, analyze = Analyze.NO)
@ElementCollection
@IndexedEmbedded
@OrderColumn
@CollectionTable(name = "NullIndexed", joinColumns = @JoinColumn(name = "array_id"))
@Column(name = "nullIndexed")
public Language[] getNullIndexed() {
return nullIndexed;
}
public void setNullIndexed(Language[] nullIndexed) {
this.nullIndexed = nullIndexed;
}
@Field(store = Store.YES, indexNullAs = NULL_NUMERIC_TOKEN, analyze = Analyze.NO)
@ElementCollection
@IndexedEmbedded
@OrderColumn
@CollectionTable(name = "NumericNullIndexed", joinColumns = @JoinColumn(name = "array_id"))
@Column(name = "numericNullIndexed")
public Integer[] getNumericNullIndexed() {
return numericNullIndexed;
}
public void setNumericNullIndexed(Integer[] phoneNumbers) {
this.numericNullIndexed = phoneNumbers;
}
@Field(store = Store.YES)
@ElementCollection
@IndexedEmbedded
@OrderColumn
@CollectionTable(name = "NullNotIndexed", joinColumns = @JoinColumn(name = "array_id"))
@Column(name = "nullNotIndexed")
public String[] getNullNotIndexed() {
return nullNotIndexed;
}
public void setNullNotIndexed(String[] skipNullCollection) {
this.nullNotIndexed = skipNullCollection;
}
@Field(store = Store.YES)
@ElementCollection
@IndexedEmbedded
@OrderColumn
@CollectionTable(name = "NumericNullNotIndexed", joinColumns = @JoinColumn(name = "array_id"))
@Column(name = "numericNullNotIndexed")
public Long[] getNumericNullNotIndexed() {
return numericNullNotIndexed;
}
public void setNumericNullNotIndexed(Long[] numericSkipNullCollection) {
this.numericNullNotIndexed = numericSkipNullCollection;
}
@Field(store = Store.YES)
@ElementCollection
@IndexedEmbedded
@OrderColumn
@CollectionTable(name = "primitive", joinColumns = @JoinColumn(name = "array_id"))
@Column(name = "primitive")
public float[] getPrimitive() {
return primitive;
}
public void setPrimitive(float[] primitive) {
this.primitive = primitive;
}
@Field(analyze = Analyze.NO, store = Store.YES)
@ElementCollection
@IndexedEmbedded
@DateBridge(resolution = Resolution.SECOND)
@OrderColumn
@CollectionTable(name = "Dates", joinColumns = @JoinColumn(name = "array_id"))
@Column(name = "dates")
public Date[] getDates() {
return dates;
}
public void setDates(Date[] dates) {
this.dates = dates;
}
@Override
public String toString() {
return ArrayBridgeTestEntity.class.getSimpleName() + "[id=" + id + ", name=" + name + "]";
}
}