0. INTRODUCTION This specification provides the definition of the EDI implementation guide definition message (IMPDEF) to be used in Electronic Data Interchange (EDI) between trading partners involved in administration, commerce and transport. 1. SCOPE 1.1 Functional Definition The EDI implementation guideline definition message (IMPDEF) permits the exchange of implementation details of an EDI message, including its usage and its presentation. 1.2 Field of Application The EDI implementation guide definition message may be used for both national and international applications. It is based on universal practice related to administration, commerce and transport, and is not dependent on the type of business or industry. 1.3 Principles The IMPDEF message provides an EDI mechanism for describing the contents of a specific Message Implementation Guideline (MIG) or Implementation Convention (IC) for an EDI message that is capable of being specified in the Directory Definition message (DIRDEF). One occurrence of the message shall contain only one MIG. An IMPDEF message for the message being implemented may contain: a. the specification of the implementation usage b. additional implementation guidance c. presentation and processing guidance The IMPDEF message shall describe usage of all necessary components (segment groups, segments, composite data elements, simple data elements and code values) from an identified source message, together with additional components (non-coded data values or ranges), to effect an implementation of the target message. The IMPDEF message may describe those components which are not used. By default, those components of the source message which are not referenced, are not used in the implementation. The IMPDEF message shall identify the source message upon which it is based. This identification may reference the source message contained either in a standard directory or in a separate DIRDEF message. The IMPDEF message shall contain a complete MIG or IC and it shall not be used for update or maintenance purposes. The hierarchical nature of both the source and target message structure must be preserved in the IMPDEF message. For example, this means that segment group information must be located immediately after the segment context of the trigger segment is established. Similarly, constituent element information must immediately follow the establishment of a segment or composite context, as must coded or non-coded values their element context. The main body of the MIG is carried by repeated instances of the DFN loop. This loop can be used to encapsulate blocks of components and place them in any given prevailing context. It can also be used to define aliases or constraint blocks. In ordinary use, the DFN segment acts as a device to allow the logic flow to cycle through the optional segment groups inside the DFN-triggered segment group in the correct order to follow the hierarchical message structure. The segment groups within the DFN-triggered segment group are ordered so as to minimise the number of repeats within ordinary use. The IMPDEF message maintains a context through the use of the segment groups within the DFN-triggered segment group. The DFN segment provides a means to redefine or re-establish the current context. The segment group that follows the DFN segment (and its associated FTX segment[s]) determines which context is being changed. For example, in normal message hierarchy sequence, codes are defined for elements within segments. To revert back to the segment context, a DFN segment would be followed by an ELU segment; similarly, to change the segment context, a DFN segment would be followed by an SGU segment. However, components such as repeats, references or relationships are considered to be applied in the context at which they are defined. Thus repeats, references, relationships or data representations may be applied to the whole message, individual segments, elements or composites. When the DFN is used to perform encapsulation, the current context is considered to be stacked upon entry, inherited within, and restored upon exit. However, any encapsulated block may establish its own context at any time, either retaining or discarding any or all of the inherited context. Upon exit, the previous context is re-established, but may be immediately modified, in whole or part, by the components that follow the closing DFN segment. The ordering of the components is governed by the source message hierarchy. Whilst the components at any particular level may be carried in any order, the message hierarchy must be maintained. This means that usage requirements of data elements within a segment must follow the usage requirements of that segment, but may themselves be presented in any order. Similarly, usage requirements of individual segments within a segment group must follow the trigger segment and the group definition and be presented together, but in any order. Where constraints are used, and a constraint is active either because the constraint expression at the start of the constraint is true or because the implicit context of the constraint definition is active, then the usage specifications inside the constraint block shall prevail against those which would apply were the constraint not active. For example, if a segment is implicitly 'Not Used' by not being mentioned in the main body of the MIG or IC, but is explicitly tagged as 'Required' within an active constraint, then the prevailing usage shall be 'Required'. Conversely, if a segment is explicitly used in the main body of the MIG or IC, and also explicitly tagged as 'Not Used' within an active constraint then the prevailing usage shall be 'Not Used'. The Interchange header shall specify character set level C. 2. REFERENCES See UNTDID, Part 4, Chapter 2.6 UN/ECE UNSM - General Introduction, Section 1. 3. TERMS AND DEFINITIONS 3.1 Standard terms and definitions See UNTDID, Part 4, Chapter 2.6 UN/ECE UNSM - General Introduction, Section 2. 3.2 Message terms and definitions The following additional definitions are for constituent parts of a message whose implementation is being described within an IMPDEF message: Alias: this is used to describe a group of components collected together and named for frequent or repetitive use. Component: this is used in a generic sense to apply to any item which may be a part of, or referenced by a part of a MIG. Thus it may refer to a segment, a segment group, a simple or composite element, a code list or individual code or non-coded value. It may also refer to structures such as an alias or a constraint within a MIG. Constraint: this is used to describe a group of components with either an explicit or implicit constraint expression, which may be named for error reporting and context determination. Source Message: this is used to refer to the original message specification as published in the relevant standard by the responsible authority. Target Message: this is used to refer to the resultant message specification produced by applying the restrictions, clarifications and constraints contained within the MIG to the Source Message. 4. MESSAGE DEFINITION 4.1 Data Segment Clarification This section should be read in conjunction with the Segment Table which indicate mandatory, conditional and repeating requirements. 0010 UNH, Message header A service segment starting and uniquely identifying a message. The message type code for the EDI implementation guide definition message is IMPDEF. Note: EDI implementation guide definition messages conforming to this document must contain the following data in segment UNH, composite S009: Data element 0065 IMPDEF 0052 D 0054 99A 0051 UN 0020 BGM, Beginning of message A segment to indicate the beginning of the message and to transmit function, type and number of the message. 0030 MSG, Message type identification A segment identifying a message type to which the implementation details apply. 0040 RCS, Requirements and conditions A segment specifying the distribution conditions for the implementation. 0050 DII, Directory identification A segment specifying the identity of the source directory set and giving its language and maintenance operation. This identifies the underlying standard from which the standard message is drawn. 0060 RFF, Reference A segment carrying reference information for the implementation as a whole. This may specify the unique registration identifier of this implementation guide; it may carry references to graphical information to be used or displayed whenever the implementation is physically displayed. 0070 DTM, Date/time/period A segment specifying dates related to the implementation guide, such as date of issue or date of approval. 0080 FTX, Free text A segment providing implementation guide notes which relate to the implementation as a whole. It may also carry various legal or contractual phrases which may apply to the ownership or copyright of the implementation guide, or contractual terms which will be incorporated by reference into any contract of which a data transmission using this implementation is a part. 0090 Segment group 1: PNA-ADR-SG2 A group of segments identifying the parties involved in the transaction with associated information. For publicly available implementation guides this includes details of the ownership and origination of the guide. 0100 PNA, Party identification A segment identifying the names of the parties involved in the transaction, e.g., originator, requester, author or secretariat. 0110 ADR, Address A segment identifying the address of the party. 0120 Segment group 2: CTA-COM A group of segments identifying a person or a department and identifying communication type and number. 0130 CTA, Contact information A segment identifying a person or a department for the party to whom the communication should be directed. 0140 COM, Communication contact A segment identifying communication type and number of the person. 0150 Segment group 3: DFN-FTX-SG4-SG5-SG6-SG7-SG8-SG9-SG10-SG11- SG12 A group of segments to describe the usage of a segment, a segment group, a composite or an element, an alias, or a constraint in a MIG or IC. The iterations of this segment group form the bulk of the MIG or IC. The MIG or IC consists of a series of iterations of this segment group which describe the target message hierarchy. Within the hierarchy, additional occurrences of this segment group may specify the conditions or relationships between the components. Only the appropriate parts of this segment group should be used as necessary on any particular iteration. The other contained segment groups are ordered to minimise the number of iterations of this segment group. The 'Alias' and 'Constraint' instances of this segment group provide a mechanism for grouping or encapsulating blocks of components. An 'Alias' has no context, and therefore takes on the context of the point at which it is used. A 'Constraint' inherits the context in which it is defined, but may redefine any part of its context by using the appropriate optional segment groups within the main segment loop. As well as its defining function, each component may also be used in a constraining manner. For example, a repeating segment may not only define its components, but also the number of times it is allowed to repeat; then, within each instance, a different combination of element requirements may be expressed. This conditionality may be based on either ordering or content criteria. Once defined, an 'Alias' may be used throughout the MIG where required, by "using" the definition which is identified by its 'name'. Similarly, in error reporting, an active constraint may be identified by its 'name'. 0160 DFN, Definition function A segment identifying the object of the definition, and containing an optional 'name' or identifier. 0170 FTX, Free text A segment providing implementation guide notes pertaining to the preceding definition, or to carry the text of a constraint expression. 0180 Segment group 4: GRU-FTX A group of segments identifying a segment group and providing details about segment group usage. This segment group depends on a segment context having been established by an instance of a segment group describing segment usage. This segment group defines a segment group context for the target message, and will immediately follow the definition of the trigger segment context, preceding the constituent elements within the trigger segment. Several instances of the same segment group may be described, with the MEA segment group distinguishing which range or instance of the target message segment is being described. 0190 GRU, Segment group usage details A segment specifying the usage of a segment group in a definition. The segment may identify one or more instances of a target segment group. 0200 FTX, Free text A segment providing implementation guide notes or textual information related to the specific group in the underlying message. 0210 Segment group 5: SGU-FTX A group of segments specifying segment usage within the definition. There will be at least one instance of this segment group for each segment described in the implementation guide. This segment group defines a segment context, and all the following components are deemed to be within the context of the segment whose usage is being defined until a subsequent segment context is defined. Several instances of the same segment may be described, with the MEA segment group distinguishing which range or instance of the target message segment is being described. 0220 SGU, Segment usage details A segment specifying the usage of a segment in a message type structure for this definition. As well as defining the specific usage of a particular target segment, this segment also provides the segment context for the following element usage details. The segment may identify one or more instances of usage for any particular segment in the target data message. 0230 FTX, Free text A segment providing implementation guide notes, or textual information relating to the specific segment in the underlying message. 0240 Segment group 6: FNT-REL-GIR-FTX A group of segments specifying formalised relationships among the various components of this implementation at a particular context, such as additional rules concerning syntax and semantics which are specific to an implementation. The relationships may be both intra-component, such as between elements in a segment, or inter-component, such as between elements in different segments. Depending on the context in which this segment group is used, it may specify relationships between segments or segment groups in a message, between data elements in a segment, or between data elements in a composite. 0250 FNT, Footnote A segment specifying a footnote identification number that may place the relationship in the current context. 0260 REL, Relationship A segment specifying a relationship between the various components, typically data elements in a segment, in the current context. 0270 GIR, Related identification numbers A segment identifying the various components in a relationship, typically data elements in a segment, in the current context. 0280 FTX, Free text A segment carrying text notes to the preceding relationship. 0290 Segment group 7: RFF-FTX A group of segments carrying references, or constraints whose default context applies to the containing segment. This segment group may be used to change the constraint mechanism at the current and deeper levels in the message hierarchy. Additionally, this segment group may be used to carry legal and contractual terms which relate, either by way of explanation or to be incorporated by reference, in the particular context at which the group appears. Depending on the context, the references may be applied to the target message as a whole, the current segment or element context, or the current code value context. 0300 RFF, Reference A segment identifying a reference document or a following constraint expression. 0310 FTX, Free text A segment carrying the text of a constraint expression or providing implementation guide notes pertaining to the preceding constraint. 0320 Segment group 8: ELU-ELM-EDT-IMD-GIS-FTX A group of segments specifying implementation requirements for data elements in the current segment or composite context. Multiple instances of this segment group will typically be used to describe the usage of all the elements in any given segment or composite context. There will be at least one instance of this segment group for each element used, although a constraint structure may override or further define the specification in any particular context or sub-context. The MEA segment group may be used to provide repeat range or specific instance information for repeating data elements. This segment group defines an element or composite context which will remain in force until the next element or composite context is defined, or a new segment context is established. 0330 ELU, Data element usage details A segment identifying the usage of a simple or composite data element in the current context. This segment starts a block of information about any one particular contextualised usage of a data element in a target data message. The data element usage determines whether this segment is defining a composite context, a simple element context or a component element context. 0340 ELM, Simple data element details A segment providing details of any variation or restriction of the current data element as used in this context. Typically this segment will convey details of restricted size or character representation. 0350 EDT, Editing details A segment providing details of any editing information such as maximum field length and status that would be used by a screen-based editor, forms input or data output process when physical representation of the data carried in a data message using this implementation guide is required. 0360 IMD, Item description A segment providing further details of presentational information such as text alignment and style that might be used by a screen-based editor, forms input or data output process when physical representation of the data carried in a data message using this implementation guide is required. 0370 GIS, General indicator A segment providing further details of processing information such as data handling, positioning or control that might be used by a screen-based editor, forms input or data output process when data is carried, stored or collected by a data message using this implementation guide is required. 0380 FTX, Free text A segment providing implementation guide notes, or other textual information relating to this element usage. The segment will also be used to carry the final set of information that would be used by a screen-based editor; forms input or data output process; a legend or user-recognisable description; and a help text. 0390 Segment group 9: MEA-FTX A group of segments specifying implementation requirements for the number of instances of repeating segments, segment groups or elements in the current context. Multiple instances of this segment group will typically be used to describe both the overall limits of usage and to identify individual instances in any given context. 0400 MEA, Measurements A segment to measure the number of instances of usage of a component in a message. The segment may specify minima, maxima, range or instance criteria. 0410 FTX, Free text A segment providing implementation guide notes, or other textual information relating to this measurement. 0420 Segment group 10:ELV-FTX A group of segments specifying the usage of values for a non-coded data element. Multiple instances of this segment group may be used to provide a complete set of ranges or specific values, including preferences. It can be used for any other type of data element, such as strings, numerics, dates and times. It can also specify a default value and associated implementation notes for a specific element in a particular context. A simple element or component element context must have been established before this segment group is used. 0430 ELV, Element value definition A segment identifying one or more components of an element value constraint series. It also may provide a default value for the current element context. This is expressed in a single text field so as to be used by or applicable to the broadest range of applications. 0440 FTX, Free text A segment providing implementation guide notes, or other textual information related to the particular context. Such a context may include implementation guide notes for the default value. 0450 Segment group 11:CDV-FTX A group of segments specifying the usage of code values for a coded data element. Multiple instances of this segment group may be used to provide a complete set of code values, including preferences. A simple element or component element context must have been established before this segment group is used. 0460 CDV, Code value definition A segment identifying the code value, its source and usage preference. 0470 FTX, Free text A segment providing implementation guide notes, or other textual information related to the particular context. 0480 Segment group 12:DRD-FTX A group of segments specifying data representation details for a component of the message. This segment group may be used in a segment, group, composite or simple data element context to describe the data representation that the implementation guide author intends to use to hold, store or represent the structure or data in a non-EDI environment. 0490 DRD, Data representation details A segment identifying an underlying data representation by tag, basic data type and size. This is the representation itself, and not a pointer to an external document. 0500 FTX, Free text A segment providing implementation guide notes, or other relevant textual information. 0510 Segment group 13:AUT-DTM A group of segments to provide authentication for the message. 0520 AUT, Authentication result A segment specifying the details of any authentication (validation) procedure applied to the IMPDEF message. 0530 DTM, Date/time/period A segment specifying the date of authentication. 0540 UNT, Message trailer A service segment ending a message, giving the total number of segments in the message and the control reference number of the message. 4.2 Data segment index (Alphabetical sequence by tag) ADR Address AUT Authentication result BGM Beginning of message CDV Code value definition COM Communication contact CTA Contact information DFN Definition function DII Directory identification DRD Data representation details DTM Date/time/period EDT Editing details ELM Simple data element details ELU Data element usage details ELV Element value definition FNT Footnote FTX Free text GIR Related identification numbers GIS General indicator GRU Segment group usage details IMD Item description MEA Measurements MSG Message type identification PNA Party identification RCS Requirements and conditions REL Relationship RFF Reference SGU Segment usage details UNH Message header UNT Message trailer
Contents of IMPDEF