Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

TRUNK-5924 : PatientIdentifier Domain - Switching from Hibernate Mappings to Annotations #4855

Open
wants to merge 7 commits into
base: master
Choose a base branch
from
39 changes: 33 additions & 6 deletions api/src/main/java/org/openmrs/PatientIdentifier.java
Original file line number Diff line number Diff line change
Expand Up @@ -13,22 +13,30 @@
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.Comparator;

import org.hibernate.search.annotations.DocumentId;
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.Table;
import org.hibernate.annotations.Parameter;
import org.codehaus.jackson.annotate.JsonIgnore;
import org.hibernate.envers.Audited;
import org.hibernate.search.annotations.Analyzer;
import org.hibernate.search.annotations.Boost;
import org.hibernate.search.annotations.DocumentId;
import org.hibernate.search.annotations.Field;
import org.hibernate.search.annotations.Fields;
import org.hibernate.search.annotations.Indexed;
import org.hibernate.search.annotations.Fields;
import org.hibernate.search.annotations.IndexedEmbedded;
import org.hibernate.search.annotations.SortableField;
import org.openmrs.api.db.hibernate.search.LuceneAnalyzers;
import org.openmrs.util.OpenmrsUtil;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import org.hibernate.annotations.GenericGenerator;
/**
* A <code>Patient</code> can have zero to n identifying PatientIdentifier(s). PatientIdentifiers
* are anything from medical record numbers, to social security numbers, to driver's licenses. The
Expand All @@ -37,6 +45,8 @@
*
* @see org.openmrs.PatientIdentifierType
*/
@Entity
@Table(name = "patient_identifier")
@Indexed
rishabhrawat05 marked this conversation as resolved.
Show resolved Hide resolved
@Audited
public class PatientIdentifier extends BaseChangeableOpenmrsData implements java.io.Serializable, Cloneable, Comparable<PatientIdentifier> {
Expand All @@ -51,9 +61,19 @@ public class PatientIdentifier extends BaseChangeableOpenmrsData implements java
* @since 1.5
*/
@DocumentId
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
rishabhrawat05 marked this conversation as resolved.
Show resolved Hide resolved
rishabhrawat05 marked this conversation as resolved.
Show resolved Hide resolved
@GenericGenerator(
name = "patient_identifier_id_seq",
strategy = "native",
parameters = @Parameter(name = "sequence", value = "patient_identifier_patient_identifier_id_seq")
)
@Column(name = "patient_identifier_id")
private Integer patientIdentifierId;


@ManyToOne
@IndexedEmbedded(includeEmbeddedObjectId = true)
@JoinColumn(name = "patient_id")
rishabhrawat05 marked this conversation as resolved.
Show resolved Hide resolved
rishabhrawat05 marked this conversation as resolved.
Show resolved Hide resolved
private Patient patient;

@Fields({
Expand All @@ -63,17 +83,24 @@ public class PatientIdentifier extends BaseChangeableOpenmrsData implements java
@Field(name = "identifierAnywhere", analyzer = @Analyzer(definition = LuceneAnalyzers.ANYWHERE_ANALYZER))
})
@SortableField(forField = "identifierExact")
@Column(name = "identifier", length = 50)
private String identifier;

@ManyToOne
@IndexedEmbedded(includeEmbeddedObjectId = true)
@JoinColumn(name = "identifier_type")
rishabhrawat05 marked this conversation as resolved.
Show resolved Hide resolved
rishabhrawat05 marked this conversation as resolved.
Show resolved Hide resolved
private PatientIdentifierType identifierType;

@ManyToOne
@JoinColumn(name = "location_id", nullable = true)
private Location location;

@ManyToOne
@JoinColumn(name = "patient_program_id", nullable = true)
private PatientProgram patientProgram;


@Field
rishabhrawat05 marked this conversation as resolved.
Show resolved Hide resolved
@Column(name = "preferred", nullable = false)
private Boolean preferred = false;

/** default constructor */
Expand Down
5 changes: 2 additions & 3 deletions api/src/main/resources/hibernate.cfg.xml
Original file line number Diff line number Diff line change
Expand Up @@ -59,9 +59,8 @@
<mapping resource="org/openmrs/api/db/hibernate/Privilege.hbm.xml" />
<mapping resource="org/openmrs/api/db/hibernate/Role.hbm.xml" />
<mapping resource="org/openmrs/api/db/hibernate/Patient.hbm.xml" />
<mapping resource="org/openmrs/api/db/hibernate/PatientIdentifier.hbm.xml" />
<mapping resource="org/openmrs/api/db/hibernate/PatientProgram.hbm.xml" />
<mapping resource="org/openmrs/api/db/hibernate/PatientProgramAttribute.hbm.xml" />
<mapping resource="org/openmrs/api/db/hibernate/PatientProgram.hbm.xml" />
<mapping resource="org/openmrs/api/db/hibernate/PatientProgramAttribute.hbm.xml" />
rishabhrawat05 marked this conversation as resolved.
Show resolved Hide resolved
<mapping resource="org/openmrs/api/db/hibernate/RelationshipType.hbm.xml" />
<mapping resource="org/openmrs/api/db/hibernate/Order.hbm.xml" />
<mapping resource="org/openmrs/api/db/hibernate/OrderAttribute.hbm.xml" />
Expand Down

This file was deleted.

2 changes: 2 additions & 0 deletions api/src/test/java/org/openmrs/api/OrderServiceTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@
import org.openmrs.OrderSet;
import org.openmrs.OrderType;
import org.openmrs.Patient;
import org.openmrs.PatientIdentifier;
import org.openmrs.PatientIdentifierType;
import org.openmrs.PatientState;
import org.openmrs.PersonAddress;
Expand Down Expand Up @@ -2740,6 +2741,7 @@ public void saveOrder_shouldFailIfTheJavaTypeOfThePreviousOrderDoesNotMatch() th
.addAnnotatedClass(ProgramAttributeType.class)
.addAnnotatedClass(HL7InError.class)
.addAnnotatedClass(OrderType.class)
.addAnnotatedClass(PatientIdentifier.class)
.getMetadataBuilder().build();


Expand Down