package fi.otavanopisto.pyramus.domainmodel.base; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.ManyToOne; import javax.persistence.TableGenerator; import javax.persistence.Version; import javax.validation.constraints.NotNull; import org.hibernate.search.annotations.DocumentId; import org.hibernate.search.annotations.Field; import org.hibernate.search.annotations.Indexed; import org.hibernate.search.annotations.Store; @Entity @Indexed public class Address { public Long getId() { return id; } public String getPostalCode() { return postalCode; } public String getStreetAddress() { return streetAddress; } public void setPostalCode(String postalCode) { this.postalCode = postalCode; } public void setStreetAddress(String streetAddress) { this.streetAddress = streetAddress; } public String getCountry() { return country; } public void setCountry(String country) { this.country = country; } public String getCity() { return city; } public void setCity(String city) { this.city = city; } public void setName(String name) { this.name = name; } public String getName() { return name; } public void setContactType(ContactType contactType) { this.contactType = contactType; } public ContactType getContactType() { return contactType; } public void setDefaultAddress(Boolean defaultAddress) { this.defaultAddress = defaultAddress; } public Boolean getDefaultAddress() { return defaultAddress; } public void setContactInfo(ContactInfo contactInfo) { this.contactInfo = contactInfo; } public ContactInfo getContactInfo() { return contactInfo; } @SuppressWarnings("unused") private void setVersion(Long version) { this.version = version; } public Long getVersion() { return version; } @Id @GeneratedValue(strategy=GenerationType.TABLE, generator="Address") @TableGenerator(name="Address", allocationSize=1, table = "hibernate_sequences", pkColumnName = "sequence_name", valueColumnName = "sequence_next_hi_value") @DocumentId private Long id; @NotNull @Column(nullable = false) @Field private Boolean defaultAddress = Boolean.FALSE; @ManyToOne @JoinColumn (name = "contactType") private ContactType contactType; @Field (store = Store.NO) private String name; @Field (store = Store.NO) private String streetAddress; @Field (store = Store.NO) private String postalCode; @Field (store = Store.NO) private String city; @Field (store = Store.NO) private String country; @ManyToOne @JoinColumn(name="contactInfo", insertable=false, updatable=false) private ContactInfo contactInfo; @Version @Column(nullable = false) private Long version; }