X12Translator Component
Properties Methods Events Configuration Settings Errors
The X12Translator component is optimized for X12 translation, providing a simple way to convert X12 documents to and from XML or JSON.
Syntax
nsoftware.IPWorksEDI.X12translator
Remarks
The X12Translator component provides a simple way to convert X12 to XML or JSON and vice versa.
Getting Started
The component will convert a document from the format specified by InputFormat to the format specified by OutputFormat. In practice this allows for converting to XML or JSON from EDI and vice versa.
Before translating from EDI to XML or JSON it is recommended to load a schema using the LoadSchema method. This ensures additional information can be included in the XML or JSON document. If a schema is specified the XML or JSON will include types and descriptions as element attributes which are useful for interpreting the data.
EDI elements may optionally be renamed when creating XML. To define how an element is renamed add a renaming rule by calling AddRenamingRule.
After calling Translate the resulting output will contain the EDI, XML or JSON data as defined by OutputFormat. If the output data is XML the ExportXMLSchema method may be called to export a schema (.xsd) defining the structure of a valid XML document. XML documents which adhere to this document may be translated from XML to EDI.
Input and Output Properties
The component will determine the source and destination of the input and output based on which properties are set.
The order in which the input properties are checked is as follows:
When a valid source is found the search stops. The order in which the output properties are checked is as follows:- SetOutputStream
- OutputFile
- OutputData: The output data is written to this property if no other destination is specified.
Example - Translating X12 to XML
X12translator translator = new X12translator();
translator.InputFormat = X12translatorInputFormats.ifX12;
translator.OutputFormat = X12translatorOutputFormats.ofXML;
translator.InputFile = "810.edi";
translator.OutputFile = "X12_810.xml";
translator.UseSchemaName = true;
translator.SchemaFormat = X12translatorSchemaFormats.schemaJSON;
translator.LoadSchema("RSSBus_00401_810.json");
translator.Translate();
The code above creates an XML document with content like:
<Interchange xmlns="http://www.nsoftware.com" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<Meta>
<ISA01 desc="Authorization Information Qualifier">00</ISA01>
<ISA02 desc="Authorization Information"> </ISA02>
<ISA03 desc="Security Information Qualifer">00</ISA03>
<ISA04 desc="Security Information"> </ISA04>
<ISA05 desc="Interchange ID Qualifier">14</ISA05>
<ISA06 desc="Interchange Sender ID">060704780001900</ISA06>
<ISA07 desc="Interchange ID Qualifier">ZZ</ISA07>
<ISA08 desc="Interchange Receiver ID">HYNIXEDI </ISA08>
<ISA09 desc="Interchange Date">130428</ISA09>
<ISA10 desc="Interchange Time">2033</ISA10>
<ISA11 desc="Interchange Control Standards Identifier">U</ISA11>
<ISA12 desc="Interchange Control Version Number Code">00401</ISA12>
<ISA13 desc="Inter Control Number">000040161</ISA13>
<ISA14 desc="Acknowlegment Requested Code">1</ISA14>
<ISA15 desc="Interchange Usage Indicator Code">T</ISA15>
<ISA16 desc="Component Element Separator">></ISA16>
</Meta>
<FunctionalGroup>
<Meta>
<GS01 desc="Functional Identifier Code">IN</GS01>
<GS02 desc="Application Sender's Code">060704780500</GS02>
<GS03 desc="Application Receiver's Code">HYNIXEDI</GS03>
<GS04 desc="Date">20130428</GS04>
<GS05 desc="Time">2033</GS05>
<GS06 desc="Group Control Number">000040161</GS06>
<GS07 desc="Responsible Agency Code">X</GS07>
<GS08 desc="Version / Release / Industry Identifier Code">004010</GS08>
</Meta>
<TransactionSet>
<TX-00401-810 type="TransactionSet">
<Meta>
<ST01 desc="Transaction Set Identifier Code">810</ST01>
<ST02 desc="Transaction Set Control Number">0001</ST02>
</Meta>
<BIG type="Segment">
<BIG01 desc="Date">20090629</BIG01>
<BIG02 desc="Invoice Number">3003014445</BIG02>
<BIG03 desc="Date" xsi:nil="true"/>
<BIG04 desc="Purchase Order Number">0476553272</BIG04>
<BIG05 desc="Release Number" xsi:nil="true"/>
<BIG06 desc="Change Order Sequence Number" xsi:nil="true"/>
<BIG07 desc="Transaction Type Code">DR</BIG07>
</BIG>
...
Example - Translating X12 to JSON
X12translator translator = new X12translator();
translator.InputFormat = X12translatorInputFormats.ifX12;
translator.OutputFormat = X12translatorOutputFormats.ofJSON;
translator.InputFile = "810.edi";
translator.OutputFile = "X12_810.json";
translator.UseSchemaName = true;
translator.SchemaFormat = X12translatorSchemaFormats.schemaJSON;
translator.LoadSchema("RSSBus_00401_810.json");
translator.Translate();
The code above creates a JSON document with content like:
{
"meta": {
"type": "Interchange",
"ISA01": {
"desc": "Authorization Information Qualifier",
"value": "00"
},
"ISA02": {
"desc": "Authorization Information",
"value": " "
},
"ISA03": {
"desc": "Security Information Qualifer",
"value": "00"
},
"ISA04": {
"desc": "Security Information",
"value": " "
},
"ISA05": {
"desc": "Interchange ID Qualifier",
"value": "14"
},
"ISA06": {
"desc": "Interchange Sender ID",
"value": "060704780001900"
},
"ISA07": {
"desc": "Interchange ID Qualifier",
"value": "ZZ"
},
"ISA08": {
"desc": "Interchange Receiver ID",
"value": "HYNIXEDI "
},
"ISA09": {
"desc": "Interchange Date",
"value": "130428"
},
"ISA10": {
"desc": "Interchange Time",
"value": "2033"
},
"ISA11": {
"desc": "Interchange Control Standards Identifier",
"value": "U"
},
"ISA12": {
"desc": "Interchange Control Version Number Code",
"value": "00401"
},
"ISA13": {
"desc": "Inter Control Number",
"value": "000040161"
},
"ISA14": {
"desc": "Acknowlegment Requested Code",
"value": "1"
},
"ISA15": {
"desc": "Interchange Usage Indicator Code",
"value": "T"
},
"ISA16": {
"desc": "Component Element Separator",
"value": ">"
}
},
"functionalgroups": [{
"meta": {
"type": "FunctionalGroup",
"GS01": {
"desc": "Functional Identifier Code",
"value": "IN"
},
"GS02": {
"desc": "Application Sender's Code",
"value": "060704780500"
},
"GS03": {
"desc": "Application Receiver's Code",
"value": "HYNIXEDI"
},
"GS04": {
"desc": "Date",
"value": "20130428"
},
"GS05": {
"desc": "Time",
"value": "2033"
},
"GS06": {
"desc": "Group Control Number",
"value": "000040161"
},
"GS07": {
"desc": "Responsible Agency Code",
"value": "X"
},
"GS08": {
"desc": "Version \/ Release \/ Industry Identifier Code",
"value": "004010"
}
},
"transactionsets": [{
"meta": {
"type": "TransactionSet",
"ST01": {
"desc": "Transaction Set Identifier Code",
"value": "810"
},
"ST02": {
"desc": "Transaction Set Control Number",
"value": "0001"
}
},
"segments": [{
"type": "Segment",
"name": "BIG",
"BIG01": {
"desc": "Date",
"value": "20090629"
},
"BIG02": {
"desc": "Invoice Number",
"value": "3003014445"
},
"BIG03": {
"desc": "Date",
"value": null
},
"BIG04": {
"desc": "Purchase Order Number",
"value": "0476553272"
},
"BIG05": {
"desc": "Release Number",
"value": null
},
"BIG06": {
"desc": "Change Order Sequence Number",
"value": null
},
"BIG07": {
"desc": "Transaction Type Code",
"value": "DR"
}
},
...
Property List
The following is the full list of the properties of the component with short descriptions. Click on the links for further details.
InputData | The data to translate. |
InputFile | The file to translate. |
InputFormat | The format of the input data. |
OutputData | The translated data. |
OutputFile | The file to which the translated data will be written. |
OutputFormat | The format of the output data. |
Overwrite | Whether to overwrite the file. |
RenamingRule | The rule defining how EDI elements are renamed when translating to XML or JSON. |
RenamingRuleCount | The number of renaming rules. |
RenamingRuleIndex | The index of the current renaming rule. |
SchemaFormat | The format of the schema file. |
Suffix | What to append after each segment delimiter. |
UseSchemaName | Whether the output XML uses element names based on name defined in the schema. |
Method List
The following is the full list of the methods of the component with short descriptions. Click on the links for further details.
AddRenamingRule | This method adds a renaming rule to define how an EDI element is renamed when translating to XML. |
Config | Sets or retrieves a configuration setting. |
DisplaySchemaInfo | Returns a string showing the structure of the schema defining the document. |
ExportXMLSchema | Exports a XML schema. |
GenerateAck | Generates an EDI acknowledgement. |
LoadRenamingRules | Loads a set of renaming rules from file. |
LoadSchema | Loads a schema file describing a Transaction Set. |
LoadSchemaStream | Loads a schema stream describing a Transaction Set. |
Reset | Resets the state of the control. |
SaveRenamingRules | Saves the current renaming rule set to a file. |
SetInputStream | The stream to which the component will read the data to translate. |
SetOutputStream | The stream to which the component will write the translated data. |
Translate | Translates the specified data. |
Event List
The following is the full list of the events fired by the component with short descriptions. Click on the links for further details.
EndFunctionalGroup | Fires whenever a control segment is read that marks the end of an interchange. |
EndInterchange | Fires whenever a control segment is read that marks the end of an interchange. |
EndLoop | Fires when the end of a loop is detected in a transaction set. |
EndTransaction | Fires whenever a control segment is read that marks the end of a transaction. |
Error | Information about errors during data delivery. |
ResolveSchema | Fires whenever a new transaction set is encountered and no schema is found for it. |
Segment | Fires whenever a data segment in a transaction set is read. |
StartFunctionalGroup | Fires whenever a control segment is read that marks the start of a functional group. |
StartInterchange | Fires whenever a control segment is read that marks the start of an interchange. |
StartLoop | Fires when the starting of a loop is detected in a transaction set. |
StartTransaction | Fires whenever a control segment is read that marks the start of a transaction. |
Warning | Fires whenever a validation warning is encountered. |
Configuration Settings
The following is a list of configuration settings for the component with short descriptions. Click on the links for further details.
CloseStreamAfterTranslate | If true, the component will close the output stream after translation. |
ComponentDelimiter | The delimiter character to use to separate components. |
CrossFieldValidationEnabled | Enables cross-field validation rules. |
ElementDelimiter | The delimiter character to use to separate data elements. |
Encoding | The character encoding to be applied when reading and writing data. |
IncludeEmptyElements | Whether to include empty data elements in a composite element. |
IncludeFooters | Whether to include footer information in the XML. |
JSONElementPrefix | An optional prefix for reserved names when translating to JSON. |
LastIXControlNumber | The control number of the most recently parsed interchange. |
LastTransactionControlNumber | The control number of the most recently parsed transaction. |
ReleaseChar | The character to use to escape delimiters within values. |
RenamingRulesData | The renaming rules data. |
RepetitionChar | The repetition character. |
SegmentDelimiter | The delimiter character to use to separate segments. |
StrictSchemaValidation | Specifies the behavior during schema validation. |
UseXMLComments | Whether the human readable description is stored as an attribute or XML comments. |
BuildInfo | Information about the product's build. |
GUIAvailable | Tells the component whether or not a message loop is available for processing events. |
LicenseInfo | Information about the current license. |
UseInternalSecurityAPI | Tells the component whether or not to use the system security libraries or an internal implementation. |