/** * 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; } }