Contact Us 1-800-596-4880

HL7 Message Validation

The HL7 connector is part of the Mule Healthcare Toolkit, which also includes transformers and components for receiving, processing, and sending HL7 messages. For details and a full list of available tools, consult the Toolkit’s documentation main page.

Overview

The Mule Healthcare toolkit allows you to configure validation for HL7 messages. You can set validation parameters in the HL7 connector, as well as several HL7 message processors. For the complete list of message processors that support validation, see Supported Tools.

The validation setting can have one of three values, described in the table below.

Setting Description

none

No validation

WEAK

Checks that the message is well-formed

STRONG

Checks that message is well-formed, and that all structural elements of the message are present

Supported Tools

The table below lists the tools in the HL7 toolkit that support validation.

Tool Validation Remarks

HL7 Connector

YES

When defined in a global HL7 connector, Mule implements validation only for those HL7 endpoints that reference the connector. If no HL7 endpoints reference the connector, Mule automatically applies validation in all HL7 endpoints in the application.

HL7 Endpoint

YES

An HL7 endpoint applies validation when it references an HL7 connector where validation has been configured (see the Using Validation). The HL7 endpoint itself has no configuration settings for validation.

HL7 Encoding Transformer

YES

HL7 ACK Component

YES

HL7 Append Segment

YES

HL7 Delete Segment

NO

HL7 Message Component

NO

Using Validation

You can set validation for specific message processors only, or for a whole application.

If you set validation only in specific message processors, Mule only applies validation to those message processors. If you define validation at an HL7 connector, Mule only applies validation to the HL7 endpoints which reference that connector. If no HL7 endpoints reference the HL7 connector, then Mule applies validation at all HL7 endpoints in the application.

Combining these configurations with the validation setting (WEAK or STRONG) allows you to use validation beyond the simple case of rejecting an invalid HL7 message. For example, you can reject HL7 messages using strong validation but still perform logging or preliminary business logic on them. The image below illustrates a simple example of this type of validation.

validation-sample_flow

Flow 1:

  • An HL7 Endpoint receives incoming HL7 messages. This endpoint references HL7 Connector 1, which applies weak validation. If the incoming messages passes validation, the endpoint forwards it to the next message processor.

  • A Variable Transformer defines variables for logging.

  • A Logger Component performs logging.

  • A Flow Ref Component invokes the next flow.

  • An HL7 ACK Component sends an ACK message back to the originating application.

Flow 2:

  • An HL7 endpoint receives the message sent by Flow 1. This endpoint references HL7 Connector 2, which applies strong validation. If the message passes validation, the endpoint forwards it to the main logic in the flow.

If this example application receives an HL7 message that is not valid for its main logic, the application rejects the message, but still logs relevant information about it.