/**
* Copyright or © or Copr. Ministère Français chargé de la Culture
* et de la Communication (2013)
*
* contact.gincoculture_at_gouv.fr
*
* This software is a computer program whose purpose is to provide a thesaurus
* management solution.
*
* This software is governed by the CeCILL license under French law and
* abiding by the rules of distribution of free software. You can use,
* modify and/ or redistribute the software under the terms of the CeCILL
* license as circulated by CEA, CNRS and INRIA at the following URL
* "http://www.cecill.info".
*
* As a counterpart to the access to the source code and rights to copy,
* modify and redistribute granted by the license, users are provided only
* with a limited warranty and the software's author, the holder of the
* economic rights, and the successive licensors have only limited liability.
*
* In this respect, the user's attention is drawn to the risks associated
* with loading, using, modifying and/or developing or reproducing the
* software by the user in light of its specific status of free software,
* that may mean that it is complicated to manipulate, and that also
* therefore means that it is reserved for developers and experienced
* professionals having in-depth computer knowledge. Users are therefore
* encouraged to load and test the software's suitability as regards their
* requirements in conditions enabling the security of their systems and/or
* data to be ensured and, more generally, to use and operate it in the
* same conditions as regards security.
*
* The fact that you are presently reading this means that you have had
* knowledge of the CeCILL license and that you accept its terms.
*/
package fr.mcc.ginco.beans;
import java.io.Serializable;
import java.util.Date;
import java.util.HashSet;
import java.util.Set;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlTransient;
import org.hibernate.envers.Audited;
import org.hibernate.envers.RelationTargetAuditMode;
/**
* Bean represents <b>thesaurus_concept</b> table, is container for
* {@link ThesaurusTerm}.
*/
@Audited(targetAuditMode = RelationTargetAuditMode.NOT_AUDITED, withModifiedFlag = true)
@XmlAccessorType(XmlAccessType.FIELD)
public class ThesaurusConcept implements Serializable, IAuditableBean {
private String identifier;
private Date created;
private Date modified;
private Integer status;
private String notation;
private Boolean topConcept;
@XmlTransient
private Thesaurus thesaurus;
@XmlTransient
private Set<ThesaurusConcept> parentConcepts = new HashSet<ThesaurusConcept>();
@XmlTransient
private Set<ThesaurusConcept> rootConcepts = new HashSet<ThesaurusConcept>();
@XmlTransient
private Set<AssociativeRelationship> associativeRelationshipLeft;
@XmlTransient
private Set<AssociativeRelationship> associativeRelationshipRight;
@XmlTransient
private Set<ThesaurusArray> conceptArrays;
public String getIdentifier() {
return identifier;
}
public void setIdentifier(String identifier) {
this.identifier = identifier;
}
public Date getCreated() {
return created;
}
public void setCreated(Date created) {
this.created = created;
}
public Date getModified() {
return modified;
}
public void setModified(Date modified) {
this.modified = modified;
}
public Integer getStatus() {
return status;
}
public void setStatus(Integer status) {
this.status = status;
}
public String getNotation() {
return notation;
}
public void setNotation(String notation) {
this.notation = notation;
}
public Boolean getTopConcept() {
return topConcept;
}
public void setTopConcept(Boolean topConcept) {
this.topConcept = topConcept;
}
public Thesaurus getThesaurus() {
return thesaurus;
}
public void setThesaurus(Thesaurus thesaurus) {
this.thesaurus = thesaurus;
}
public Set<ThesaurusConcept> getParentConcepts() {
return parentConcepts;
}
public void setParentConcepts(Set<ThesaurusConcept> parentConcepts) {
this.parentConcepts = parentConcepts;
}
public Set<ThesaurusConcept> getRootConcepts() {
return rootConcepts;
}
public void setRootConcepts(Set<ThesaurusConcept> rootConcepts) {
this.rootConcepts = rootConcepts;
}
public Set<AssociativeRelationship> getAssociativeRelationshipLeft() {
return associativeRelationshipLeft;
}
public void setAssociativeRelationshipLeft(
Set<AssociativeRelationship> associativeRelationshipLeft) {
this.associativeRelationshipLeft = associativeRelationshipLeft;
}
public Set<AssociativeRelationship> getAssociativeRelationshipRight() {
return associativeRelationshipRight;
}
public void setAssociativeRelationshipRight(
Set<AssociativeRelationship> associativeRelationshipRight) {
this.associativeRelationshipRight = associativeRelationshipRight;
}
@Override
public String getThesaurusId() {
return thesaurus.getIdentifier();
}
public Set<ThesaurusArray> getConceptArrays() {
return conceptArrays;
}
public void setConceptArrays(Set<ThesaurusArray> conceptArrays) {
this.conceptArrays = conceptArrays;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
if (identifier == null) {
result = prime * result
+ 0;
} else {
result = prime * result
+ identifier.hashCode();
}
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (getClass() != obj.getClass()) {
return false;
}
ThesaurusConcept other = (ThesaurusConcept) obj;
if (identifier == null) {
if (other.identifier != null) {
return false;
}
} else if (!identifier.equals(other.identifier)) {
return false;
}
return true;
}
}