Acknowledging HL7 Messages

Automatic message acknowledgement for HL7 messages is enabled in the Micro Integrator by default. With this setting, an ACK is immediately returned to the client when a message is received.

If required, you can disable automatic acknowledgement. This allows you to control how and when ACK/NACK messages should be returned to the client. That is, you can define the integration logic to generate an ack/nack message after message validations or related tasks.

Configuring message acknowledgement for HL7

When auto acknowledgement for HL7 messages is disabled in the Micro Integrator, you can manually configure ACK/NACK messages in the mediation logic by using the Property mediator.

Info

Add the following parameter to the proxy service to disable auto acknowledgement and validation:

<parameter name="transport.hl7.AutoAck">false</parameter>

  • Specify an axis2 scope message context property HL7_GENERATE_ACK and set its value to true as shown below.

    <property name="HL7_GENERATE_ACK" value="true" scope="axis2"/>

    This ensures that an ACK/NACK message is created automatically when a message is sent (using the HL7 formatter). By default, an ACK message is created.

  • If a NACK message is required instead, set the result mode to NACK and provide a custom NACK message as shown below.

    <property name="HL7_RESULT_MODE" value="NACK" scope="axis2" />
    <property name="HL7_NACK_MESSAGE" value="ERROR MESSAGE" scope="axis2" />
  • You can use the HL7_RAW_MESSAGE property in the axis2 scope to retrieve the original raw EDI format HL7 message in an InSequence. The user doesn't have to convert from XML to EDI again. Therefore, this may be particularly helpful inside a custom mediator.

    <property name="HL7_RAW_MESSAGE" value="$axis2:HL7_RAW_MESSAGE" scope="axis2" />
  • To control the encoding type of incoming messages, set the Java system property ca.uhn.hl7v2.llp.charset.

  • If you do want to wait for the back-end application's response before sending the ACK/NACK message to the client, define the following property in the InSequence:

    <property name="HL7_APPLICATION_ACK" value="true" scope="axis2"/> 

    In this case, the request thread will wait until the back-end application returns the response before sending the "accept-acknowledgement" message to the client.

Example 1: Generate ACK/NACK before the backend responds

Consider an example where the client sending the message only requires an acknowledgement from the proxy service that the message was received. It does not need to wait for the back-end service to process the message before receiving this acknowledgement.

Synapse configuration

Given below is a sample proxy service that is configured to send an ACK/NACK as soon as the message is received.

<?xml version="1.0" encoding="UTF-8"?>
<proxy xmlns="http://ws.apache.org/ns/synapse" name="HL7Proxy" transports="hl7" startOnLoad="true" trace="disable">
    <description/>
    <target>
        <inSequence>
            <property name="HL7_RESULT_MODE" value="ACK" scope="axis2"/>
            <property name="HL7_GENERATE_ACK" value="true" scope="axis2"/>
            <send>
               <endpoint name="hl7_endpoint">
                    <address uri="hl7://localhost:9988"/>
                </endpoint>
            </send>
        </inSequence>
        <outSequence>
            <log level="custom">
                <property name="OUT" value="***********out sequence proxy2***********"/>
            </log>
           <drop/>
        </outSequence>
     </target>
     <parameter name="transport.hl7.AutoAck">false</parameter>
     <parameter name="transport.hl7.ValidateMessage">false</parameter>
     <parameter name="transport.hl7.Port">9293</parameter>
</proxy>

Build and run

Create the artifacts:

  1. Set up ESB Integration Studio.
  2. Create an integration project with an ESB Configs module and an Composite Exporter.
  3. Create the proxy service with the configurations given above.
  4. Configure the HL7 transport in your Micro Integrator.
  5. Deploy the artifacts in your Micro Integrator.

To test this scenario, you need the following:

  • An HL7 client that sends messages to the port specified by the transport.hl7.Port parameter.
  • An HL7 back-end application that receives messages from the Micro Integrator.

You can simulate the HL7 client and back-end application using a tool such as HAPI.

Example 2: Generate ACK/NACK after the backend responds

Consider an example where the client sending the message requires an acknowledgement from the proxy service only after the back-end service has processed the message.

Synapse configuration

The following proxy service is configured to send a NACK message after the backend has processed the message.

<?xml version="1.0" encoding="UTF-8"?>
<proxy xmlns="http://ws.apache.org/ns/synapse" name="HL7Proxy" transports="hl7" statistics="disable" trace="disable" startOnLoad="true">
  <target>
      <inSequence>
           <property name="HL7_APPLICATION_ACK" value="true" scope="axis2"/> 
            <send>
                  <endpoint name="endpoint_urn_uuid_9CB8D06C91A1E996796270828144799-1418795938">
                          <address uri="hl7://localhost:9988"/>
                  </endpoint>
            </send>
      </inSequence>
      <outSequence> 
           <property name="HL7_RESULT_MODE" value="NACK" scope="axis2"/>
           <property name="HL7_NACK_MESSAGE" value="error msg" scope="axis2"/>
           <send/>
      </outSequence>
  </target>
  <parameter name="transport.hl7.AutoAck">false</parameter>
  <parameter name="transport.hl7.ValidateMessage">true</parameter>
  <parameter name="transport.hl7.Port">9294</parameter>
  <description></description>
</proxy>

Build and run

Create the artifacts:

  1. Set up ESB Integration Studio.
  2. Create an integration project with an ESB Configs module and an Composite Exporter.
  3. Create the proxy service with the configurations given above.
  4. Configure the HL7 transport in your Micro Integrator.
  5. Deploy the artifacts in your Micro Integrator.

To test this scenario, you need the following:

  • An HL7 client that sends messages to the port specified by the transport.hl7.Port parameter.
  • An HL7 back-end application that receives messages from the Micro Integrator.

You can simulate the HL7 client and back-end application using a tool such as HAPI.

Top