Skip to main content
Skip table of contents

HL72XML

The HL72XML component is used to parse HL7 (Health Level Seven) v2.x document and convert it to XML format.

HL7 v2.x is a messaging standard used to define how information is packaged and communicated between different systems in hospital workflows.

An equivalent XML format (XML Schema) is defined for each HL7 v2.x message format. The component, upon receiving an HL7 v2.x message, will convert it into an appropriate XML message that conforms to any of the XML Schemas defined.

Configuration

Component Configuration

 
Figure 1: Component configuration

Attributes

Error handling configuration

Please refer Error Handling section in Common Configurations page. 


Figure 2: Error Handling Configuration

Output schema

If the component receives a message of the same format at all times, then XML schema of that message format can be provided here using schema editor which opens-up on clicking the ellipsis 

button.


Figure 3: Output Schema editor to provide XML schema that supports Input Messages of the same format

The component will convert any valid HL7 v2.x message to respective XML message conforming to XML schemas defined for HL7 messages, irrespective of the schema provided here. Defining an XML schema here will only set the schema on the input port of the component so that any required transformations can be defined using the schema.

Do not define the Schema here if the component can receive messages in different HL7 format. Instead, the schemas should be loaded manually into the output structure of Mapper tool defining transformations.

XML Schema files for hl7 messages are present at FIORANO_HOME/xml-catalog/fiorano/hl7.

Enable input validation

Enable this property to validate the Input to conform with the HL7 message rules.

Validation Type


Figure 4: Validation Type appears after enabling Input Validation

This property appears only when Enable input validation property is enabled.

  • DEFAULT: Messages will be validated with standard HL7 message rules.
  • CONFORMANCE PROFILE: Message will be validated with the conformance profile file configured for its type. Default validation is performed if conformance profile is not configured for a specific type. When this option is chosen, Conformance Profile Configuration property appears where the configuration can be set.
Conformance Profile Configuration

Click the ellipsis 

button to provide the Conformance Profile configuration.


Figure 5: Conformance Profile Configuration property appears after choosing the respective Validation Type

This property appears only when the Validation Type property is chosen as 'Conformance Profile'.

Click the Conformance Profile configuration ellipsis button and click Add in the dialog box to add the following attributes pertaining to Conformance Profile:

  • Message Type
  • Trigger Event
  • File Path


Figure 6: Dialog box to set the Conformance Profile Configuration

Input contains multiple messages

Enable this property if the input contains multiple HL7 messages delimited by a character.

Message Delimiter

Provide delimited character in hex format.


Figure 7: Message Delimiter property to specify delimiter character

Expert Properties

Enable the Expert Properties view to configure these properties.

Expert properties are meant for advanced users; use with caution.


Figure 8: Expert properties for Generate sequencer mode

Pre Processing XSL Configuration

Pre Processing XSL configuration can be used to transform request message before processing it. Click the ellipses button against the property to configure the properties.

Refer to the Pre/Post Processing XSL Configuration section under the Common Configurations page for details regarding Pre Processing XSL configuration and Post Processing XSL configuration (below).

Post Processing XSL Configuration 

Post Processing XSL configuration can be used to transform the response message before sending it to the output port.

Process Message Based on Property

The property helps components to skip certain messages from processing.

Refer to the Process Message Based On a Property section under the Common Configurations page.

Threadpool Configuration

This property is used when there is a need to process messages in parallel within the component, still maintaining the sequence from the external perspective. 

  • Limit the usage of the Threadpool Configuration property only in circumstances as mentioned above.
  • If sequential processing is not required, please use sessions on the input port.

Click the Threadpool Configuration ellipsis button to configure the Threadpool Configuration properties.


Figure
 9: Threadpool Configuration

Enable Thread Pool

Enable this option to configure the properties that appear as below.

Pool Size

Number of requests to be processed in parallel within the component. Default value is '1'.

Batch Eviction Interval (in ms)

Time in milliseconds after which the threads are evicted in case of inactivity. New threads are created in place of evicted threads when new requests are received. Default value is '1000'.

Custom HL7 Message Packages

The table contains a Map for a version of HL7Message mapped to the list of provided Custom packages separated by the delimiter ; 


Figure 10: Threadpool Configuration

Elements to Encrypt

Select the elements to encrypt in output. Elements in the Output Message will be encrypted. Elements get auto-populated based on the Output Schema provided. Select the elements to encrypt and click the arrow button to choose those.


Figure 11: Properties of elements to encrypt

Add elements to encrypt/decrypt

Some components may not have schema on ports. In that case, semicolon separated XPaths can be provided here.

