/*******************************************************************************
* Open Behavioral Health Information Technology Architecture (OBHITA.org)
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* * Neither the name of the <organization> nor the
* names of its contributors may be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
******************************************************************************/
package gov.samhsa.consent2share.domain.valueset;
import java.util.List;
import javax.persistence.AttributeOverride;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.OneToMany;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.hibernate.envers.Audited;
import org.hibernate.envers.NotAudited;
@Entity
@Audited
@AttributeOverride(name = "code", column = @Column(name = "code", unique = true, nullable = false))
public class ValueSetCategory extends AbstractNode {
@Id
@GeneratedValue
@Column(name = "valueset_cat_id")
private Long id;
@Column(name = "description", length = 5000)
private String description;
/*
* ValueSet has Composition Relation with ValueSetCategory If
* ValueSetCategory is destroyed or ValueSet is removed from
* ValueSetCategory's collection Then ValueSetCategory is destroyed
* automatically
*/
@OneToMany(mappedBy = "valueSetCategory", orphanRemoval = true)
@NotAudited
private List<ValueSet> valueSets;
// it is required by Hibernate
public ValueSetCategory() {
}
/**
* A Builder class used to create new CodeSystem objects.
*/
public static class Builder {
ValueSetCategory built;
/**
* Creates a new Builder instance.
*
* @param code
* The code of the created ValueSetCategory object.
* @param name
* The name of the created ValueSetCategory object.
* @param userName
* The User who created ValueSetCategory object.
*/
Builder(String code, String name, String userName) {
built = new ValueSetCategory();
built.code = code;
built.name = name;
built.userName = userName;
}
/**
* Builds the new CodeSystem object.
*
* @return The created CodeSystem object.
*/
public ValueSetCategory build() {
return built;
}
// optional
public Builder description(String description) {
built.setDescription(description);
return this;
}
}
/**
* Creates a new Builder instance.
*
* @param code
* The code of the created ValueSetCategory object.
* @param name
* The name of the created ValueSetCategory object.
* @param userName
* The User who created ValueSetCategory object.
*/
public static Builder getBuilder(String code, String name, String userName) {
return new Builder(code, name, userName);
}
/**
* Updates a ValueSetCategory instance.
*
* @param code
* The code of the created ValueSetCategory object.
* @param name
* The name of the created ValueSetCategory object.
* @param userName
* The User who created ValueSetCategory object.
*
*/
public void update(String code, String name, String description,
String userName) {
this.code = code;
this.name = name;
this.description = description;
this.userName = userName;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public List<ValueSet> getValueSets() {
return valueSets;
}
public void setValueSets(List<ValueSet> valueSets) {
this.valueSets = valueSets;
}
@Override
public String toString() {
return ToStringBuilder.reflectionToString(this);
}
}