diff --git a/hl7/4.3/antora.yml b/hl7/4.3/antora.yml new file mode 100644 index 0000000000..da2a6f723b --- /dev/null +++ b/hl7/4.3/antora.yml @@ -0,0 +1,18 @@ +name: hl7-connector +version: '4.3' +display_version: 4.3 (Mule 4) +title: HL7 EDI Connector +nav: +- modules/ROOT/nav.adoc +asciidoc: + attributes: + page-component-desc: This connector enables you to convert HL7 ER7 messages to and from DataWeave-compatible representations using lists and maps. + page-connector-type: Connector + page-connector-level: Premium + page-exchange-group-id: com.mulesoft.connectors + page-exchange-asset-id: mule-hl7-extension + page-icon-extension: png + page-runtime-version: 4.1.1 + page-release-notes-page: release-notes::connector/hl7-connector-release-notes-mule-4.adoc + page-vendor-name: hl7 + page-vendor-title: HL7 diff --git a/hl7/4.3/modules/ROOT/images/hl7-connector-flow-in-studio.png b/hl7/4.3/modules/ROOT/images/hl7-connector-flow-in-studio.png new file mode 100644 index 0000000000..88dc0fb604 Binary files /dev/null and b/hl7/4.3/modules/ROOT/images/hl7-connector-flow-in-studio.png differ diff --git a/hl7/4.3/modules/ROOT/nav.adoc b/hl7/4.3/modules/ROOT/nav.adoc new file mode 100644 index 0000000000..a12d22af63 --- /dev/null +++ b/hl7/4.3/modules/ROOT/nav.adoc @@ -0,0 +1,8 @@ +.xref:index.adoc[HL7 EDI Connector] +* xref:index.adoc[HL7 EDI Connector Overview] +* xref:hl7-connector-reference.adoc[HL7 EDI Connector Reference] +* xref:hl7-connector-studio.adoc[Using Anypoint Studio to Configure HL7 EDI Connector] +* xref:hl7-connector-config-topics.adoc[HL7 Schema Configuration] +* xref:hl7-connector-examples.adoc[HL7 EDI Examples] +* xref:hl7-connector-xml-maven.adoc[HL7 EDI XML and Maven Support] +* xref:hl7-schemas.adoc[HL7 Supported Schemas] diff --git a/hl7/4.3/modules/ROOT/pages/hl7-connector-config-topics.adoc b/hl7/4.3/modules/ROOT/pages/hl7-connector-config-topics.adoc new file mode 100644 index 0000000000..59ffb24723 --- /dev/null +++ b/hl7/4.3/modules/ROOT/pages/hl7-connector-config-topics.adoc @@ -0,0 +1,270 @@ += HL7 EDI - Customizing Schemas and Mapping Message Types - Mule 4 + +Use these options to: + +* Customize your schema definitions + +* Define a mapping from the HL7 event and message types to message structures + +* Customize global elements + +== Copy and Edit Schema Definitions + +HL7 schema definitions are located in the `hl7-schemas-4.0.0.jar` file, +embedded inside the HL7 EDI Connector update site, and within the standard MuleSoft enterprise Maven repositories +(under group ID `com.mulesoft.connectors`). You can copy a message structure schema +from the `hl7-schemas-4.0.0.jar` file and edit it to match your specific needs. + +To make changes at the segment level, copy the message structure +schema. To change segment definitions, copy the `basedefs.esl` schema of the same version, as that file contains the segment, composite, and element definitions. + +The xref:x12-edi-connector::x12-edi-schema-language-reference.adoc[EDI Schema Language Reference] provides an overview of the ESL schema structure used by all the EDI connectors, including HL7 EDI Connector. + +The following is an example HL7 message structure schema for the +standard v2.5.1 ADT_A05 message structure: + +[source,yaml,linenums] +---- +form: HL7 +version: '2.5.1' +imports: [ '/hl7/v2_5_1/basedefs.esl' ] +id: 'ADT_A05' +name: 'ADT_A05' +data: +- { idRef: 'MSH', position: '01', usage: M } +- { idRef: 'SFT', position: '02', usage: O, count: '>1' } +- { idRef: 'EVN', position: '03', usage: M } +- { idRef: 'PID', position: '04', usage: M } +- { idRef: 'PD1', position: '05', usage: O } +- { idRef: 'ROL', position: '06', usage: O, count: '>1' } +- { idRef: 'NK1', position: '07', usage: O, count: '>1' } +- { idRef: 'PV1', position: '08', usage: M } +- { idRef: 'PV2', position: '09', usage: O } +- { idRef: 'ROL', position: '10', usage: O, count: '>1' } +- { idRef: 'DB1', position: '11', usage: O, count: '>1' } +- { idRef: 'OBX', position: '12', usage: O, count: '>1' } +- { idRef: 'AL1', position: '13', usage: O, count: '>1' } +- { idRef: 'DG1', position: '14', usage: O, count: '>1' } +- { idRef: 'DRG', position: '15', usage: O } +- groupId: 'PROCEDURE' + count: '>1' + usage: O + items: + - { idRef: 'PR1', position: '17', usage: M } + - { idRef: 'ROL', position: '18', usage: O, count: '>1' } +- { idRef: 'GT1', position: '20', usage: O, count: '>1' } +- groupId: 'INSURANCE' + count: '>1' + usage: O + items: + - { idRef: 'IN1', position: '22', usage: M } + - { idRef: 'IN2', position: '23', usage: O } + - { idRef: 'IN3', position: '24', usage: O, count: '>1' } + - { idRef: 'ROL', position: '25', usage: O, count: '>1' } +- { idRef: 'ACC', position: '27', usage: O } +- { idRef: 'UB1', position: '28', usage: O } +- { idRef: 'UB2', position: '29', usage: O } +---- + +This shows the list of segments that compose the `ADT_A05` message structure, +including the segment groups PROCEDURE and INSURANCE. Because this example illustrates +the standard definition (not the lax version), it includes both mandatory +segments (indicated with `usage: M`) and optional segments +(indicated with `usage: O`). The full set of usage codes used for HL7 includes: + +* `C` for Conditional ++ +Equivalent to Optional +* `M` for Mandatory +* `O` for Optional +* `U` for Unused ++ +Accepted without warning when reading, but not present +in the data passed on from the read operation and ignored when writing + +The possible number of occurrences of a segment or group is defined by the +count value. This defaults to a value of `1`. + +To delete segments from the message structure or change segment requirements from mandatory to optional (or vice versa), make the change in your copy of the schema and use the modified version in your application. + +You can add segments that are not present in the original message +structure definition. Remove the position values from all existing segment and group definition lines in the schema; otherwise, you must renumber everything following an added segment. +If you remove the explicit position numbers, segments and groups are assigned +position numbers sequentially, and for most purposes these numbers are not +seen by HL7 EDI Connector applications. + +If you want to add a standard HL7 segment to a message structure, +reference it with an `idRef` line at the appropriate place, and HL7 obtains +the definition from the `basedefs.esl` file referenced as an import. + +The following partial example shows `CON` segments added to an ADT_A05 message structure: + +[source,yaml,linenums] +---- +form: HL7 +version: '2.5.1' +imports: [ '/hl7/v2_5_1/basedefs.esl' ] +id: 'ADT_A05' +name: 'ADT_A05' +data: +- { idRef: 'MSH', usage: M } +- { idRef: 'SFT', usage: O, count: '>1' } +- { idRef: 'EVN', usage: M } +- { idRef: 'PID', usage: M } +- { idRef: 'PD1', usage: O } +- { idRef: 'CON', usage: O, count: '>1' } +- { idRef: 'NTE', usage: O } +- { idRef: 'ROL', usage: O, count: '>1' } +- { idRef: 'NK1', usage: O, count: '>1' } +- { idRef: 'PV1', usage: M } +- { idRef: 'PV2', usage: O } +- { idRef: 'CON', usage: O, count: '>1' } +- { idRef: 'ROL', usage: O, count: '>1' } +... +---- + +If you want to define a nonstandard segment for your message structure, +add the segment definition to the schema. This is more complex than just +modifying the segment structure, because you need to list all components +in the segment. The easiest starting point is to find a similar +standard HL7 segment and copy the definition used for that standard +segment from the `basedefs.esl` file. You can then add the segment's key, +following your message structure definition, followed by one or more +segment definitions. + +=== Set Your Schema Locations + +You can configure schema locations in the Anypoint Studio XML view. + +. Select the XML view by clicking *Configuration XML*. + +. Modify your HL7 EDI configuration to include a list of all the schemas to include by adding an `++` element for each document type: ++ +[source,xml,linenums] +---- + + + hl7/v2_6/ADT_A01.esl + + +---- ++ +. After you create a global element for your HL7 EDI, configure the event and message structure. + +== Event and Message-to-Message Structure Map + +If you configure the connector with multiple message structure schemas +(whether in separate schema definitions files, as with the provided schemas, +or in a single file), you must define a mapping from the HL7 event +and message types to message structures. + +HL7 defines the message type in the component values of `MSH-09`, a composite +structure of type MSG. HL7 EDI Connector uses these component values to find the structure schema to use for processing a receive message, according to the following rules: + +* If the MSG-01 Message Code value is `ACK`, always use the predefined ACK schema. +* If the MSG-03 Message Structure value is present (a value such +as `ADT_A01`), use the schema structure with that ID. +* If neither of these, then use a configured Event and Message-to-Message Structure Map to determine +the message structure from the specified Trigger Event (`MSG-02`) and Message Code (`MSG-01`) values. + +The Event and Message-to-Message Structure Map is an optional configuration parameter. +It must be a YAML file consisting of a map from each Event Type to a map for each +supported Message Code to the actual Message Structure. + +Here's an example: + +[source,yaml,linenums] +---- +A01: { XYZ: ADT_A01, ACK: ACK } +A02: { XYZ: ADT_A02, ACK: ACK } +A03: { XYZ: ADT_A03, ACK: ACK } +A04: { XYZ: ADT_A01, ACK: ACK } +A05: { XYZ: ADT_A05, ACK: ACK } +A06: { XYZ: ADT_A06, ACK: ACK } +A07: { XYZ: ADT_A06, ACK: ACK } +A08: { XYZ: ADT_A01, ACK: ACK } +---- + +Each version of HL7 defines a different set of mappings from the event type and +message code to the message structure. The default mappings are provided in the +same JAR file as the standard HL7 schema definitions, in files named `event-message.yaml`. +You use the same type of paths for these mapping definitions as for the actual message structure schemas. + +=== Uses for the General Tab + +Use the *General* tab to configure settings for reading and writing HL7 messages: + +* HL7 character encoding ++ +Always used for writing messages and used when reading messages unless a different encoding is specified by the MSH-18 (Character Set). +* Disable numeric prefixes for data keys ++ +This option is true by default, which turns off numeric prefixes for segment data. The +only reason to set this option as false is to achieve compatibility with mappings defined for HL7 EDI Connector 3.0.0. +* Manually create or edit the list of schemas + +=== Set Your HL7 Identification in the Visual Editor + +You can configure the Message Header (MSH) application and facility +identification for you and your trading partner in the HL7 EDI Connector configuration. + +The values you set are used when writing HL7 messages to supply the +namespace ID, universal ID, and universal ID type, and are verified +in receive messages. If you don't want to restrict incoming messages, +then leave these blank and set the values for outgoing messages +on the write operation or the actual outgoing message. Values set on +the write operation override the connector configuration, and values +set directly on the message override both the connector configuration +and any values set on the write operation. + +In Studio, these values are set in the following Global Element Properties: + +* Self identification parameters identify your side of the trading partner relationship. These are some self identification settings: ++ +[source,text,linenums] +---- +Mule Application Namespace ID (MSH-03/HD-01 when sending, MSH-05/HD-01 when receiving) +Mule Application Universal ID (MSH-03/HD-02 when sending, MSH-05/HD-02 when receiving) +Mule Application Universal ID Type (MSH-03/HD-03 when sending, MSH-05/HD-03 when receiving) +---- ++ +* Partner identification parameters identify your trading partner. These are some partner identification settings: ++ +[source,text,linenums] +---- +Partner Application Namespace ID (MSH-03/HD-01 when receiving, MSH-05/HD-01 when sending) +Partner Application Universal ID (MSH-03/HD-02 when receiving, MSH-05/HD-02 when sending) +Partner Application Universal ID Type (MSH-03/HD-03 when receiving, MSH-05/HD-03 when sending) +---- + +=== Parser Tab + +You can set the following options if needed: + +[%header%autowidth.spread] +|=== +|XML Value |Studio Option +|eventMessageMap="/hl7/v2_5_1/event-message.yaml" |Event and message-to-message structure map path (required if using multiple message structures, unless the MSH-09 and MSG-03 message structure values are always present in the received messages) +|genericExtensionPattern="Z.." |Java regular pattern for generic extension segment names (to allow handling of extension segments as maps of field values) +|invalidCharacterInValueFail="true" |Fail when an invalid character is in a value +|missingRequiredValueFail="true" |Fail when a required value is missing +|processingId="PRODUCTION" |Required processing ID (to specify a particular processing ID required on receive messages, such as `P` for Production) +|segmentOutOfOrderFail="true" |Fail when a segment is out of order in a message +|unknownSegmentFail="true" |Fail when an unknown segment is in a message +|unusedSegmentPresentFail="true" |Fail when an unused segment is included in a message +|validateHL7Version="true" |Validate the HL7 message version +|valueLengthErrorFail="true" |Fail when a value length is outside an allowed range +|wrongSegmentsRepeatsFail="true" |Fail when there are too many repeats of a segment +|wrongValuesRepeatsFail="true" |Fail when there are too many repetitions of a value +|enforceERRSegmentRepeatability="true"|Enforces the ERR Segment repeatability (count) in the Acknowledgment. +|=== + +== Next Step + +After you complete connector configuration, you can try +the xref:hl7-connector-examples.adoc[Examples]. + +== See Also + +* xref:connectors::introduction/introduction-to-anypoint-connectors.adoc[Introduction to Anypoint Connectors] +* https://help.mulesoft.com[MuleSoft Help Center] diff --git a/hl7/4.3/modules/ROOT/pages/hl7-connector-examples.adoc b/hl7/4.3/modules/ROOT/pages/hl7-connector-examples.adoc new file mode 100644 index 0000000000..331f4c409e --- /dev/null +++ b/hl7/4.3/modules/ROOT/pages/hl7-connector-examples.adoc @@ -0,0 +1,282 @@ += HL7 EDI - Examples - Mule 4 + +Use the following examples to see how to customize a schema, configure the Message Header (MSH) application and facility identification for you and your trading partner, and view a test flow with an HTTP Listener that initiates a flow. + +== Simplify a Schema Using Example Messages + +The HL7 standard definitions are very complex, with segments often +having twenty or more components. Many of these components are broken down into subcomponents. This component nesting can +make mapping HL7 difficult, since the DataSense view of the message +has to contain all these subcomponents. + +In practice, most users of HL7 populate only a small fraction of the +total HL7 standard definitions. To take advantage of this, HL7 +EDI Connector provides a console-based Java tool you can use to +simplify your schema definitions by eliminating components that +are not normally used in your messages. + +The schema simplification tool is in the +`hl7-simplify-4.0.0.jar` file, which is found in the standard +MuleSoft enterprise Maven repositories (under group ID `com.mulesoft.connectors`). +The tool accepts a message structure schema and one or more example messages +(as separate files) as input, and generates an output schema reduced to only those segments and components present in one or more of +the sample messages. + +To use this tool, download the `JAR` and open a command line console, then type: + +[source,console] +---- +java -jar hl7-simplify-4.0.0.jar {input-schema} {output-schema} {sample1} {sample2} ... +---- + +The placeholders in this syntax represent the following values: + +* `input-schema` ++ +Message structure schema used to read the messages, +which can be a file or a classpath reference to a supplied schema +such as the `/hl7/v2_5_1/ADT_A05.esl` path. +* `output-schema` ++ +File path for the simplified schema output. +* `sample1...n` ++ +File paths to the sample messages. + +Ensure that each sample message file is saved with a carriage return (CR) +line ending, which is the required HL7 segment delimiter. Text editors +generally use the default line ending for your operating system, and this might not be correct. + +Here's a partial example of a simplified schema generated using this tool: + +[source,yaml,linenums] +---- +form: HL7 +version: '2.5.1' +structures: +- id: 'SIU_S12' + name: 'SIU_S12' + data: + - { idRef: 'MSH', position: '01', usage: O } + - { idRef: 'SCH', position: '02', usage: O } + - groupId: 'PATIENT' + count: '>1' + usage: O + items: + - { idRef: 'PID', position: '06', usage: O } + - { idRef: 'PV1', position: '08', usage: O } + - groupId: 'RESOURCES' + count: '>1' + usage: O + items: + - { idRef: 'RGS', position: '14', usage: O } + - groupId: 'SERVICE' + count: '>1' + usage: O + items: + - { idRef: 'AIS', position: '16', usage: O } + - groupId: 'GENERAL_RESOURCE' + count: '>1' + usage: O + items: + - { idRef: 'AIG', position: '20', usage: O } + - groupId: 'LOCATION_RESOURCE' + count: '>1' + usage: O + items: + - { idRef: 'AIL', position: '24', usage: O } + - groupId: 'PERSONNEL_RESOURCE' + count: '>1' + usage: O + items: + - { idRef: 'AIP', position: '28', usage: O } +segments: +- id: 'AIG' + name: 'Appointment Information - General Resource' + varTag: 'AIG' + values: + - { idRef: 'SI', name: 'Set ID - AIG', usage: O } + - { idRef: 'varies', name: 'Segment Action Code', usage: U, count: '>1' } + - { idRef: 'CE_2', name: 'Resource ID', usage: O } + - { idRef: 'varies', name: 'Resource Type', usage: U, count: '>1' } + - { idRef: 'varies', name: 'Resource Group', usage: U, count: '>1' } + - { idRef: 'varies', name: 'Resource Quantity', usage: U, count: '>1' } + - { idRef: 'varies', name: 'Resource Quantity Units', usage: U, count: '>1' } + - { idRef: 'TS', name: 'Start Date/Time', usage: O } +- id: 'AIL' + name: 'Appointment Information - Location Resource' + varTag: 'AIL' + values: + - { idRef: 'SI', name: 'Set ID - AIL', usage: O } + - { idRef: 'varies', name: 'Segment Action Code', usage: U, count: '>1' } + - { idRef: 'PL', name: 'Location Resource ID', usage: O, count: '>1' } + - { idRef: 'CE', name: 'Location Type-AIL', usage: O } + - { idRef: 'varies', name: 'Location Group', usage: U, count: '>1' } + - { idRef: 'TS', name: 'Start Date/Time', usage: O } +- id: 'AIP' + name: 'Appointment Information - Personnel Resource' + varTag: 'AIP' + values: + - { idRef: 'SI', name: 'Set ID - AIP', usage: O } + - { idRef: 'varies', name: 'Segment Action Code', usage: U, count: '>1' } + - { idRef: 'XCN_2', name: 'Personnel Resource ID', usage: O, count: '>1' } + - { idRef: 'CE_1', name: 'Resource Type', usage: O } + - { idRef: 'varies', name: 'Resource Group', usage: U, count: '>1' } + - { idRef: 'TS', name: 'Start Date/Time', usage: O } +... +composites: +- id: 'CE' + name: 'Coded Element' + values: + - { idRef: 'ST', name: 'Identifier', usage: O } + - { idRef: 'ST', name: 'Text', usage: O } +- id: 'CE_1' + name: 'Coded Element' + values: + - { idRef: 'ST', name: 'Identifier', usage: O } +- id: 'CE_2' + name: 'Coded Element' + values: + - { idRef: 'ST', name: 'Identifier', usage: O } + - { idRef: 'ST', name: 'Text', usage: O } + - { idRef: 'ID', name: 'Name of Coding System', usage: O } +... +---- + +Because unused components of a segment cannot be dropped from the segment +definition unless they're at the end of the segment, the simplification +tool substitutes a `varies` data type for the component and marks it +with `Usage: U` for Unused. The repetition count for `varies` remains the +same as for the original component, but it does not display +in the DataSense view of the data you see in DataWeave. + +When the schema simplification tool checks for data present in the +messages, it handles each occurrence of a composite in context. Different +uses of the same composite might have different values present in your samples. When this happens, the composite is defined more than once, using different identifiers. + +The simplified schema retains the segment positions from the original schema. +You can delete these position values from the simplified schema, +because they're not used by HL7 EDI Connector unless you use position +prefixes on segment keys (one of the connector configuration options). + +=== Example: HL7 Studio + +The following flow can be loaded from the XML. +//// +image::hl7-connector-flow-in-studio.png[Example flow in Studio] +//// + +[source,xml,linenums] +---- + + + + + + + + + + + + + + + + + + + + + + + +---- + +== Set Your HL7 Identification in XML + +You can configure the Message Header (MSH) application and facility identification for you and your trading partner in the HL7 EDI connector configuration. + +The values you set are used when writing HL7 messages to supply the namespace ID, universal ID, and universal ID type, and are verified in receive messages. If you don't want to restrict incoming messages you can leave these blank, and set the values for outgoing messages on the write operation or the actual outgoing message. Values set on the write operation override the connector configuration, and values set directly on the message override both the connector configuration and any values set on the write operation. + +* Self-identification parameters identify your side of the trading partner relationship. ++ +Self-identification parameters: ++ +[source,text,linenums] +---- +appNamespaceIdSelf="" +appUniversalIdSelf="" +appUniversalIdTypeSelf="" +---- ++ +* Partner-identification parameters identify your trading partner. ++ +Partner-identification parameters: ++ +[source,text,linenums] +---- +appNamespaceIdPartner="" +appUniversalIdPartner="" +appUniversalIdTypePartner="" +---- + +== Reading and Validating HL7 ER7 Messages + +To read an HL7 message: + +. Search the palette for *HL7 EDI* and drag it into a flow. + +. From the properties view, select the previously created connector configuration and then the `Read` operation. ++ +This operation reads any byte stream into the structure as described by your HL7 schemas. ++ + +HL7 EDI validates the message structure when read: + +* Checking the syntax and content of the MSH and all component segments of the message. + +* The generated ACK message logs, accumulates, and reports errors provided in the generated data structure. + +* All messages, whether error-free or with non-fatal errors, are passed on for processing as part of the output message map. + +* Reading input data errors can throw exceptions. + +Error data entered in the receive data map uses the HL7Error class, a read-only JavaBean with the following properties: + +[%header,cols="30a,70a"] +|=== +|Property |Description +|`segment` |Zero-based index within the input of the segment causing the error +|`fatal` |Flag for a fatal error, meaning the associated message was rejected as a result of the error +|`errorType` |Enumeration for the different types of errors defined by the HL7 standards (ERR-3 values) +|`errorCode` |Error code, as defined by the HL7 standard for the indicated type of error +|`errorText` |Text description of the error +|=== + +The `Read` operation returns error data as an optional list with the `Errors` key. + +== See Also + +* xref:connectors::introduction/introduction-to-anypoint-connectors.adoc[Introduction to Anypoint Connectors] +* https://help.mulesoft.com[MuleSoft Help Center] diff --git a/hl7/4.3/modules/ROOT/pages/hl7-connector-reference.adoc b/hl7/4.3/modules/ROOT/pages/hl7-connector-reference.adoc new file mode 100644 index 0000000000..eaddb11f71 --- /dev/null +++ b/hl7/4.3/modules/ROOT/pages/hl7-connector-reference.adoc @@ -0,0 +1,360 @@ += HL7 EDI Connector 4.3 Reference +:page-aliases: connectors::hl7/hl7-connector-reference.adoc + +== Configurations +--- +[[config]] +=== Config + + +==== Parameters + +[%header%autowidth.spread] +|=== +| Name | Type | Description | Default Value | Required +|Name | String | Name for this configuration. Connectors reference the configuration with this name. | |x +| Connection a| Connection + | Connection type for this configuration.| |x +| Expiration Policy a| ExpirationPolicy | Configures the minimum amount of time that a dynamic configuration instance can remain idle before Mule considers it eligible for expiration. This does not mean that the instance expires at the exact moment that it becomes eligible. Mule purges the instances when appropriate. | | +| Mule application namespace ID (MSH-3-1/MSH-5-1) a| String a| Application namespace ID for Mule in the message header (MSH segment). If set, this value affects both receive and send message handling: + +* On the receive side, the MSH receiving application namespace ID must match this value. +* On the send side, the connector uses this value as the MSH sending application namespace ID unless the send configuration or message parameters override it. | | +| Mule Application universal ID (MSH-3-2/MSH-5-2) a| String a| Application universal ID for Mule in the message header (MSH segment). If set, this value affects both receive and send message handling: + +* On the receive side, the MSH receiving application universal ID must match this value. +* On the send side, the connector uses this value as the MSH sending application universal ID unless it is overridden in the send configuration or message parameters. | | +| Mule Application universal ID Type (MSH-3-3/MSH-5-3) a| String a| Application universal ID type for Mule in the message header (MSH segment). If set, this value affects both receive and send message handling: + +* On the receive side, the MSH receiving application universal ID type must match this value. +* On the send side, the connector uses this value as the MSH sending application universal ID type unless it is overridden in the send configuration or message parameters. | | +| Partner Application Namespace ID (MSH-3-1/MSH-5-1) a| String a| Application namespace ID for the partner in the message header (MSH segment). If set, this value affects both receive and send message handling: + +* On the receive side, the MSH sending application namespace ID must match this value. +* On the send side, the connector uses this value as the MSH sending application namespace ID unless it is overridden in the send configuration or message parameters. | | +| Partner Application universal ID (MSH-3-2/MSH-5-2) a| String a| Application universal ID for the partner in the message header (MSH segment). If set, this value affects both receive and send message handling: + +* On the receive side, the MSH sending application universal ID must match this value. +* On the send side, the connector uses this value as the MSH sending application universal ID unless it is overridden in the send configuration or message parameters. | | +| Partner Application universal ID Type (MSH-3-3/MSH-5-3) a| String a| Application universal ID type for the partner in the message header (MSH segment). If set, this value affects both receive and send message handling: + +* On the receive side, the MSH sending application universal ID type must match this value. +* On the send side, the connector uses this value as the MSH sending application universal ID type unless it is overridden in the send configuration or message parameters. | | +| Schema definitions a| Array of String | List of schema paths for the connector to use. The paths can be filesystem paths or classpaths. | |x +| Event and message to message structure map path a| String a| Path to a YAML file that defines the mapping of the event code and message code to the message structure ID: + +* If working with multiple message structures, this mapping definition supports using MSH-9-1 and MSH-9-2 to determine the message structure when MSH-9-3 is not present in a message. +* If only a single message structure is present in the schemas for which this message structure is used, the connector uses the message structure to parse all messages. +* If MSH-9-3 is present in a message, the connector ignores the MSH-9-1 and MSH-9-2 values. | | +| HL7 Message character encoding a| Enumeration, one of: + +** ASCII +** BIG_5 +** EUC_KR +** EUC_TW +** GB_18030 +** ISO_8859_1 +** ISO_8859_15 +** ISO_8859_2 +** ISO_8859_3 +** ISO_8859_4 +** ISO_8859_5 +** ISO_8859_6 +** ISO_8859_7 +** ISO_8859_8 +** ISO_8859_9 +** JIS0208 +** JIS_X0201 +** JIS_X0212 +** UTF_16 +** UTF_32 +** UTF_8 +| Character encoding for HL7 messages. This is the default for receive messages when MSH-18 is not present and for send messages when MSH-18 is not present in the send message data. | ASCII | +| Disable numeric prefixes for data keys a| Boolean | Uses segment and group IDs directly as keys in the data, rather than prefixing the segment and group IDs with position values. | true | +| Required processing ID a| Enumeration, one of: + +** DEBUGGING +** PRODUCTION +** TRAINING | Value to match the MSH-11-1 processing ID. If set, only messages with the specified processing ID are accepted for processing. Messages with other processing ID values or with no processing ID specified are rejected with an exception. | | +| Pattern for generic extension segment names a| String | Java regular pattern for segment names to treat as generic extension segments. If specified, segment names matching this pattern are allowed anywhere in the message and are converted to maps of string values for elements and composites. | | +| Fail when required value missing a| Boolean a| Whether to reject a message if a required value is missing: + +* If `true`, a message with this error is rejected. +* If `false`, the value is ignored and the message is accepted. + +In either case, the error is logged and reported in an ERR segment. | false | +| Fail when value length outside allowed range a| Boolean a| Whether to reject a message if the receive value length is outside of allowed the range: + +* If `true`, a message with this error is rejected. +* If `false`, the value is used and the message is accepted. + +In either case, the error is logged and reported in an ERR segment. | false | +| Fail when invalid character in value a| Boolean a| Whether to reject a message if the receive value contains an invalid character: + +* If `true`, a message with this error is rejected. +* If `false`, the character is either passed through or substituted, and the message is accepted. + +In either case the error is reported in an ERR segment. | false | +| Fail when too many repeats of value a| Boolean a| Whether to reject a message if the receive value is repeated too many times: + +* If `true`, a message with this error is rejected. +* If `false`, the value is accepted and the message is accepted. + +In either case the error is reported in an ERR segment. | false | +| Fail when unknown segment in message a| Boolean a| Whether to reject a message if it contains an unknown segment: + +* If `true`, a message with this error is rejected. +* If `false`, the segment is ignored and the message is accepted. + +In either case the error is reported in an ERR segment. | false | +| Fail when segment out of order in message set a| Boolean a| Whether to reject a message when a segment in a message set is out of order: + +* If `true`, a message with this error is rejected. +* If `false` and the segment can be reordered, the message is accepted. + +In either case the error is reported in an ERR segment. | false | +| Fail when unused segment included in message set a| Boolean a| Whether to reject a message when a segment marked as unused is included in a message set: + +* If `true`, a message with this error is rejected. +* If `false`, the message is accepted and the unused segment is ignored. + +In either case the error is reported in an ERR segment. | false | +| Fail when too many repeats of segment a| Boolean a| Whether to reject a message when a segment occurs too many times in a message set: + +* If `true`, a message with this error is rejected. +* If `false`, the message is accepted. + +In either case, the error is reported in an ERR segment. | false | +| HL7 Message segment terminator a| Enumeration, one of: + +** CR +** LF | Value for the segment terminator. | CR | +| Enforce Acknowledgment ERR Segment repeatability a| Boolean a| Whether to enforce the ERR Segment repeatability (count) in the Acknowledgment: + +* If `true` and the ERR segment count is not 1, errors will be added to the ERR-01 (ELD) in a single ERR segment. +* If `false`, every error will be added to the ERR list. + +In either case, the error is reported in an ERR segment. | false | +|=== + +[[config_connection]] +== Connection Type + +=== Parameters + +[%header%autowidth.spread] +|=== +| Name | Type | Description | Default Value | Required +| Reconnection a| <> | Configures a reconnection strategy to use when a connector operation fails to connect to an external server. + | | +|=== + +== Operations + +* <> +* <> + +[[read]] +=== Read + +`` + +==== Parameters + +[%header%autowidth.spread] +|=== +| Name | Type | Description | Default Value | Required +| Configuration | String | Name of the configuration to use. | |x +| Read Content a| Binary | Input payload.| `#[payload]` | +| Target Variable a| String | Name of the variable that stores the operation's output.| | +| Target Value a| String | Expression that evaluates the operation’s output. The outcome of the expression is stored in the *Target Variable* field. | `#[payload]` | +| Reconnection Strategy a| +* None +* <> +* <> | Reconnection strategy to use. | | +|=== + +==== Output + +[cols=".^50%,.^50%"] +|=== +| Type a| Object +|=== + +==== For Configurations + +* config + +==== Throws + +* HL7:RETRY_EXHAUSTED +* HL7:UNKNOWN +* HL7:PARSE +* HL7:SCHEMA +* HL7:CONNECTIVITY +* HL7:WRITE + + +[[write]] +=== Write + +`` + +==== Parameters + +[%header%autowidth.spread] +|=== +| Name | Type | Description | Default Value | Required +| Configuration | String | Name of the configuration to use. | |x +| Write Content a| Object | Output payload. | `#[payload]` | +| Streaming Strategy a| * <> +* <> +* <> | Configures how Mule processes streams. Repeatable streams are the default behavior. | | +| Target Variable a| String | The name of a variable that stores the output of the operation. | | +| Target Value a| String | Expression that evaluates the operation’s output. The outcome of the expression is stored in the *Target Variable* field. | `#[payload]` | +| Reconnection Strategy a| +* None +* <> +* <> | Reconnection strategy to use. | | +|=== + +==== Output + +[cols=".^50%,.^50%"] +|=== +| Type a| Binary +|=== + +==== For Configurations + +* config + +==== Throws + +* HL7:RETRY_EXHAUSTED +* HL7:UNKNOWN +* HL7:PARSE +* HL7:SCHEMA +* HL7:CONNECTIVITY +* HL7:WRITE + + + +== Types + +[[ExpirationPolicy]] +=== Expiration Policy + +Configures the maximum amount of time that a dynamic configuration instance can remain idle before Mule considers it eligible for expiration. + +[%header%autowidth.spread] +|=== +| Field | Type | Description | Default Value | Required +| Max Idle Time a| Number | Maximum amount of time that a dynamic configuration instance can remain idle before Mule considers it eligible for expiration. | | +| Time Unit a| Enumeration, one of: + +** NANOSECONDS +** MICROSECONDS +** MILLISECONDS +** SECONDS +** MINUTES +** HOURS +** DAYS | A time unit that qualifies the *Max Idle Time* field. | | +|=== + +[[forever]] +=== Forever + +Configures a forever reconnection strategy by which the connector operation attempts to reconnect at a specified frequency for as long as the Mule app runs. + +[%header%autowidth.spread] +|=== +| Field | Type | Description | Default Value | Required +| Frequency | Number| How often to attempt to reconnect, in milliseconds.| | +|=== + +[[non-repeatable-stream]] +=== Non-Repeatable Stream + +Disables the repeatable stream functionality and uses non-repeatable streams to have lower performance overhead, memory use, and cost. + +[[reconnection]] +=== Reconnection + +Configures reconnection options. + +[%header%autowidth.spread] +|=== +| Field | Type | Description | Default Value | Required +| Fails deployment when test connection fails a| Boolean a| What to do if, when an app is deployed, a connectivity test does not pass after exhausting the associated reconnection strategy: + +* true ++ +Allow the deployment to fail. ++ +* false ++ +Ignore the results of the connectivity test. +| | +| Reconnection Strategy a| +* None +* <> +* <> | Reconnection strategy to use. | | +|=== + +[[repeatable-file-store-stream]] +=== Repeatable File Store Stream + +Configures the repeatable file store streaming strategy by which Mule keeps a portion of the stream content in memory. If the stream content is larger than the configured buffer size, Mule backs up the buffer’s content to disk and then clears the memory. + +[%header%autowidth.spread] +|=== +| Field | Type | Description | Default Value | Required +| Max In Memory Size a| Number a| Maximum amount of memory that the stream can use for data. If the amount of memory exceeds this value, Mule buffers the content to disk. To optimize performance: + +* Configure a larger buffer size to avoid the number of times Mule needs to write the buffer on disk. This increases performance, but it also limits the number of concurrent requests your application can process, because it requires additional memory. + +* Configure a smaller buffer size to decrease memory load at the expense of response time. | | +| Buffer Unit a| Enumeration, one of: + +** BYTE +** KB +** MB +** GB | Unit for the *Max In Memory Size* field. | | +|=== + +[[repeatable-in-memory-stream]] +=== Repeatable In Memory Stream + +Configures the in-memory streaming strategy by which the request fails if the data exceeds the maximum buffer size. Always run performance tests to find the optimal buffer size for your specific use case. + +[%header%autowidth.spread] +|=== +| Field | Type | Description | Default Value | Required +| Initial Buffer Size a| Number | Initial amount of memory to allocate to the data stream. If the streamed data exceeds this value, the buffer expands by the *Buffer Size Increment*, with an upper limit of the *Max Buffer Size* value. | | +| Buffer Size Increment a| Number | Amount by which the buffer size expands if it exceeds its initial size. Setting a value of `0` or lower specifies that the buffer can't expand. | | +| Max Buffer Size a| Number | Maximum size of the buffer. If the buffer size exceeds this value, Mule raises a `STREAM_MAXIMUM_SIZE_EXCEEDED` error. A value of less than or equal to `0` means no limit.| | +| Buffer Unit a| Enumeration, one of: + +** BYTE +** KB +** MB +** GB | Unit for the *Initial Buffer Size*, *Buffer Size Increment*, and *Max Buffer Size* fields.| | +|=== + +[[standard]] +=== Standard + +Configures a standard reconnection strategy, which specifies how often to reconnect and how many reconnection attempts the connector operation can make. + +[%header%autowidth.spread] +|=== +| Field | Type | Description | Default Value | Required +| Frequency a| Number | How often to attempt to reconnect, in milliseconds. | | +| Reconnection Attempts a| Number | How many reconnection attempts the Mule app can make. | | +|=== + +== See Also + +* xref:connectors::introduction/introduction-to-anypoint-connectors.adoc[Introduction to Anypoint Connectors] +* https://help.mulesoft.com[MuleSoft Help Center] diff --git a/hl7/4.3/modules/ROOT/pages/hl7-connector-studio.adoc b/hl7/4.3/modules/ROOT/pages/hl7-connector-studio.adoc new file mode 100644 index 0000000000..fe939aee34 --- /dev/null +++ b/hl7/4.3/modules/ROOT/pages/hl7-connector-studio.adoc @@ -0,0 +1,110 @@ += Using Anypoint Studio to Configure HL7 EDI Connector - Mule 4 +ifndef::env-site,env-github[] +include::_attributes.adoc[] +endif::[] + +Anypoint Studio (Studio) editors help you design and update your Mule applications, properties, and configuration files. + +To add and configure a connector in Studio: + +. <>. +. <>. +. <>. +. <>. +. <>. +. <>. + +When you run the connector, you can view the app log to check for problems in real time, as described in <>. + +If you are new to configuring connectors in Studio, see xref:connectors::introduction/intro-config-use-studio.adoc[Using Anypoint Studio to Configure a Connector]. If, after reading this topic, you need additional information about the connector fields, see the xref:hl7-connector-reference.adoc[HL7 EDI Reference]. + +[[create-mule-project]] +== Create a Mule Project + +In Studio, create a new Mule project in which to add and configure the connector: + +. In Studio, select *File > New > Mule Project*. +. Enter a name for your Mule project and click *Finish*. + +[[add-connector-to-project]] +== Add the Connector to Your Mule Project + +Add HL7 EDI Connector to your Mule project to automatically populate the XML code with the connector's namespace and schema location and add the required dependencies to the project's `pom.xml` file: + +. In the *Mule Palette* view, click *(X) Search in Exchange*. +. In the *Add Dependencies to Project* window, type `HL7` in the search field. +. Click HL7 EDI in *Available modules*. +. Click *Add*. +. Click *Finish*. + +Adding a connector to a Mule project in Studio does not make that connector available to other projects in your Studio workspace. + +[[configure-source]] +== Configure a Source + +A source initiates a flow when a specified condition is met. +You can configure HTTP Listener as the source for the HL7 EDI Connector to initiate a flow each time the listener receives a request on the configured host and port. + +To configure an HTTP Listener source, follow these steps: + +. In the *Mule Palette* view, select *HTTP > Listener*. +. Drag *Listener* to the Studio canvas. +. On the *Listener* configuration screen, optionally change the value of the *Display Name* field. +. Specify a value for the *Path* field. +. Click the plus sign (*+*) next to the *Connector configuration* field to configure a global element that can be used by all instances of the HTTP Listener source in the app. +. On the *General* tab, specify connection information for the connector. +. On the *TLS* tab, optionally specify the TLS information for the connector. +. On the *Advanced* tab, optionally specify reconnection information, including a reconnection strategy. +. Click *Test Connection* to confirm that Mule can connect with the specified server. +. Click *OK*. + +[[add-connector-operation]] +== Add a Connector Operation to the Flow + +When you add a connector operation to your flow, you are specifying an action for that connector to perform. + +To add an operation for HL7 EDI Connector, follow these steps: + +. In the *Mule Palette* view, select *HL7* and then select the desired operation. +. Drag the operation onto the Studio canvas to the right of the input source. + +[[configure-global-element]] +== Configure a Global Element for the Connector + +When you configure a connector, configure a global element that all instances of that connector in the app can use. Configuring a global element requires you to provide the authentication credentials that the connector requires to access the target HL7 EDI system. + +To configure the global element for HL7 EDI Connector, follow these steps: + +. Select the operation in the Studio canvas. +. In the configuration screen for the operation, click the plus sign (*+*) next to the *Connector configuration* field to access the global element configuration fields. ++ +You can reference a configuration file that contains ANT-style property placeholders (recommended), or you can enter your authorization credentials in the global configuration properties. + +. On the *Advanced* tab, optionally specify reconnection information, including a reconnection strategy. +. Click *Test Connection* to confirm that Mule can connect with the specified server. +. Click *OK*. + +[[configure-other-fields]] +== Configure Additional Connector Fields + +After you configure a global element for HL7, configure the other required fields for the connector. The required fields vary depending on which connector operation you use. + +[[view-app-log]] + +== View the App Log + +To check for problems, you can view the app log as follows: + +* If you’re running the app from Anypoint Platform, the output is visible in the Anypoint Studio console window. +* If you’re running the app using Mule from the command line, the app log is visible in your OS console. + +Unless the log file path is customized in the app’s log file (`log4j2.xml`), you can also view the app log in the default location `MULE_HOME/logs/.log`. + +== Next Step + +See xref:hl7-connector-config-topics.adoc[Additional Configuration Information] for more configuration steps. + +== See Also + +* xref:hl7-connector-reference.adoc[HL7 EDI Connector Reference] +* https://help.mulesoft.com[MuleSoft Help Center] diff --git a/hl7/4.3/modules/ROOT/pages/hl7-connector-xml-maven.adoc b/hl7/4.3/modules/ROOT/pages/hl7-connector-xml-maven.adoc new file mode 100644 index 0000000000..8ecfe0da81 --- /dev/null +++ b/hl7/4.3/modules/ROOT/pages/hl7-connector-xml-maven.adoc @@ -0,0 +1,80 @@ += HL7 EDI - XML and Maven Support - Mule 4 +ifndef::env-site,env-github[] +include::_attributes.adoc[] +endif::[] + +Although you can manually code a Mule app in XML, it is more efficient to use Anypoint Studio: + +* If you manually code a Mule runtime engine (Mule) app in XML either from the Anypoint Studio XML editor or from a text editor, you can access the connector from your app by adding reference statements to both your XML Mule flow and the Apache Maven `pom.xml` file. +* If you add the connector in Studio, Studio automatically populates the XML code with the connector's namespace and schema location and it also adds a dependency to the `pom.xml` file. + +== Add a Namespace for the Connector + +Paste the following code inside the `mule` tag of the header of your configuration XML: + +[source,xml,linenums] +---- +http://www.mulesoft.org/schema/mule/hl7 +http://www.mulesoft.org/schema/mule/hl7/current/mule-hl7.xsd +---- + +This example shows how the namespace statements are placed in the XML: + +[source,xml,linenums] +---- + +---- + +// Ensure that XML code examples have line breaks after XML elements +// to reduce the need for users to scroll the code horizontally to read it. + +== Add a POM File Dependency + +The Apache Maven `pom.xml` file generated by Anypoint Studio contains dependencies +for a Mule app. When you code a Mule app manually, include this XML snippet in +your `pom.xml` file to enable access to this connector: + +[source,xml,linenums] +---- + + com.mulesoft.connectors + mule-hl7-extension + x.x.x + mule-plugin + +---- + +Replace `` with the version that corresponds to the connector you are using. + +To obtain the most up-to-date `pom.xml` file information: + +. Go to https://www.mulesoft.com/exchange/[Anypoint Exchange]. +. In Exchange, click *Login* and supply your Anypoint Platform username and password. +. In Exchange, search for `HL7 EDI`. +. Select the connector. +. Click *Dependency Snippets* near the upper right of the screen. + +== Next Step + +After completing your namespace and `pom.xml` file, you can try the xref:hl7-connector-examples.adoc[Examples]. + +== See Also + +* xref:connectors::introduction/introduction-to-anypoint-connectors.adoc[Introduction to Anypoint Connectors] +* https://help.mulesoft.com[MuleSoft Help Center] diff --git a/hl7/4.3/modules/ROOT/pages/hl7-schemas.adoc b/hl7/4.3/modules/ROOT/pages/hl7-schemas.adoc new file mode 100644 index 0000000000..7a36cf1ea2 --- /dev/null +++ b/hl7/4.3/modules/ROOT/pages/hl7-schemas.adoc @@ -0,0 +1,2341 @@ += HL7 Supplied Schemas +:page-aliases: connectors::hl7/hl7-schemas.adoc + +These are the message structures included in the schema +definitions for each version of HL7. + +== Version 2.1 + +ACK + +ADR_A19 +ADT_A01 +ADT_A02 +ADT_A03 +ADT_A04 +ADT_A05 +ADT_A06 +ADT_A07 +ADT_A08 +ADT_A09 +ADT_A10 +ADT_A11 +ADT_A12 +ADT_A13 +ADT_A14 +ADT_A15 +ADT_A16 +ADT_A17 +ADT_A18 +ADT_A20 +ADT_A21 +ADT_A22 +ADT_A23 +ADT_A24 + +BAR_P01 +BAR_P02 + +DFT_P03 +DSR_Q01 +DSR_Q03 + +MCF_Q02 + +ORM_O01 +ORR_O02 +ORU_R01 +ORU_R03 + +QRY_A19 +QRY_Q01 +QRY_Q02 + +UDM_Q05 + +== Version 2.2 + +ACK + +ADR_A19 +ADT_A01 +ADT_A02 +ADT_A03 +ADT_A04 +ADT_A05 +ADT_A06 +ADT_A07 +ADT_A08 +ADT_A09 +ADT_A10 +ADT_A11 +ADT_A12 +ADT_A13 +ADT_A14 +ADT_A15 +ADT_A16 +ADT_A17 +ADT_A18 +ADT_A20 +ADT_A21 +ADT_A22 +ADT_A23 +ADT_A24 +ADT_A25 +ADT_A26 +ADT_A27 +ADT_A28 +ADT_A29 +ADT_A30 +ADT_A31 +ADT_A32 +ADT_A33 +ADT_A34 +ADT_A35 +ADT_A36 +ADT_A37 + +BAR_P01 +BAR_P02 + +DFT_P03 +DSR_P04 +DSR_Q01 +DSR_Q03 +DSR_R03 + +MFD_M01 +MFD_M02 +MFD_M03 +MFK_M01 +MFK_M02 +MFK_M03 +MFN_M01 +MFN_M02 +MFN_M03 +MFQ_M01 +MFQ_M02 +MFQ_M03 +MFR_M01 +MFR_M02 +MFR_M03 +NMD_N01 +NMQ_N02 +NMR_N02 + +ORD_O02 +ORF_R04 +ORM_O01 +ORN_O02 +ORR_O02 +ORU_R01 +ORU_R03 + +QRY_A19 +QRY_P04 +QRY_Q01 +QRY_Q02 +QRY_R02 + +UDM_Q05 + +== Version 2.3 + +ACK + +ADR_A19 +ADT_A01 +ADT_A02 +ADT_A03 +ADT_A04 +ADT_A05 +ADT_A06 +ADT_A07 +ADT_A08 +ADT_A09 +ADT_A10 +ADT_A11 +ADT_A12 +ADT_A13 +ADT_A14 +ADT_A15 +ADT_A16 +ADT_A17 +ADT_A18 +ADT_A20 +ADT_A21 +ADT_A22 +ADT_A23 +ADT_A24 +ADT_A25 +ADT_A26 +ADT_A27 +ADT_A28 +ADT_A29 +ADT_A30 +ADT_A31 +ADT_A32 +ADT_A33 +ADT_A34 +ADT_A35 +ADT_A36 +ADT_A37 +ADT_A38 +ADT_A39 +ADT_A40 +ADT_A41 +ADT_A42 +ADT_A43 +ADT_A44 +ADT_A45 +ADT_A46 +ADT_A47 +ADT_A48 +ADT_A49 +ADT_A50 +ADT_A51 + +BAR_P01 +BAR_P02 +BAR_P05 +BAR_P06 + +CRM_C01 +CRM_C02 +CRM_C03 +CRM_C04 +CRM_C05 +CRM_C06 +CRM_C07 +CRM_C08 +CSU_C09 +CSU_C10 +CSU_C11 +CSU_C12 + +DFT_P03 +DOC_T12 +DSR_Q01 +DSR_Q02 +DSR_Q03 + +EDR_Q01 +EQQ_Q01 +ERP_Q01 + +MDM_T01 +MDM_T02 +MDM_T03 +MDM_T04 +MDM_T05 +MDM_T06 +MDM_T07 +MDM_T08 +MDM_T09 +MDM_T10 +MDM_T11 +MFK_M01 +MFK_M02 +MFK_M03 +MFK_M04 +MFK_M05 +MFK_M07 +MFN_M01 +MFN_M02 +MFN_M03 +MFN_M04 +MFN_M05 +MFN_M06 +MFN_M07 +MFN_M08 +MFN_M09 +MFN_M10 +MFN_M11 + +OMD_O01 +OMN_O01 +OMS_O01 +ORD_O02 +ORF_R02 +ORF_R04 +ORM_O01 +ORN_O02 +ORR_O02 +ORU_R01 +OSQ_Q06 +OSR_Q06 + +PEX_P07 +PEX_P08 +PGL_PC6 +PGL_PC7 +PGL_PC8 +PIN_I07 +PPG_PCG +PPG_PCH +PPG_PCJ +PPP_PCB +PPP_PCC +PPP_PCD +PPR_PC1 +PPR_PC2 +PPR_PC3 +PPT_PCL +PPV_PCA +PRR_PC5 +PTR_PCF + +QCK_Q02 +QRY_A19 +QRY_PC4 +QRY_PC9 +QRY_PCE +QRY_PCK +QRY_Q01 +QRY_Q02 +QRY_R02 +QRY_T12 + +RAR_RAR +RAS_O01 +RAS_O02 +RCI_I05 +RCL_I06 +RDE_O01 +RDO_O01 +RDR_RDR +RDS_O01 +REF_I12 +REF_I13 +REF_I14 +REF_I15 +RER_RER +RGR_RGR +RGV_O01 +ROR_ROR +RPA_I08 +RPA_I09 +RPA_I10 +RPA_I11 +RPI_I01 +RPI_I04 +RPL_I02 +RPR_I03 +RQA_I08 +RQA_I09 +RQA_I10 +RQA_I11 +RQC_I05 +RQC_I06 +RQI_I01 +RQI_I02 +RQI_I03 +RQP_I04 +RQQ_Q01 +RRA_O02 +RRD_O02 +RRE_O01 +RRG_O02 +RRI_I12 +RRI_I13 +RRI_I14 +RRI_I15 +RRO_O02 + +SIU_S12 +SIU_S13 +SIU_S14 +SIU_S15 +SIU_S16 +SIU_S17 +SIU_S18 +SIU_S19 +SIU_S20 +SIU_S21 +SIU_S22 +SIU_S23 +SIU_S24 +SIU_S26 +SPQ_Q01 +SQM_S25 +SQR_S25 +SRM_S01 +SRM_S02 +SRM_S03 +SRM_S04 +SRM_S05 +SRM_S06 +SRM_S07 +SRM_S08 +SRM_S09 +SRM_S10 +SRM_S11 +SRR_S01 +SRR_S02 +SRR_S03 +SRR_S04 +SRR_S05 +SRR_S06 +SRR_S07 +SRR_S08 +SRR_S09 +SRR_S10 +SRR_S11 +SUR_P09 + +TBR_Q01 + +UDM_Q05 + +VQQ_Q01 +VXQ_V01 +VXR_V03 +VXU_V04 +VXX_V02 + +== Version 2.3.1 + +ACK + +ADR_A19 +ADT_A01 +ADT_A02 +ADT_A03 +ADT_A04 +ADT_A05 +ADT_A06 +ADT_A07 +ADT_A08 +ADT_A09 +ADT_A10 +ADT_A11 +ADT_A12 +ADT_A13 +ADT_A14 +ADT_A15 +ADT_A16 +ADT_A17 +ADT_A18 +ADT_A20 +ADT_A21 +ADT_A22 +ADT_A23 +ADT_A24 +ADT_A25 +ADT_A26 +ADT_A27 +ADT_A28 +ADT_A29 +ADT_A30 +ADT_A31 +ADT_A32 +ADT_A33 +ADT_A34 +ADT_A35 +ADT_A36 +ADT_A37 +ADT_A38 +ADT_A39 +ADT_A40 +ADT_A41 +ADT_A42 +ADT_A43 +ADT_A44 +ADT_A45 +ADT_A46 +ADT_A47 +ADT_A48 +ADT_A49 +ADT_A50 +ADT_A51 + +BAR_P01 +BAR_P02 +BAR_P05 +BAR_P06 + +CRM_C01 +CSU_C09 + +DFT_P03 +DOC_T12 +DSR_Q01 +DSR_Q03 + +EDR_R07 +EQQ_Q04 +ERP_R09 + +MDM_T01 +MDM_T02 +MDM_T03 +MDM_T04 +MDM_T05 +MDM_T06 +MDM_T07 +MDM_T08 +MDM_T09 +MDM_T10 +MDM_T11 +MFK_M01 +MFK_M04 +MFK_M05 +MFK_M06 +MFN_M01 +MFN_M02 +MFN_M03 +MFN_M04 +MFN_M05 +MFN_M06 +MFN_M07 +MFN_M08 +MFN_M09 +MFN_M10 +MFN_M11 +MFQ_M01 +MFR_M01 + +NMD_N02 +NMQ_N01 +NMR_N01 + +OMD_O01 +OMN_O01 +OMS_O01 +ORD_O02 +ORF_R04 +ORM_O01 +ORN_O02 +ORR_O02 +ORS_O02 +ORU_R01 +OSQ_Q06 +OSR_Q06 + +PEX_P07 +PGL_PC6 +PIN_I07 +PPG_PCG +PPP_PCB +PPR_PC1 +PPT_PCL +PPV_PCA +PRR_PC5 +PTR_PCF + +QCK_Q02 +QRY_A19 +QRY_PC4 +QRY_PC9 +QRY_PCE +QRY_PCK +QRY_Q01 +QRY_Q02 +QRY_R02 +QRY_T12 + +RAR_RAR +RAS_O01 +RCI_I05 +RCL_I06 +RDE_O01 +RDO_O01 +RDR_RDR +RDS_O01 +REF_I12 +RER_RER +RGR_RGR +RGV_O01 +ROR_R0R +ROR_ROR +RPA_I08 +RPI_I01 +RPI_I04 +RPL_I02 +RPR_I03 +RQA_I08 +RQC_I05 +RQC_I06 +RQI_I01 +RQI_I02 +RQI_I03 +RQP_I04 +RQQ_Q09 +RRA_O02 +RRD_O02 +RRE_O02 +RRG_O02 +RRI_I12 +RRO_O02 + +SIU_S12 +SPQ_Q08 +SQM_S25 +SQR_S25 +SRM_S01 +SRR_S01 +SUR_P09 + +TBR_R08 + +UDM_Q05 + +VQQ_Q07 +VXQ_V01 +VXR_V03 +VXU_V04 +VXX_V02 + +== Version 2.4 + +ACK + +ADR_A19 +ADT_A01 +ADT_A02 +ADT_A03 +ADT_A05 +ADT_A06 +ADT_A09 +ADT_A15 +ADT_A16 +ADT_A17 +ADT_A18 +ADT_A20 +ADT_A21 +ADT_A24 +ADT_A30 +ADT_A37 +ADT_A38 +ADT_A39 +ADT_A43 +ADT_A45 +ADT_A50 +ADT_A52 +ADT_A54 +ADT_A60 +ADT_A61 + +BAR_P01 +BAR_P02 +BAR_P05 +BAR_P06 +BAR_P10 + +CRM_C01 +CSU_C09 + +DFT_P03 +DFT_P11 +DOC_T12 +DSR_Q01 +DSR_Q03 + +EAC_U07 +EAN_U09 +EAR_U08 +EDR_R07 +EQQ_Q04 +ERP_R09 +ESR_U02 +ESU_U01 + +INR_U06 +INU_U05 + +LSU_U12 + +MDM_T01 +MDM_T02 +MFK_M01 +MFN_M01 +MFN_M02 +MFN_M03 +MFN_M04 +MFN_M05 +MFN_M06 +MFN_M07 +MFN_M08 +MFN_M09 +MFN_M10 +MFN_M11 +MFN_M12 +MFQ_M01 +MFR_M01 + +NMD_N02 +NMQ_N01 +NMR_N01 + +OMD_O03 +OMG_O19 +OML_O21 +OMN_O07 +OMP_O09 +OMS_O05 +ORD_O04 +ORF_R04 +ORG_O20 +ORL_O22 +ORM_O01 +ORN_O08 +ORP_O10 +ORR_O02 +ORS_O06 +ORU_R01 +OSQ_Q06 +OSR_Q06 +OUL_R21 + +PEX_P07 +PGL_PC6 +PMU_B01 +PMU_B03 +PMU_B04 +PPG_PCG +PPP_PCB +PPR_PC1 +PPT_PCL +PPV_PCA +PRR_PC5 +PTR_PCF + +QBP_K13 +QBP_Q11 +QBP_Q13 +QBP_Q15 +QBP_Q21 +QBP_Qnn +QBP_Z73 +QCK_Q02 +QCN_J01 +QRY_A19 +QRY_PC4 +QRY_Q01 +QRY_Q02 +QRY_R02 +QRY_T12 +QSB_Q16 +QVR_Q17 + +RAR_RAR +RAS_O17 +RCI_I05 +RCL_I06 +RDE_O11 +RDR_RDR +RDS_O13 +RDY_K15 +REF_I12 +RER_RER +RGR_RGR +RGV_O15 +ROR_ROR +RPA_I08 +RPI_I01 +RPI_I04 +RPL_I02 +RPR_I03 +RQA_I08 +RQC_I05 +RQI_I01 +RQP_I04 +RQQ_Q09 +RRA_O18 +RRD_O14 +RRE_O12 +RRG_O16 +RRI_I12 +RSP_K11 +RSP_K13 +RSP_K15 +RSP_K21 +RSP_K22 +RSP_K23 +RSP_K24 +RSP_K25 +RSP_Z82 +RSP_Z86 +RSP_Z88 +RSP_Z90 +RTB_K13 +RTB_Knn +RTB_Q13 +RTB_Z74 + +SIU_S12 +SPQ_Q08 +SQM_S25 +SQR_S25 +SRM_S01 +SRR_S01 +SSR_U04 +SSU_U03 +SUR_P09 + +TBR_R08 +TCU_U10 + +UDM_Q05 + +VQQ_Q07 +VXQ_V01 +VXR_V03 +VXU_V04 +VXX_V02 + +== Version 2.5 + +ACK + +ADR_A19 +ADT_A01 +ADT_A02 +ADT_A03 +ADT_A05 +ADT_A06 +ADT_A09 +ADT_A12 +ADT_A15 +ADT_A16 +ADT_A17 +ADT_A18 +ADT_A20 +ADT_A21 +ADT_A24 +ADT_A30 +ADT_A37 +ADT_A38 +ADT_A39 +ADT_A43 +ADT_A45 +ADT_A50 +ADT_A52 +ADT_A54 +ADT_A60 +ADT_A61 + +BAR_P01 +BAR_P02 +BAR_P05 +BAR_P06 +BAR_P10 +BAR_P12 +BPS_O29 +BRP_O30 +BRT_O32 +BTS_O31 + +CRM_C01 +CSU_C09 + +DFT_P03 +DFT_P11 +DOC_T12 +DSR_Q01 +DSR_Q03 + +EAC_U07 +EAN_U09 +EAR_U08 +EDR_R07 +EQQ_Q04 +ERP_R09 +ESR_U02 +ESU_U01 + +INR_U06 +INU_U05 + +LSU_U12 + +MDM_T01 +MDM_T02 +MFK_M01 +MFN_M01 +MFN_M02 +MFN_M03 +MFN_M04 +MFN_M05 +MFN_M06 +MFN_M07 +MFN_M08 +MFN_M09 +MFN_M10 +MFN_M11 +MFN_M12 +MFN_M13 +MFN_M15 +MFN_Znn +MFQ_M01 +MFR_M01 +MFR_M04 +MFR_M05 +MFR_M06 +MFR_M07 + +NMD_N02 +NMQ_N01 +NMR_N01 + +OMB_O27 +OMD_O03 +OMG_O19 +OMI_O23 +OML_O21 +OML_O33 +OML_O35 +OMN_O07 +OMP_O09 +OMS_O05 +ORB_O28 +ORD_O04 +ORF_R04 +ORG_O20 +ORI_O24 +ORL_O22 +ORL_O34 +ORL_O36 +ORM_O01 +ORN_O08 +ORP_O10 +ORR_O02 +ORS_O06 +ORU_R01 +ORU_R30 +OSQ_Q06 +OSR_Q06 +OUL_R21 +OUL_R22 +OUL_R23 +OUL_R24 + +PEX_P07 +PGL_PC6 +PMU_B01 +PMU_B03 +PMU_B04 +PMU_B07 +PMU_B08 +PPG_PCG +PPP_PCB +PPR_PC1 +PPT_PCL +PPV_PCA +PRR_PC5 +PTR_PCF + +QBP_K13 +QBP_Q11 +QBP_Q13 +QBP_Q15 +QBP_Q21 +QBP_Qnn +QBP_Z73 +QCK_Q02 +QCN_J01 + +QRY + +QRY_A19 +QRY_PC4 +QRY_Q01 +QRY_Q02 +QRY_R02 +QSB_Q16 +QVR_Q17 + +RAR_RAR +RAS_O17 +RCI_I05 +RCL_I06 +RDE_O11 +RDR_RDR +RDS_O13 +RDY_K15 +REF_I12 +RER_RER +RGR_RGR +RGV_O15 +ROR_ROR +RPA_I08 +RPI_I01 +RPI_I04 +RPL_I02 +RPR_I03 +RQA_I08 +RQC_I05 +RQI_I01 +RQP_I04 +RQQ_Q09 +RRA_O18 +RRD_O14 +RRE_O12 +RRG_O16 +RRI_I12 +RSP_K11 +RSP_K21 +RSP_K23 +RSP_K25 +RSP_K31 +RSP_Q11 +RSP_Z82 +RSP_Z86 +RSP_Z88 +RSP_Z90 +RTB_K13 +RTB_Knn +RTB_Z74 + +SIU_S12 +SPQ_Q08 +SQM_S25 +SQR_S25 +SRM_S01 +SRR_S01 +SSR_U04 +SSU_U03 +SUR_P09 + +TBR_R08 +TCU_U10 + +UDM_Q05 + +VQQ_Q07 +VXQ_V01 +VXR_V03 +VXU_V04 +VXX_V02 + +== Version 2.5.1 + +ACK + +ADR_A19 +ADT_A01 +ADT_A02 +ADT_A03 +ADT_A05 +ADT_A06 +ADT_A09 +ADT_A12 +ADT_A15 +ADT_A16 +ADT_A17 +ADT_A18 +ADT_A20 +ADT_A21 +ADT_A24 +ADT_A30 +ADT_A37 +ADT_A38 +ADT_A39 +ADT_A43 +ADT_A45 +ADT_A50 +ADT_A52 +ADT_A54 +ADT_A60 +ADT_A61 + +BAR_P01 +BAR_P02 +BAR_P05 +BAR_P06 +BAR_P10 +BAR_P12 +BPS_O29 +BRP_O30 +BRT_O32 +BTS_O31 + +CRM_C01 +CSU_C09 + +DFT_P03 +DFT_P11 +DOC_T12 +DSR_Q01 +DSR_Q03 + +EAC_U07 +EAN_U09 +EAR_U08 +EDR_R07 +EQQ_Q04 +ERP_R09 +ESR_U02 +ESU_U01 + +INR_U06 +INU_U05 + +LSU_U12 + +MDM_T01 +MDM_T02 +MFK_M01 +MFN_M01 +MFN_M02 +MFN_M03 +MFN_M04 +MFN_M05 +MFN_M06 +MFN_M07 +MFN_M08 +MFN_M09 +MFN_M10 +MFN_M11 +MFN_M12 +MFN_M13 +MFN_M15 +MFN_Znn +MFQ_M01 +MFR_M01 +MFR_M04 +MFR_M05 +MFR_M06 +MFR_M07 + +NMD_N02 +NMQ_N01 +NMR_N01 + +OMB_O27 +OMD_O03 +OMG_O19 +OMI_O23 +OML_O21 +OML_O33 +OML_O35 +OMN_O07 +OMP_O09 +OMS_O05 +ORB_O28 +ORD_O04 +ORF_R04 +ORG_O20 +ORI_O24 +ORL_O22 +ORL_O34 +ORL_O36 +ORM_O01 +ORN_O08 +ORP_O10 +ORR_O02 +ORS_O06 +ORU_R01 +ORU_R30 +OSQ_Q06 +OSR_Q06 +OUL_R21 +OUL_R22 +OUL_R23 +OUL_R24 + +PEX_P07 +PGL_PC6 +PMU_B01 +PMU_B03 +PMU_B04 +PMU_B07 +PMU_B08 +PPG_PCG +PPP_PCB +PPR_PC1 +PPT_PCL +PPV_PCA +PRR_PC5 +PTR_PCF + +QBP_Q11 +QBP_Q13 +QBP_Q15 +QBP_Q21 +QBP_Qnn +QBP_Z73 +QCK_Q02 +QCN_J01 + +QRY + +QRY_A19 +QRY_PC4 +QRY_Q01 +QRY_Q02 +QRY_R02 +QSB_Q16 +QVR_Q17 + +RAR_RAR +RAS_O17 +RCI_I05 +RCL_I06 +RDE_O11 +RDR_RDR +RDS_O13 +RDY_K15 +REF_I12 +RER_RER +RGR_RGR +RGV_O15 +ROR_ROR +RPA_I08 +RPI_I01 +RPI_I04 +RPL_I02 +RPR_I03 +RQA_I08 +RQC_I05 +RQI_I01 +RQP_I04 +RQQ_Q09 +RRA_O18 +RRD_O14 +RRE_O12 +RRG_O16 +RRI_I12 +RSP_K11 +RSP_K21 +RSP_K23 +RSP_K25 +RSP_K31 +RSP_Q11 +RSP_Z82 +RSP_Z86 +RSP_Z88 +RSP_Z90 +RTB_K13 +RTB_Knn +RTB_Z74 + +SIU_S12 +SPQ_Q08 +SQM_S25 +SQR_S25 +SRM_S01 +SRR_S01 +SSR_U04 +SSU_U03 +SUR_P09 + +TBR_R08 +TCU_U10 + +UDM_Q05 + +VQQ_Q07 +VXQ_V01 +VXR_V03 +VXU_V04 +VXX_V02 + +== Version 2.6 + +ACK + +ADR_A19 +ADT_A01 +ADT_A02 +ADT_A03 +ADT_A05 +ADT_A06 +ADT_A09 +ADT_A12 +ADT_A15 +ADT_A16 +ADT_A17 +ADT_A18 +ADT_A20 +ADT_A21 +ADT_A24 +ADT_A30 +ADT_A37 +ADT_A38 +ADT_A39 +ADT_A43 +ADT_A45 +ADT_A50 +ADT_A52 +ADT_A54 +ADT_A60 +ADT_A61 + +BAR_P01 +BAR_P02 +BAR_P05 +BAR_P06 +BAR_P10 +BAR_P12 +BPS_O29 +BRP_O30 +BRT_O32 +BTS_O31 + +CRM_C01 +CSU_C09 + +DFT_P03 +DFT_P11 +DOC_T12 +DSR_Q01 +DSR_Q03 + +EAC_U07 +EAN_U09 +EAR_U08 +EHC_E01 +EHC_E02 +EHC_E04 +EHC_E10 +EHC_E12 +EHC_E13 +EHC_E15 +EHC_E20 +EHC_E21 +EHC_E24 +ESR_U02 +ESU_U01 + +INR_U06 +INU_U05 + +LSU_U12 + +MDM_T01 +MDM_T02 +MFK_M01 +MFN_M01 +MFN_M02 +MFN_M03 +MFN_M04 +MFN_M05 +MFN_M06 +MFN_M07 +MFN_M08 +MFN_M09 +MFN_M10 +MFN_M11 +MFN_M12 +MFN_M13 +MFN_M15 +MFN_M16 +MFN_M17 +MFN_Znn +MFQ_M01 +MFR_M01 +MFR_M04 +MFR_M05 +MFR_M06 +MFR_M07 +NMD_N02 +NMQ_N01 +NMR_N01 + +OMB_O27 +OMD_O03 +OMG_O19 +OMI_O23 +OML_O21 +OML_O33 +OML_O35 +OMN_O07 +OMP_O09 +OMS_O05 +OPL_O37 +OPR_O38 +OPU_R25 +ORB_O28 +ORD_O04 +ORF_R04 +ORG_O20 +ORI_O24 +ORL_O22 +ORL_O34 +ORL_O36 +ORM_O01 +ORN_O08 +ORP_O10 +ORR_O02 +ORS_O06 +ORU_R01 +ORU_R30 +OSQ_Q06 +OSR_Q06 +OUL_R21 +OUL_R22 +OUL_R23 +OUL_R24 + +PEX_P07 +PGL_PC6 +PMU_B01 +PMU_B03 +PMU_B04 +PMU_B07 +PMU_B08 +PPG_PCG +PPP_PCB +PPR_PC1 +PPT_PCL +PPV_PCA +PRR_PC5 +PTR_PCF + +QBP_E03 +QBP_E22 +QBP_Q11 +QBP_Q13 +QBP_Q15 +QBP_Q21 +QBP_Qnn +QBP_Z73 +QCK_Q02 +QCN_J01 +QRY_A19 +QRY_PC4 +QRY_Q01 +QRY_Q02 +QRY_R02 +QRY_T12 +QSB_Q16 +QVR_Q17 + +RAR_RAR +RAS_O17 +RCI_I05 +RCL_I06 +RDE_O11 +RDR_RDR +RDS_O13 +RDY_K15 +REF_I12 +RER_RER +RGR_RGR +RGV_O15 +ROR_ROR +RPA_I08 +RPI_I01 +RPI_I04 +RPL_I02 +RPR_I03 +RQA_I08 +RQC_I05 +RQI_I01 +RQP_I04 +RRA_O18 +RRD_O14 +RRE_O12 +RRG_O16 +RRI_I12 +RSP_E03 +RSP_E22 +RSP_K11 +RSP_K21 +RSP_K23 +RSP_K25 +RSP_K31 +RSP_Q11 +RSP_Z82 +RSP_Z86 +RSP_Z88 +RSP_Z90 +RTB_K13 +RTB_Z74 + +SDR_S31 +SDR_S32 +SIU_S12 +SLR_S28 +SQM_S25 +SQR_S25 +SRM_S01 +SRR_S01 +SSR_U04 +SSU_U03 +STC_S33 +SUR_P09 + +TCU_U10 + +UDM_Q05 + +VXQ_V01 +VXR_V03 +VXU_V04 +VXX_V02 + +== Version 2.7 + +ACK + +ADT_A01 +ADT_A02 +ADT_A03 +ADT_A05 +ADT_A06 +ADT_A09 +ADT_A12 +ADT_A15 +ADT_A16 +ADT_A17 +ADT_A20 +ADT_A21 +ADT_A24 +ADT_A37 +ADT_A38 +ADT_A39 +ADT_A43 +ADT_A44 +ADT_A45 +ADT_A50 +ADT_A52 +ADT_A54 +ADT_A60 +ADT_A61 + +BAR_P01 +BAR_P02 +BAR_P05 +BAR_P06 +BAR_P10 +BAR_P12 +BPS_O29 +BRP_O30 +BRT_O32 +BTS_O31 + +CCF_I22 +CCI_I22 +CCM_I21 +CCQ_I19 +CCR_I16 +CCU_I20 +CQU_I19 +CRM_C01 +CSU_C09 + +DFT_P03 +DFT_P11 + +EAC_U07 +EAN_U09 +EAR_U08 +EHC_E01 +EHC_E02 +EHC_E04 +EHC_E10 +EHC_E12 +EHC_E13 +EHC_E15 +EHC_E20 +EHC_E21 +EHC_E24 +ESR_U02 +ESU_U01 + +INR_U06 +INU_U05 + +LSU_U12 + +MDM_T01 +MDM_T02 +MFK_M01 +MFN_M02 +MFN_M04 +MFN_M05 +MFN_M06 +MFN_M07 +MFN_M08 +MFN_M09 +MFN_M10 +MFN_M11 +MFN_M12 +MFN_M13 +MFN_M15 +MFN_M16 +MFN_M17 +MFN_Znn + +NMD_N02 + +OMB_O27 +OMD_O03 +OMG_O19 +OMI_O23 +OML_O21 +OML_O33 +OML_O35 +OML_O39 +OMN_O07 +OMP_O09 +OMS_O05 +OPL_O37 +OPR_O38 +OPU_R25 +ORA_R33 +ORB_O28 +ORD_O04 +ORG_O20 +ORI_O24 +ORL_O22 +ORL_O34 +ORL_O36 +ORL_O40 +ORN_O08 +ORP_O10 +ORS_O06 +ORU_R01 +ORU_R30 +OSM_R26 +OUL_R22 +OUL_R23 +OUL_R24 + +PEX_P07 +PGL_PC6 +PMU_B01 +PMU_B03 +PMU_B04 +PMU_B07 +PMU_B08 +PPG_PCG +PPP_PCB +PPR_PC1 +PPT_PCL +PPV_PCA +PRR_PC5 +PTR_PCF + +QBP_E03 +QBP_E22 +QBP_Q11 +QBP_Q13 +QBP_Q15 +QBP_Q21 +QBP_Qnn +QBP_Z73 +QCN_J01 +QRY_PC4 +QSB_Q16 +QVR_Q17 + +RAS_O17 +RCI_I05 +RCL_I06 +RDE_O11 +RDR_RDR +RDS_O13 +RDY_K15 +REF_I12 +RGV_O15 +RPA_I08 +RPI_I01 +RPI_I04 +RPL_I02 +RPR_I03 +RQA_I08 +RQC_I05 +RQI_I01 +RQP_I04 +RRA_O18 +RRD_O14 +RRE_O12 +RRG_O16 +RRI_I12 +RSP_E03 +RSP_E22 +RSP_K11 +RSP_K21 +RSP_K22 +RSP_K23 +RSP_K25 +RSP_K31 +RSP_K32 +RSP_Z82 +RSP_Z86 +RSP_Z88 +RSP_Z90 +RTB_K13 +RTB_Knn +RTB_Z74 + +SDR_S31 +SDR_S32 +SIU_S12 +SLR_S28 +SRM_S01 +SRR_S01 +SSR_U04 +SSU_U03 +STC_S33 + +TCU_U10 + +UDM_Q05 + +VXU_V04 + +== Version 2.7.1 + +ACK + +ADT_A01 +ADT_A02 +ADT_A03 +ADT_A05 +ADT_A06 +ADT_A09 +ADT_A12 +ADT_A15 +ADT_A16 +ADT_A17 +ADT_A20 +ADT_A21 +ADT_A24 +ADT_A37 +ADT_A38 +ADT_A39 +ADT_A43 +ADT_A44 +ADT_A45 +ADT_A50 +ADT_A52 +ADT_A54 +ADT_A60 +ADT_A61 + +BAR_P01 +BAR_P02 +BAR_P05 +BAR_P06 +BAR_P10 +BAR_P12 +BPS_O29 +BRP_O30 +BRT_O32 +BTS_O31 + +CCF_I22 +CCI_I22 +CCM_I21 +CCQ_I19 +CCR_I16 +CCU_I20 +CQU_I19 +CRM_C01 +CSU_C09 + +DFT_P03 +DFT_P11 + +EAC_U07 +EAN_U09 +EAR_U08 +EHC_E01 +EHC_E02 +EHC_E04 +EHC_E10 +EHC_E12 +EHC_E13 +EHC_E15 +EHC_E20 +EHC_E21 +EHC_E24 +ESR_U02 +ESU_U01 + +INR_U06 +INU_U05 + +LSU_U12 + +MDM_T01 +MDM_T02 +MFK_M01 +MFN_M02 +MFN_M04 +MFN_M05 +MFN_M06 +MFN_M07 +MFN_M08 +MFN_M09 +MFN_M10 +MFN_M11 +MFN_M12 +MFN_M13 +MFN_M15 +MFN_M16 +MFN_M17 +MFN_Znn + +NMD_N02 + +OMB_O27 +OMD_O03 +OMG_O19 +OMI_O23 +OML_O21 +OML_O33 +OML_O35 +OML_O39 +OMN_O07 +OMP_O09 +OMS_O05 +OPL_O37 +OPR_O38 +OPU_R25 +ORA_R33 +ORB_O28 +ORD_O04 +ORG_O20 +ORI_O24 +ORL_O22 +ORL_O34 +ORL_O36 +ORL_O40 +ORN_O08 +ORP_O10 +ORS_O06 +ORU_R01 +ORU_R30 +OSM_R26 +OUL_R22 +OUL_R23 +OUL_R24 + +PEX_P07 +PGL_PC6 +PMU_B01 +PMU_B03 +PMU_B04 +PMU_B07 +PMU_B08 +PPG_PCG +PPP_PCB +PPR_PC1 +PPT_PCL +PPV_PCA +PRR_PC5 +PTR_PCF + +QBP_E03 +QBP_E22 +QBP_Q11 +QBP_Q13 +QBP_Q15 +QBP_Q21 +QBP_Qnn +QBP_Z73 +QCN_J01 +QRY_PC4 +QSB_Q16 +QVR_Q17 + +RAS_O17 +RCI_I05 +RCL_I06 +RDE_O11 +RDR_RDR +RDS_O13 +RDY_K15 +REF_I12 +RGV_O15 +RPA_I08 +RPI_I01 +RPI_I04 +RPL_I02 +RPR_I03 +RQA_I08 +RQC_I05 +RQI_I01 +RQP_I04 +RRA_O18 +RRD_O14 +RRE_O12 +RRG_O16 +RRI_I12 +RSP_E03 +RSP_E22 +RSP_K11 +RSP_K21 +RSP_K22 +RSP_K23 +RSP_K25 +RSP_K31 +RSP_K32 +RSP_Z82 +RSP_Z86 +RSP_Z88 +RSP_Z90 +RTB_K13 +RTB_Knn +RTB_Z74 + +SDR_S31 +SDR_S32 +SIU_S12 +SLR_S28 +SRM_S01 +SRR_S01 +SSR_U04 +SSU_U03 +STC_S33 + +TCU_U10 +UDM_Q05 + + +VXU_V04 + +== Version 2.8 + +ACK + +ADT_A01 +ADT_A02 +ADT_A03 +ADT_A05 +ADT_A06 +ADT_A09 +ADT_A12 +ADT_A15 +ADT_A16 +ADT_A17 +ADT_A20 +ADT_A21 +ADT_A24 +ADT_A37 +ADT_A38 +ADT_A39 +ADT_A43 +ADT_A44 +ADT_A45 +ADT_A50 +ADT_A52 +ADT_A54 +ADT_A60 +ADT_A61 + +BAR_P01 +BAR_P02 +BAR_P05 +BAR_P06 +BAR_P10 +BAR_P12 +BPS_O29 +BRP_O30 +BRT_O32 +BTS_O31 + +CCF_I22 +CCI_I22 +CCM_I21 +CCQ_I19 +CCR_I16 +CCU_I20 +CQU_I19 +CRM_C01 +CSU_C09 + +DBC_O41 +DBC_O42 +DEL_O46 +DEO_O45 +DER_O44 +DFT_P03 +DFT_P11 +DPR_O48 +DRC_O47 +DRG_O43 + +EAC_U07 +EAN_U09 +EAR_U08 +EHC_E01 +EHC_E02 +EHC_E04 +EHC_E10 +EHC_E12 +EHC_E13 +EHC_E15 +EHC_E20 +EHC_E21 +EHC_E24 +ESR_U02 +ESU_U01 + +INR_U06 +INU_U05 + +LSU_U12 + +MDM_T01 +MDM_T02 +MFK_M01 +MFN_M02 +MFN_M04 +MFN_M05 +MFN_M06 +MFN_M07 +MFN_M08 +MFN_M09 +MFN_M10 +MFN_M11 +MFN_M12 +MFN_M13 +MFN_M15 +MFN_M16 +MFN_M17 +MFN_Znn + +NMD_N02 + +OMB_O27 +OMD_O03 +OMG_O19 +OMI_O23 +OML_O21 +OML_O33 +OML_O35 +OML_O39 +OMN_O07 +OMP_O09 +OMQ_O42 +OMS_O05 +OPL_O37 +OPR_O38 +OPU_R25 +ORA_R33 +ORA_R41 +ORB_O28 +ORD_O04 +ORG_O20 +ORI_O24 +ORL_O22 +ORL_O34 +ORL_O36 +ORL_O40 +ORN_O08 +ORP_O10 +ORS_O06 +ORU_R01 +ORU_R30 +ORX_O43 +OSM_R26 +OSU_O41 +OUL_R22 +OUL_R23 +OUL_R24 + +PEX_P07 +PGL_PC6 +PMU_B01 +PMU_B03 +PMU_B04 +PMU_B07 +PMU_B08 +PPG_PCG +PPP_PCB +PPR_PC1 + +QBP_E03 +QBP_E22 +QBP_O33 +QBP_O34 +QBP_Q11 +QBP_Q13 +QBP_Q15 +QBP_Q21 +QBP_Qnn +QBP_Z73 +QCN_J01 +QSB_Q16 +QVR_Q17 + +RAS_O17 +RDE_O11 +RDR_RDR +RDS_O13 +RDY_K15 +RDY_Z80 +REF_I12 +RGV_O15 +RPA_I08 +RPI_I01 +RPI_I04 +RPL_I02 +RPR_I03 +RQA_I08 +RQI_I01 +RQP_I04 +RRA_O18 +RRD_O14 +RRE_O12 +RRG_O16 +RRI_I12 +RSP_E03 +RSP_E22 +RSP_K11 +RSP_K21 +RSP_K22 +RSP_K23 +RSP_K25 +RSP_K31 +RSP_K32 +RSP_O33 +RSP_O34 +RSP_Z82 +RSP_Z84 +RSP_Z86 +RSP_Z88 +RSP_Z90 +RSP_Znn +RTB_K13 +RTB_Knn +RTB_Z74 + +SDR_S31 +SDR_S32 +SIU_S12 +SLR_S28 +SRM_S01 +SRR_S01 +SSR_U04 +SSU_U03 +STC_S33 + +TCU_U10 + +UDM_Q05 + +VXU_V04 + +== Version 2.8.1 + +ACK + +ADT_A01 +ADT_A02 +ADT_A03 +ADT_A05 +ADT_A06 +ADT_A09 +ADT_A12 +ADT_A15 +ADT_A16 +ADT_A17 +ADT_A20 +ADT_A21 +ADT_A24 +ADT_A37 +ADT_A38 +ADT_A39 +ADT_A43 +ADT_A44 +ADT_A45 +ADT_A50 +ADT_A52 +ADT_A54 +ADT_A60 +ADT_A61 + +BAR_P01 +BAR_P02 +BAR_P05 +BAR_P06 +BAR_P10 +BAR_P12 +BPS_O29 +BRP_O30 +BRT_O32 +BTS_O31 + +CCF_I22 +CCI_I22 +CCM_I21 +CCQ_I19 +CCR_I16 +CCU_I20 +CQU_I19 +CRM_C01 +CSU_C09 + +DBC_O41 +DBC_O42 +DEL_O46 +DEO_O45 +DER_O44 +DFT_P03 +DFT_P11 +DPR_O48 +DRC_O47 +DRG_O43 + +EAC_U07 +EAN_U09 +EAR_U08 +EHC_E01 +EHC_E02 +EHC_E04 +EHC_E10 +EHC_E12 +EHC_E13 +EHC_E15 +EHC_E20 +EHC_E21 +EHC_E24 +ESR_U02 +ESU_U01 + +INR_U06 +INU_U05 + +LSU_U12 + +MDM_T01 +MDM_T02 +MFK_M01 +MFN_M02 +MFN_M04 +MFN_M05 +MFN_M06 +MFN_M07 +MFN_M08 +MFN_M09 +MFN_M10 +MFN_M11 +MFN_M12 +MFN_M13 +MFN_M15 +MFN_M16 +MFN_M17 +MFN_Znn + +NMD_N02 + +OMB_O27 +OMD_O03 +OMG_O19 +OMI_O23 +OML_O21 +OML_O33 +OML_O35 +OML_O39 +OMN_O07 +OMP_O09 +OMQ_O42 +OMS_O05 +OPL_O37 +OPR_O38 +OPU_R25 +ORA_R33 +ORA_R41 +ORB_O28 +ORD_O04 +ORG_O20 +ORI_O24 +ORL_O22 +ORL_O34 +ORL_O36 +ORL_O40 +ORL_O41 +ORL_O42 +ORL_O43 +ORL_O44 +ORN_O08 +ORP_O10 +ORS_O06 +ORU_R01 +ORU_R30 +ORX_O43 +OSM_R26 +OSU_O41 +OUL_R22 +OUL_R23 +OUL_R24 + +PEX_P07 +PGL_PC6 +PMU_B01 +PMU_B03 +PMU_B04 +PMU_B07 +PMU_B08 +PPG_PCG +PPP_PCB +PPR_PC1 + +QBP_E03 +QBP_E22 +QBP_O33 +QBP_O34 +QBP_Q11 +QBP_Q13 +QBP_Q15 +QBP_Q21 +QBP_Qnn +QBP_Z73 +QCN_J01 +QSB_Q16 +QVR_Q17 + +RAS_O17 +RDE_O11 +RDR_RDR +RDS_O13 +RDY_K15 +RDY_Z80 +REF_I12 +RGV_O15 +RPA_I08 +RPI_I01 +RPI_I04 +RPL_I02 +RPR_I03 +RQA_I08 +RQI_I01 +RQP_I04 +RRA_O18 +RRD_O14 +RRE_O12 +RRG_O16 +RRI_I12 +RSP_E03 +RSP_E22 +RSP_K11 +RSP_K21 +RSP_K22 +RSP_K23 +RSP_K25 +RSP_K31 +RSP_K32 +RSP_O33 +RSP_O34 +RSP_Z82 +RSP_Z84 +RSP_Z86 +RSP_Z88 +RSP_Z90 +RSP_Znn +RTB_K13 +RTB_Knn +RTB_Z74 + +SDR_S31 +SDR_S32 +SIU_S12 +SLR_S28 +SRM_S01 +SRR_S01 +SSR_U04 +SSU_U03 +STC_S33 + +TCU_U10 + +UDM_Q05 + +VXU_V04 diff --git a/hl7/4.3/modules/ROOT/pages/index.adoc b/hl7/4.3/modules/ROOT/pages/index.adoc new file mode 100644 index 0000000000..d06b7567bf --- /dev/null +++ b/hl7/4.3/modules/ROOT/pages/index.adoc @@ -0,0 +1,183 @@ += HL7 EDI Connector 4.3 - Mule 4 +:page-aliases: connectors::hl7/hl7-connector.adoc + + + +Anypoint Connector for HL7 EDI (HL7 EDI Connector) is a collection of features that facilitate integration with healthcare systems by providing the tools needed to easily create, read, and transform HL7 version v2.x messages within Mule. Health Level Seven International (HL7) is a standards development organization that defines a set of standards for the transport and communication of healthcare information. + +For compatibility information and fixed issues, see the HL7 EDI Connector Release Notes. + +Standard schema definitions are included in HL7 EDI Connector for +HL7 versions 2.1, 2.2, 2.3.1, 2.3, 2.4, 2.5, 2.5.1, 2.6, 2.7, +2.7.1, 2.8, 2.8.1. The schemas are provided in two forms: + +* Standard HL7 ++ +Uses required or optional status data types, +field lengths, and repetition counts (as listed) for each HL7 version. + + +* Lax HL7 ++ +All segments and value items are optional. These +low-level data types are treated as simple strings. Field lengths and repetition counts are not enforced. + +Both forms of schemas are available in the connector's `classpath`. Standard HL7 +schemas use the path `/hl7/v2_5_1/ADT_A01.esl`. + +Lax schemas use the path `/hl7lax/v2_5_1/ADT_A01.esl`. + +The schema definitions you need for xref:hl7-schemas.adoc[HL7 supplied schemas] are included. + +For complete information about schemas, see xref:x12-edi-connector::x12-edi-schema-language-reference.adoc[EDI Schema Language Reference]. + +== Before You Begin + +To use this connector, you must be familiar with: + +* Anypoint Connectors +* Mule runtime engine (Mule) +* Elements and global elements in a Mule flow +* Creating a Mule app using Anypoint Studio (Studio) +* HL7 EDI Connector + +To use HL7 EDI Connector, you must have: + +* Purchased a MuleSoft license for HL7. Contact your Account Representative about purchasing a license. +* Anypoint Studio 7.0 or later. + +=== Understanding the EDI Schema Language + +HL7 EDI Connector uses a YAML format called EDI Schema Language (ESL) to represent EDI schemas. +Basic ESLs define the structure of Electronic Data Interchange (EDI) messages in terms of: + +* structures (_message structures_, in HL7 terminology) + +* groups + +* segments, composites, and elements + +You can customize the HL7 schema definitions to suit your data by +copying and editing the schema definitions directly or by using a +console tool to generate a simplified schema based on one or more +sample documents. Alternatively, you can use an overlay schema for +HL7, as with other EDI formats, but this option is not recommended +due to the complexity of HL7 definitions. + +You can define your own schemas from scratch, or you can copy and edit a base HL7 schema definition to suit your data as shown in the xref:x12-edi-connector::x12-edi-schema-language-reference.adoc[EDI Schema Language Reference]. + +=== Finding the HL7 Schema Location + +To use the connector, you must know the locations of the schemas +in your project. If you're using the out-of-the-box HL7 schemas and +not customizing anything, the standard schema location follows the +`/hl7/{version}/{message structure}.esl` pattern and the lax schema +location follows the `/hl7lax/{version}/{message structure}.esl` pattern. + +For example, if you're using the 2.5.1 schema version and the ADT_A01 message +structure, your schema location is `/hl7/v2_5_1/ADT_A01.esl` for the +standard version or `/hl7lax/v2_5_1/ADT_A01.esl` for the lax version. + +If you're using one or more custom schemas, put these in a directory in `src/main/mule` and refer to the location using `${app.home}`. +For example, if you put your ADT_A01 schema under `src/main/mule/mypartner/ADT_A01.esl, +your schema location is `${app.home}/mypartner/ADT_A01.esl`. + +The Mule runtime engine automatically checks `src/main/mule` for any locations +that contain the `${app.home}` value. + +== The Hierarchy of X12 EDI Connector Message Structure + +Use this connector to read or write HL7 documents into (or from) the canonical ER7 message structure. +This structure is a hierarchy of Java Maps and Lists. You use either DataWeave or code to manipulate them. +Each transaction structure is defined in the schemas. + +The message itself contains the following keys, some of which apply only to either the read operation or the write operation, as indicated: + +[%header%autowidth.spread] +|=== +|Key Name |Description +|ACK (read only) |Message generated by the module during the read operation. The `MSA-01` acknowledgment code value is based on the parser configuration settings. +|Data (read or write) |Wrapper for message data, with a key matching the message structure ID value that links to the actual data. Allows different messages to be included in the metadata and handled in DataWeave mappings. +|Delimiters (read or write) |The delimiters used for the message. +The characters in the string of delimiters are interpreted based on their position in string, in the following order: component separator, repetition separator, escape character, and subcomponent separator, with a value of `U` indicating no value in that position. +|Errors (read only) |A list of errors associated with the input message. +|Id |Message structure ID. +|MSH (read only) |Link that receives MSH segment data. +|Name (read only) |Message structure name. +|=== + +Individual messages have their own maps, with keys matching the segments of the message. For example, an ACK message uses the message structure ID ACK, and the data for the sent or received ACK message is an ACK value in the data map. The ACK message is itself a map, and the segments and groups of the message are represented as maps (in the case of singleton instances) or lists of maps (for repeating instances) with positional keys. + +In two special cases, use generic handling for data that is not included in a schema definition. + +The first case is HL7 values of the `varies` type. Because these values consist of any structure of components and subcomponents that can be repeated, the parser uses a list of map representations for each `varies` of type. The keys in each map are generated as the value is parsed, matching standard HL7 value names with two digits used for each nesting level. +For example, a simple text value for an `OBX-05 Observation Value` field would use the key `OBX-05` in a map. If there are two components present, they use keys `OBX-05-01` and `OBX-05-02`. + +The second case is when extension segments have tags that match a pattern configured under parser options. These are similar in structure to the `varies` values, with the exception of only being within a single map for the entire segment. + +The maps containing extension segment data are added to the basic message map in lists with the key `ExtensionSegs`. In addition to the actual extension segment data, the map for the extension segment contains two other keys: + +[%header%autowidth.spread] +|=== +|Key |Description +|Ident |The extension segment identifier (tag). +|Position |The position of the segment within the message structure, as a two-digit string. This is the same as the position of the immediately preceding defined segment, as defined in the schema. If a `ZVN` extension segment is used following the `EVN` segment in an `ADT_A01` message structure, the `ZVN` is at position `03)`. +|=== + +If extension segments are used in nested groups, the list containing those segments are included in the map representing that group. Extension segments are ordered by position in the lists created by the parser, and must also be ordered by position when writing. + +=== About Sending Acknowledgments + +An ACK (acknowledgment) message is an HL7 message that enables you to acknowledge to a message sender that your application has received a message. ACK messages are the same as any other HL7 message write operations, except that you set the ACK message to what was generated during the read operation as the output message under a `Data` key. + +Here is an example: + +[source,xml,linenums] +---- + + + + + + + + ... + + + + + + ... + +---- + +The generated ACK messages have MSH data set up for sending back to the sender of the original message, so you don't need to change anything in the data to perform the send. + +If you include an ACK message schema in your configuration, that schema is used to both receive and generate ACK messages, you also need to specify include the `eventMessageMap` to use the ACK structure in the parser. If you don't specify an ACK schema, the standard `hl7/v2_5_1/ACK.esl` schema default is used. + +== Exchange Templates and Examples + +https://www.mulesoft.com/exchange/[Anypoint Exchange] provides both templates and examples that you can use as starting points for your apps and examples that illustrate a complete solution. + +//// +List and link to up to 10 Exchange templates and examples. +Use the Integration Pattern categories (broadcast, migration, bidirectional sync, aggregation). +//// + +== Next Step + +After you complete the prerequisites, you are ready to create your own app and configure the connector using xref:hl7-connector-studio.adoc[Anypoint Studio]. + +== See Also + +xref:connectors::introduction/introduction-to-anypoint-connectors.adoc[Introduction to Anypoint Connectors] +xref:connectors::introduction/intro-use-exchange.adoc[Use Exchange to Discover Connectors, Templates, and Examples] +https://help.mulesoft.com[MuleSoft Help Center]