Namespace Prefixes: A map of prefix versus namespace used in XPaths can be configured here.

Functional Demonstration

Scenario 1

This scenario explains the basic functionality of HL72XML component.

Create flow by connecting HL72XML to feeder and display components. Send sample input (valid HL7 message) to check the response (transformed XML message).

The HL7 input is sent from the feeder and the corresponding XML output can be seen in display.


Figure 12: Sample Event Process

Sample Input

XML
MSH|^~\&|GDML|GDML|||20140207163234||ORU^R01|3ca92c1f-a566-4868-a704-dcb9d0c1fcd3|T|2.6|||||||EN
PID|1|^^^^^^|NNTV19880113^^^Other^Other^^^^Other^^0~NNTV88011300^^^CANQC^Other^^^^Other^^51~NNTV0013^^^Other^Other^^^^Other^^26||NNTEST13^V12TEST13^^||19880113|F|||13 STREET^^ABJOU^^J1K2L3|||||||||||||||||||||||||||||
PRT|1|||OP^Physician|79335^ZAPHIRATOS^THOMAS^^^|||||||||202 - 7200 HUTCHISON^^MONTRÉAL^Qc^H3N 1Z2|Work^514^4957932^||^^
PRT|2|||PO^Lab||||ZAPHIRATOS, T. DR.^^^^^GDML^^^^LLZAPHIR||||||7200 Hutchison^^MONTREAL^Qc^H3N 1Z2|Work^495^2555^^Fax^495^7932^||^^
ORC|||3872090||O||||20140206163434
NTE|1|L||This requisition was edited and resaved on the2014/02/07 12:06:52 (GMT-05:00)|GR
OBR|1||3872090|2054^GLUCOSE POS 1:2 H^GDML^^^^^^|R||20140206163434|||||||||||||^BIOCHEMISTRY|||||I||||
SPM||||||||||

Output


Figure 13: Output generated in the Display window in XML format for Scenario 1 input

Please refer to http://www.hl7.org/ for more information about HL7 messages.

Scenario 2

This scenario includes functionality to include multiple messages. In the HL72XML CPS, enable the Input contains multiple messages property, provide the Message Delimeter value as hex value of # and use the following input in the Feeder window.

Sample Input

CODE
MSH|^~\&|GDML|GDML|||20140207163234||ORU^R01|3ca92c1f-a566-4868-a704-dcb9d0c1fcd3|T|2.6|||||||EN
PID|1|^^^^^^|NNTV19880113^^^Other^Other^^^^Other^^0~NNTV88011300^^^CANQC^Other^^^^Other^^51~NNTV0013^^^Other^Other^^^^Other^^26||NNTEST13^V12TEST13^^||19880113|F|||13 STREET^^ABJOU^^J1K2L3|||||||||||||||||||||||||||||
PRT|1|||OP^Physician|79335^ZAPHIRATOS^THOMAS^^^|||||||||202 - 7200 HUTCHISON^^MONTRÉAL^Qc^H3N 1Z2|Work^514^4957932^||^^
PRT|2|||PO^Lab||||ZAPHIRATOS, T. DR.^^^^^GDML^^^^LLZAPHIR||||||7200 Hutchison^^MONTREAL^Qc^H3N 1Z2|Work^495^2555^^Fax^495^7932^||^^
ORC|||3872090||O||||20140206163434
NTE|1|L||This requisition was edited and resaved on the2014/02/07 12:06:52 (GMT-05:00)|GR
OBR|1||3872090|2054^GLUCOSE POS 1:2 H^GDML^^^^^^|R||20140206163434|||||||||||||^BIOCHEMISTRY|||||I||||
SPM||||||||||#MSH|^~\&|EPIC|EPICADT|SMS|SMSADT|199912271408|CHARRIS|ADT^A04|1817457|D|2.5|
PID||0493575^^^2^ID 1|454721||DOE^JOHN^^^^|DOE^JOHN^^^^|19480203|M||B|254 MYSTREET AVE^^MYTOWN^OH^44123^USA||(216)123-4567|||M|NON|400003403~1129086|
NK1||ROE^MARIE^^^^|SPO||(216)123-4567||EC|||||||||||||||||||||||||||
PV1||O|168 ~219~C~PMA^^^^^^^^^||||277^ALLEN MYLASTNAME^BONNIE^^^^|||||||||| ||2688684|||||||||||||||||||||||||199912271408||||||002376853

Output


Figure 14: Output generated in the Display window in XML format for Scenario 2 input


JavaScript errors detected

Please note, these errors can depend on your browser setup.

If this problem persists, please contact our support.