Im Rahmen der Veranstaltung "CS3330 - Projektpraktikum MedizinischeInformatik" an der Universität zu Lübeck entstandenes Krankenhausinformationssystem (KIS).
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

201 行
8.7 KiB

  1. package de.uniluebeck.mi.projmi6;
  2. import ca.uhn.hl7v2.DefaultHapiContext;
  3. import ca.uhn.hl7v2.HL7Exception;
  4. import ca.uhn.hl7v2.HapiContext;
  5. import ca.uhn.hl7v2.model.DataTypeException;
  6. import ca.uhn.hl7v2.model.Message;
  7. import ca.uhn.hl7v2.model.v25.datatype.DTM;
  8. import ca.uhn.hl7v2.model.v251.datatype.FN;
  9. import ca.uhn.hl7v2.model.v251.message.ACK;
  10. import ca.uhn.hl7v2.model.v251.message.ADT_A01;
  11. import ca.uhn.hl7v2.model.v251.message.BAR_P05;
  12. import ca.uhn.hl7v2.model.v251.segment.*;
  13. import ca.uhn.hl7v2.parser.Parser;
  14. import ca.uhn.hl7v2.parser.PipeParser;
  15. import ca.uhn.hl7v2.validation.ValidationContext;
  16. import ca.uhn.hl7v2.validation.impl.ValidationContextFactory;
  17. import de.uniluebeck.mi.projmi6.db.DBHandler;
  18. import de.uniluebeck.mi.projmi6.model.Diagnose;
  19. import de.uniluebeck.mi.projmi6.model.Fall;
  20. import de.uniluebeck.mi.projmi6.model.Patient;
  21. import java.io.BufferedWriter;
  22. import java.io.File;
  23. import java.io.FileWriter;
  24. import java.io.IOException;
  25. import java.sql.SQLException;
  26. import java.sql.Time;
  27. import java.time.LocalDate;
  28. import java.time.LocalDateTime;
  29. import java.time.LocalTime;
  30. import java.util.ArrayList;
  31. import java.util.List;
  32. /**
  33. * Created by taschi on 15.11.15.
  34. * enthaelt alle Klassen um eine Hl7 Nachricht zu erstellen bzw. zu Parsen.
  35. */
  36. public class HL7 {
  37. /**
  38. * erstellt eine ADT_A0 nachricht, welche anschließend an die OPS Gruppe verschickt werden soll.
  39. * TODO Mit OPS Gruppe absprechen, welche Informationen sie auf jeden Fall benötigen und Code entsprechend anpassen.
  40. * @param fall nach dem Erstellen eines neuen Falls wird diese Methode aufgerufen um Hl7 Nachricht zu erzeugen
  41. * @throws Exception
  42. */
  43. public void createMessageADTA01( Fall fall) throws HL7Exception, IOException {
  44. Patient patient = fall.getPatient ();
  45. ADT_A01 adt = new ADT_A01 ();
  46. //default MSH Values (Sets Segments: 1,2,7,9
  47. adt.initQuickstart ("ADT", "A01", "P");
  48. //MSH Segment:
  49. MSH mshSegment = adt.getMSH();
  50. mshSegment.getMsh3_SendingApplication ().getNamespaceID ().setValue ( "KISGruppe6" );
  51. mshSegment.getMsh5_ReceivingApplication ().getNamespaceID ().setValue("OPS Gruppe von Maurice und Torben");
  52. mshSegment.getMsh12_VersionID ().getVersionID ().setValue ( "2.2" );
  53. mshSegment.getMsh15_AcceptAcknowledgmentType ().setValue ( "AL" );
  54. //Security?
  55. //Message Control ID?
  56. //Processing ID?
  57. //Sequence Number ?
  58. //Contituation Pointer ?
  59. //Cointry Code
  60. //Character Set
  61. //Principal Language of Message
  62. //EVN Segment:
  63. EVN evnSegment = adt.getEVN ();
  64. evnSegment.getEvn1_EventTypeCode ().setValue ("A01");
  65. evnSegment.getEvn4_EventReasonCode ().setValue ( "01" );
  66. //Operator ID
  67. //Event occured
  68. //PID
  69. PID pidSegment = adt.getPID ();
  70. pidSegment.getPid3_PatientIdentifierList (0).getIDNumber ().setValue ( Integer.toString(patient.getPatID ()) );
  71. pidSegment.getPid5_PatientName (0).getFamilyName ().getSurname ().setValue ( patient.getNachname () );
  72. pidSegment.getPid5_PatientName (0).getGivenName ().setValue ( patient.getVorname () );
  73. pidSegment.getPid7_DateTimeOfBirth ().getTime ().setValue ( patient.getGeburtsdatum ().toString () );
  74. pidSegment.getPid8_AdministrativeSex ().setValue ( patient.getGeschlecht ().toString () );
  75. pidSegment.getPid11_PatientAddress (0).getStreetAddress ().getStreetName().setValue ( patient.getStrasse () );
  76. pidSegment.getPid11_PatientAddress (0).getStreetAddress ().getDwellingNumber ( ).setValue ( patient.getHausnummer () );
  77. pidSegment.getPid11_PatientAddress (0).getCity ().setValue (patient.getOrt () );
  78. pidSegment.getPid13_PhoneNumberHome (0).getTelephoneNumber ().setValue ( patient.getTelefon () );
  79. pidSegment.getPid16_MaritalStatus ().getAlternateIdentifier ().setValue ( patient.getFamilienstand ().toString());
  80. validateMessage(adt);
  81. /*
  82. //Dg1 (Diagnosen)
  83. List<DG1> dg1List = new ArrayList<> ( );
  84. diagnosen.add(fall.getHauptDiagnose ());
  85. DG1 dg1Segment = adt.getDG1 ();
  86. for (Diagnose aDiagnosen : diagnosen) {
  87. dg1Segment = adt.getDG1 ();
  88. dg1Segment.getDg12_DiagnosisCodingMethod ().setValue ( "ICD10" );
  89. dg1Segment.getDg13_DiagnosisCodeDG1 ().getIdentifier ().setValue ( "CODE" );
  90. dg1Segment.getDg14_DiagnosisDescription ().setValue ( aDiagnosen.getFreiText () );
  91. dg1List.add ( dg1Segment );
  92. }
  93. */
  94. //print generated message
  95. printXMLEncodedMessageADT(adt);
  96. }
  97. /**
  98. * gibt erzeugte hl7 Nachricht auf der Konsole aus (Kann nach Debug phase wieder geloescht werden)
  99. * @param msg
  100. * @throws HL7Exception
  101. */
  102. public void printXMLEncodedMessageADT(Message msg) throws HL7Exception, IOException {
  103. HapiContext context = new DefaultHapiContext ();
  104. Parser parser = context.getXMLParser();
  105. String encodedMessage = parser.encode(msg);
  106. LocalDateTime ldt = LocalDateTime.now();
  107. File file = new File("ADTA01Messafge" +LocalDateTime.now().toString() +"xml" );
  108. if (!file.exists()) {
  109. file.createNewFile();
  110. }
  111. FileWriter fw = new FileWriter(file.getAbsoluteFile());
  112. BufferedWriter bw = new BufferedWriter(fw);
  113. bw.write(encodedMessage);
  114. bw.close();
  115. System.out.println (encodedMessage);
  116. }
  117. /**
  118. *
  119. * @param msg
  120. */
  121. public void parseMessage(Message msg) throws DataTypeException, SQLException {
  122. if (msg instanceof BAR_P05) {
  123. BAR_P05 p05 = (BAR_P05) msg;
  124. EVN evnSegment = p05.getEVN();
  125. PID pidSegment = p05.getPID();
  126. DBHandler dh = new DBHandler();
  127. Patient patient =dh.getPatient(Integer.valueOf(pidSegment.getPid3_PatientIdentifierList(0).getIDNumber().getValue()));
  128. Fall fall = new Fall();
  129. LocalDateTime ldt = generateLocalDateTimeFromHl7(p05);
  130. patient.setBearbeitetDatumZeit(ldt);
  131. patient.setBearbeiter(Integer.valueOf(evnSegment.getEvn5_OperatorID(0).getIDNumber().getValue()));
  132. /** wenn ein neuer patient angelegt werden sollte
  133. patient.setNachname(pidSegment.getPid5_PatientName(0).getFamilyName().getName());
  134. patient.setVorname(pidSegment.getPid5_PatientName(0).getGivenName().getValue());
  135. ca.uhn.hl7v2.model.v251.datatype.DTM geburtsTag = pidSegment.getPid7_DateTimeOfBirth().getTime();
  136. LocalDate ld = LocalDate.of(geburtsTag.getYear(), geburtsTag.getMonth(), geburtsTag.getDay());
  137. patient.setGeburtsdatum(ld);
  138. Patient.Geschlecht geschlecht = Patient.Geschlecht.parseStringFromHL7(pidSegment.getPid8_AdministrativeSex().getValue());
  139. patient.setGeschlecht(geschlecht);
  140. patient.setStrasse(pidSegment.getPid11_PatientAddress(0).getStreetAddress().getStreetName().getValue());
  141. patient.setOrt(pidSegment.getPid11_PatientAddress(0).getCity().getValue());
  142. patient.setHausnummer(pidSegment.getPid11_PatientAddress(0).getStreetAddress().getDwellingNumber().getValue());
  143. patient.setTelefon(pidSegment.getPid13_PhoneNumberHome(0).getTelephoneNumber().getValue());
  144. Patient.Familienstand familienstand = pidSegment.getPid16_MaritalStatus().getAlternateText().getValue();
  145. patient.setFamilienstand();
  146. */
  147. }
  148. }
  149. public void validateMessage(Message msg) {
  150. HapiContext context = new DefaultHapiContext();
  151. context.setValidationContext(ValidationContextFactory.<ValidationContext>defaultValidation());
  152. PipeParser parser = context.getPipeParser();
  153. try {
  154. parser.encode(msg);
  155. } catch (HL7Exception e) {
  156. System.out.println("invaid message!" +e);
  157. }
  158. }
  159. public LocalDateTime generateLocalDateTimeFromHl7(BAR_P05 msg) throws DataTypeException {
  160. EVN evnSegment = msg.getEVN();
  161. int stunden = evnSegment.getEvn2_RecordedDateTime ().getTime ().getHour ();
  162. int minuten = evnSegment.getEvn2_RecordedDateTime ().getTime ().getMinute ();
  163. int sekunden = evnSegment.getEvn2_RecordedDateTime ().getTime ().getSecond ();
  164. int tag = evnSegment.getEvn2_RecordedDateTime ().getTime ().getDay ();
  165. int monat = evnSegment.getEvn2_RecordedDateTime ().getTime ().getMonth ();
  166. int jahr = evnSegment.getEvn2_RecordedDateTime ().getTime ().getYear ();
  167. LocalTime bearbeitetZeit = LocalTime.of(stunden,minuten,sekunden);
  168. LocalDate bearbeitetDate = LocalDate.of(jahr, monat, tag);
  169. LocalDateTime ldt = LocalDateTime.of(bearbeitetDate, bearbeitetZeit);
  170. return ldt;
  171. }
  172. }