use of ca.uhn.hl7v2.HL7Exception in project openmrs-core by openmrs.
the class HL7ServiceTest method getUuidFromIdentifiers_shouldNotFailIfMultipleSimilarUUIDsExistInIdentifiers.
/**
* @throws HL7Exception
* @see HL7Service#getUuidFromIdentifiers(null)
*/
@Test
public void getUuidFromIdentifiers_shouldNotFailIfMultipleSimilarUUIDsExistInIdentifiers() throws HL7Exception {
HL7Service hl7service = Context.getHL7Service();
Message message = hl7service.parseHL7String("MSH|^~\\&|FORMENTRY|AMRS.ELD|HL7LISTENER|AMRS.ELD|20080226102656||ORU^R01|JqnfhKKtouEz8kzTk6Zo|P|2.5|1||||||||16^AMRS.ELD.FORMID\r" + "PID|||3^^^^||John3^Doe^||\r" + "NK1|1|Hornblower^Horatio^L|2B^Sibling^99REL||||||||||||M|19410501|||||||||||||||||2178037d-f86b-4f12-8d8b-be3ebc220022^^^UUID^v4~2178037d-f86b-4f12-8d8b-be3ebc220022^^^UUID^v4||||\r" + "PV1||O|1^Unknown Location||||1^Super User (1-8)|||||||||||||||||||||||||||||||||||||20080212|||||||V\r" + "ORC|RE||||||||20080226102537|1^Super User\r" + "OBR|1|||1238^MEDICAL RECORD OBSERVATIONS^99DCT\r" + "OBX|1|NM|5497^CD4, BY FACS^99DCT||450|||||||||20080206\r" + "OBX|2|DT|5096^RETURN VISIT DATE^99DCT||20080229|||||||||20080212");
ORU_R01 oru = (ORU_R01) message;
List<NK1> nk1List = new ORUR01Handler().getNK1List(oru);
CX[] identifiers = nk1List.get(0).getNextOfKinAssociatedPartySIdentifiers();
String result = hl7service.getUuidFromIdentifiers(identifiers);
Assert.assertEquals("2178037d-f86b-4f12-8d8b-be3ebc220022", result);
}
use of ca.uhn.hl7v2.HL7Exception in project openmrs-core by openmrs.
the class ADTA28Handler method createPatient.
// Create a new patient when this patient doesn't exist in the database
private Patient createPatient(PID pid, String creatorName) throws HL7Exception {
Patient patient = new Patient();
// Try to use the specified username as the creator
User creator = Context.getUserService().getUserByUsername(creatorName);
if (creator != null) {
patient.setCreator(creator);
}
// Create all patient identifiers specified in the message
// Copied code from resolvePatientId() in HL7ServiceImpl.java
CX[] idList = pid.getPatientIdentifierList();
if (idList == null || idList.length < 1) {
throw new HL7Exception("Missing patient identifier in PID segment");
}
List<PatientIdentifier> goodIdentifiers = new ArrayList<>();
for (CX id : idList) {
String assigningAuthority = id.getAssigningAuthority().getNamespaceID().getValue();
String hl7PatientId = id.getIDNumber().getValue();
log.debug("identifier has id=" + hl7PatientId + " assigningAuthority=" + assigningAuthority);
if (assigningAuthority != null && assigningAuthority.length() > 0) {
try {
PatientIdentifierType pit = Context.getPatientService().getPatientIdentifierTypeByName(assigningAuthority);
if (pit == null) {
log.warn("Can't find PatientIdentifierType named '" + assigningAuthority + "'");
// skip identifiers with unknown type
continue;
}
PatientIdentifier pi = new PatientIdentifier();
if (creator != null) {
pi.setCreator(creator);
}
pi.setIdentifierType(pit);
pi.setIdentifier(hl7PatientId);
// Get default location
Location location = Context.getLocationService().getDefaultLocation();
if (location == null) {
throw new HL7Exception("Cannot find default location");
}
pi.setLocation(location);
try {
PatientIdentifierValidator.validateIdentifier(pi);
goodIdentifiers.add(pi);
} catch (PatientIdentifierException ex) {
log.warn("Patient identifier in PID is invalid: " + pi, ex);
}
} catch (Exception e) {
log.error("Uncaught error parsing/creating patient identifier '" + hl7PatientId + "' for assigning authority '" + assigningAuthority + "'", e);
}
} else {
log.error("PID contains identifier with no assigning authority");
continue;
}
}
if (goodIdentifiers.isEmpty()) {
throw new HL7Exception("PID segment has no recognizable patient identifiers.");
}
patient.addIdentifiers(goodIdentifiers);
// Extract patient name from the message
XPN patientNameX = pid.getPatientName(0);
if (patientNameX == null) {
throw new HL7Exception("Missing patient name in the PID segment");
}
// Patient name
PersonName name = new PersonName();
name.setFamilyName(patientNameX.getFamilyName().getSurname().getValue());
name.setGivenName(patientNameX.getGivenName().getValue());
name.setMiddleName(patientNameX.getSecondAndFurtherGivenNamesOrInitialsThereof().getValue());
if (creator != null) {
name.setCreator(creator);
}
patient.addName(name);
// Gender (checks for null, but not for 'M' or 'F')
String gender = pid.getAdministrativeSex().getValue();
if (gender == null) {
throw new HL7Exception("Missing gender in the PID segment");
}
gender = gender.toUpperCase();
if (!OpenmrsConstants.GENDER().containsKey(gender)) {
throw new HL7Exception("Unrecognized gender: " + gender);
}
patient.setGender(gender);
// Date of Birth
TS dateOfBirth = pid.getDateTimeOfBirth();
if (dateOfBirth == null || dateOfBirth.getTime() == null || dateOfBirth.getTime().getValue() == null) {
throw new HL7Exception("Missing birth date in the PID segment");
}
patient.setBirthdate(tsToDate(dateOfBirth));
// Estimated birthdate?
ID precisionTemp = dateOfBirth.getDegreeOfPrecision();
if (precisionTemp != null && precisionTemp.getValue() != null) {
String precision = precisionTemp.getValue().toUpperCase();
log.debug("The birthdate is estimated: " + precision);
if ("Y".equals(precision) || "L".equals(precision)) {
patient.setBirthdateEstimated(true);
}
}
return patient;
}
use of ca.uhn.hl7v2.HL7Exception in project openmrs-core by openmrs.
the class ADTA28Handler method processMessage.
/**
* Processes an ADT A28 event message
*/
@Override
public Message processMessage(Message message) throws ApplicationException {
log.debug("Processing ADT_A28 message");
if (!(message instanceof ADT_A05)) {
throw new ApplicationException("Invalid message sent to ADT_A28 handler");
}
Message response;
try {
ADT_A05 adt = (ADT_A05) message;
response = processADT_A28(adt);
} catch (ClassCastException e) {
log.error("Error casting " + message.getClass().getName() + " to ADT_A28", e);
throw new ApplicationException("Invalid message type for handler");
} catch (HL7Exception e) {
log.error("Error while processing ADT_A28 message", e);
throw new ApplicationException(e);
}
log.debug("Finished processing ADT_A28 message");
return response;
}
Aggregations