Description
Title PageDeveloper Version 7.1 Flat File Schema Developer’s Guide Copyright & Docu‐ ment ID Cerebra, Glue, Infravio X‐Broker, Infravio X‐Registry, Infravio, My webMethods Server, My webMethods, webMethods Access, webMethods Administrator, webMethods Broker, webMethods Central Configuration, webMethods Dashboard, webMethods Designer, webMethods Developer, webMethods Fabric, webMethods Glue, webMethods Infrastructure Data Collector, webMethods Infravio X‐Broker, webMethods Infravio X‐Registry, webMethods Installer, webMethods Integration Server, webMethods logo, webMethods Mainframe, webMethods Manager, webMethods Modeler, webMethods Monitor, webMethods Optimize for Infrastructure, webMethods Optimize for Process, webMethods Optimize, webMethods Portal, webMethods Process Engine, webMethods Servicenet, webMethods Task Engine, webMethods Trading Networks, webMethods Workflow, and webMethods are either registered trademarks or trademarks of webMethods, Inc. Acrobat, Acrobat, and Reader are registered trademarks of Adobe Systems Incorporated. Amdocs and ClarifyCRM are registered trademarks of Amdocs. Ariba is a registered trademark of Ariba, Inc. BEA, BEA WebLogic Server, Jolt, and Tuxedo are registered trademarks, and BEA WebLogic Platform is a trademark of BEA Systems, Inc. Action Request System, BMC Software, PATROL, and Remedy are registered trademarks of BMC Software, Inc. BroadVision is a registered trademark of BroadVision, Inc. Chem eStandards and CIDX are trademarks of CIDX, The Chemical Industry Data Exchange. SiteMinder and Unicenter are registered trademarks of CA, Inc. PopChart is a registered trademark of CORDA Technologies, Inc. Kenan and Arbor are registered trademarks of Alcatel‐Lucent. Data Connection and SNAP‐IX are registered trademarks of Data Connection Corporation. D&B and D‐U‐N‐S are registered trademarks of Dun & Bradstreet Corporation. Eclipse is a trademark of Eclipse Foundation, Inc. Entrust is a registered trademark of Entrust, Inc. papiNet is a registered trademark of the European Union and the United States. Financial Information eXchange, F.I.X, and F.I.X Protocol are trademarks of FIX Protocol Ltd. UCCnet and eBusinessReady are registered trademarks, and 1SYNC and Transora are trademarks of GS1 US. Hewlett‐Packard, HP, HP‐UX, OpenView, PA‐ RISC, and SNAplus2 are trademarks of Hewlett‐Packard Company. i2 is a registered trademark of i2 Technologies, Inc. AIX, AS/400, CICS, ClearCase, DB2, Domino, IBM, Informix, Infoprint, Lotus, Lotus Notes, MQSeries, OS/390, OS/400, RACF, RS/6000, SQL/400, S/390, System/390, VTAM, and WebSphere, and z/OS are registered trademarks; and Communications System for Windows NT, DB2 Universal Database, IMS, MVS, and SQL/DS are trademarks of IBM Corporation. InnoDB is a trademark of Innobase Oy. Itanium is a registered trademark of Intel Corporation. Linux is a registered trademark of Linus Torvalds. W3C is a registered trademark, and X Window System is a trademark of the Massachusetts Institute of Technology. MetaSolv is a registered trademark of Metasolv Software, Inc. ActiveX, Microsoft, Outlook, Visual Basic, Visual SourceSafe, Windows, Windows NT, and Windows Server are registered trademarks of Microsoft Corporation. Six Sigma is a registered trademark of Motorola, Inc. Firefox and Mozilla are registered trademarks of the Mozilla Foundation. MySQL is a registered trademark of MySQL AB. nCipher is a trademark of nCipher Corporation Ltd. Eclipse is a trademark of Eclipse Foundation, Inc. Entrust is a registered trademark of Entrust, Inc. papiNet is a registered trademark of the European Union and the United States. Financial Information eXchange, F.I.X, and F.I.X Protocol are trademarks of FIX Protocol Ltd. UCCnet and eBusinessReady are registered trademarks, and 1SYNC and Transora are trademarks of GS1 US. Hewlett‐Packard, HP, HP‐UX, OpenView, PA‐RISC, and SNAplus2 are trademarks of Hewlett‐Packard Company. i2 is a registered trademark of i2 Technologies, Inc. AIX, AS/400, CICS, ClearCase, DB2, Domino, IBM, Informix, Infoprint, Lotus, Lotus Notes, MQSeries, OS/390, OS/400, RACF, RS/6000, SQL/400, S/390, System/390, VTAM, and WebSphere, and z/OS are registered trademarks; and Communications System for Windows NT, DB2 Universal Database, IMS, MVS, and SQL/DS are trademarks of IBM Corporation. InnoDB is a trademark of Innobase Oy. Itanium is a registered trademark of Intel Corporation. Teradata is a registered trademark of NCR Corporation. Netscape is a registered trademark of Netscape Communications Corporation. ServletExec is a registered trademark, and New Atlanta is a trademark of New Atlanta Communications, LLC. SUSE is a registered trademark of Novell, Inc. Appia is a registered trademark and Javelin Technologies is a trademark of NYFIX, Inc. CORBA is a registered trademark of Object Management Group, Inc. JD Edwards, OneWorld, Oracle, PeopleSoft, Siebel, and Vantive are registered trademarks; and Infranet, PeopleSoft Pure Internet Architecture, Portal, and WorldSoftware are trademarks of Oracle Corporation. Perforce is a trademark of Perforce Software. JBoss and Red Hat are registered trademarks of Red Hat, Inc. PIP and RosettaNet are trademarks of RosettaNet, a non‐profit organization. SAP and R/3 are registered trademarks of SAP AG. PVCS is a registered trademark of Serena Software, Inc. SWIFT and SWIFTNet are registered trademarks of Society for Worldwide Interbank Financial Telecommunication SCRL. SPARC and SPARCStation are registered trademarks of SPARC International, Inc. BAAN and SSA are registered trademarks; and SSA Global is a trademark of SSA Global Technologies, Inc. EJB, Enterprise JavaBeans, Java, JavaServer, JDBC, JSP, J2EE, Solaris, Sun, and Sun Microsystems are registered trademarks; and Java Naming and Directory Interface, JavaServer Pages, SOAP with Attachments API for Java, and SunSoft are trademarks of Sun Microsystems, Inc. Sybase is a registered trademark of Sybase, Inc. VERITAS is a registered trademark, and VERITAS Cluster Server is a trademark of Symantec Corporation. UNIX is a registered trademark of The Open Group. Unicode is a trademark of Unicode, Inc. VeriSign is a registered trademark of Verisign, Inc. Software AG and all Software AG product names are either trademarks or registered trademarks of Software AG. Other product and company names mentioned herein may be the trademarks of their respective owners. Copyright © 2007 webMethods, Inc. All rights reserved. Copyright © 2007 Software AG and/or its suppliers, Uhlandstrasse 12, 64297 Darmstadt, Germany. All rights reserved. Document ID: DEV-FFS-DG-71-20070831 Contents Contents About This Guide. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Document Conventions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Additional Information . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 7 8 Chapter 1. Concepts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . What Is a Flat File? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . What Types of Flat Files Does webMethods Support? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . What Is a Flat File Schema? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . What Type of Flat File Constraints Can You Define? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . How Is a Flat File Schema Used to Parse Records? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Record Parsers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Record Identifiers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Extractors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Undefined Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Default Records . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . What Is a Flat File Dictionary? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . When Should I Create a Flat File Dictionary? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . What Is the Flat File Schema Editor? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Flat File Structure Tab . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 10 10 11 12 12 14 14 15 16 16 18 18 19 19 21 Chapter 2. Processing Flat Files Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Formatting Inbound and Outbound Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Processing Inbound Flat Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Step 1: Create Appropriate Flat File Schema . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Step 2: Receive the Flat File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Step 3: Parse, Convert, and Validate Flat File Data to an IS Document . . . . . . . . . . . . . . . . . . . Step 4: Process the IS Document . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Mapping Flat File Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Handling Large Flat Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Processing Outbound Flat Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Step 1: Create Appropriate Flat File Schema . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Step 2: Convert the IS Document to a Flat File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Step 3: Send/Process the Flat File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 24 25 25 26 26 27 27 27 30 31 31 31 32 33 Flat File Schema Developer’s Guide Version 7.1 3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Step 2: Specify Flat File Properties . . . . . . . . . . . . . . . Step 1: Add and Configure the Flat File Schema . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Building a Client that Posts a Flat File to a Service . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Creating a Flat File Schema . . . . . . . . . . . . . . . . . . . Extractors . . . . Byte Count Validator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Creating a Flat File Dictionary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Length Validator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Editing a Flat File Schema or Dictionary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Creating Format Services . . . Floating Records . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Displaying Element Descriptions and Alternate Names in the Flow Editor . . . . . . . . . . . . . . . . . . . . Step 4: Test the Flat File Schema . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Validators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Format Services . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 36 36 41 43 44 47 48 57 61 62 62 64 64 64 65 66 66 66 66 67 67 68 69 72 72 73 74 Chapter 4. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Code List Validator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . FTPing a File From a webMethods Integration Server . . . . . . . . . . . . . . . . . . Setting Access Permissions . . . . . . . . . . . . . . . . . . . . . . . . . . . . Submitting a Flat File to Integration Server via HTTP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Managing Flat File Dictionary Dependencies . .Contents Chapter 3. . . . . . . . . . . . . . . . Working with Format Error Messages . . . . . . . . . . . . . . . . . . . . . . Getting Results from an FTP’d Document . . . . . . . . . . . . . . . . . . . . . . . . . Conditional Validators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Flat File Content Handler and Content Type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Submitting a Flat File to Integration Server via FTP . . . . . . . . . . . . . . . . . . . . . Sending and Receiving Flat Files . . . . . . . . . . . Choosing the Service to Receive the Flat File from the Content Handler . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Field Validators . . . . . . . . . . . Submitting a Flat File to Integration Server in a String Variable . . . . . Creating and Editing Flat File Schemas and Dictionaries . . . . . . . . . . . . . . . . . . Flat File Schema Property Descriptions . . . . . . . . . . . Step 3: Define the Structure of the Flat File Schema . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Disabling Format Services . . . . . . . . . . . . . . . . . . . . . . . . .1 4 . . . . Managing Dictionary Dependencies on Format Services . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Examples: Parsing Inbound Floating Records . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Examples: Parsing Outbound Floating Records . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Customizing the Flat File Configuration Settings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77 78 78 79 79 80 80 81 82 83 Flat File Schema Developer’s Guide Version 7. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . pub. . . . . . . . . . . . . . . . . . . . . . . . . . . pub. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Flat File Generation IS Document Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . pub. . .generate:saveXMLASFFSchema . . . . .generate:deleteFFSchema . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .flatFile. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .flatFile. . . . .generate:getFFSchemaAsXML . . . . . . . . . . . General Error Entries in the errors Array . . . . . . . . . . . . . . . . . . . . . . . . . . .flatFile. . . . . . . . . . .flatFile. . . WmFlatFile Built–in Services Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .flatFile. . . . . . . . . . . . . . . . . . . . . . . pub. . . . . . . . . . pub. . . . . . . . . . . . . . . . . . . . . . . .flatFile:FormatService .flatFile. . . . . . . . . . . . . . . . . .generate:deleteFFDictionaryEntry .flatFile. . . . . . . . . . . . . . . . . . . . . . . . . . .flatFile. . . . . . . . . . . . . . . . . . . . . . . . . pub. . . . . . .generate:saveXMLAsFFDictionary . . . . pub. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Validation Error Codes . . . . . . . . . . . . . . . . . . . . .generate:listFFDictionaryEntries . . . . . . Flat File Generation Sample Services . . . . . . . . . . . Flat File Conversion Services . . . . . . . . . . . . . . . . . . . . . . . . . . . . Flat File Generation Services . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .flatFile. . . . . .flatFile. .flatFile. . . . . . . . . . . . . 84 84 84 85 Chapter 5. pub. . . . . . . . . . . . . . . . . . . . . . pub. . . . . .generate:createDocumentType . . . . . . . . . . .flatFile. . . . . . . . . . . . . . . . . . . . . . . pub. .generate:updateFFDictionaryEntryFromXML .Contents Submitting a Flat File to Integration Server via File Polling . . . . . . . . . . . . . . . . . . . . .generate:FFSchema . . . . . . . . . . . . . . . . . . . . .flatFile. . . . . . . . . . . . . . . . . .generate:findDependants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . pub. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .generate:findReferences . . . . . . . . . . . . . . . .flatFile. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .generateFFSchema:fixedLength . . . . . . . . . . . . . . . 115 Validation Error Contents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . sample. . pub. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .generate:getFFDictionaryAsXML . . . . . . . . . . . . . . . . . . . .flatFile. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Getting Results from an Emailed Document . . .flatFile:getSupportedEncodings . . . Entries for Conditional Validator Errors in errorDetails Array . . . . . . . . . . . . . . Submitting a Flat File to Integration Server via an E–mail Message . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Requirements for Submitting a Flat File Document via an E-mail Message . . . . . . . . . . .flatFile. . . . . . . . . . . . .flatFile. . . . . . . . . . . . . . . . . . . . . .generate:FFDictionary . . . . . . . . .flatFile:convertToString . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .flatFile. . . . . . pub. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .generate:getFFDictionaryEntryAsXML . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . pub. . . . . .1 5 . . .flatFile:convertToValues . . . . . . . . . . . . . . . . . . . 87 88 88 90 93 98 98 98 99 99 100 100 101 101 101 102 102 103 103 104 106 107 107 109 111 111 113 Appendix A. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . sample. . . . . . . . . . . . . . . . . . . . . . . . . . Validation Errors . . . . . pub. . . . . . . . . . . . . . . .generateFFSchema:delimited . . . . 116 117 117 120 Flat File Schema Developer’s Guide Version 7. . . . pub. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . pub. . . . . . . . . . . . . . pub. . . . . . . . . .generate:createFFDictionary . . . . . . . . . . . . . pub. pub. . . . . . . . . . . . . . . .generate:deleteFFDictionary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Creating Flat File Dictionary Entries. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Retrieving Namespace Data to Write to an XML File . . . . .Contents Appendix B. . . . . . . . . . . . . . . . . . . . . . . . Modifying an Existing Flat File Dictionary Entry . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130 130 131 132 133 133 134 134 138 140 140 140 141 Index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 129 Overview . . . . . . . . . . . . . . . . . and Schemas . . . . . . . . . . . 123 Overview . . . . . . . . . . . . . Creating a Flat File Schema . . . . . . . . . . . Writing Partial Character Encodings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . and Schemas . . . . . . . . . . . . . . . . . . . . Dictionaries. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Dictionaries. . . . . . . . . . Modifying Flat File Dictionary Entries. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Flat File Byte Count Parser . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Modifying an Existing Flat File Schema . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Creating an Entire Flat File Dictionary with Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Dictionaries. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Programmatically Creating Flat File Schemas and Dictionaries . . . . 124 124 125 126 127 127 Appendix C. . . . . . . . . . . . . . . . . . Deleting Flat File Dictionary Entries. . . . . . . . .1 6 . . . . . . . . . . . . Stateful Encodings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Reading Partial Characters . . Sample Flow Services for Working with XML Files . 143 Flat File Schema Developer’s Guide Version 7. . . . . . . . Creating an Empty Flat File Dictionary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . and Schemas . . . . . . . . . . . . . Handling Partial Characters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Creating Flat File Dictionary Entries . . . . . . . . . . . . . . . . . . . . . . . . . . . . Writing Stateful Encodings . . . . . . . . . . . . . . . . . . Creating a Service that Retrieves the XML File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . This guide is for users who want to use webMethods Developer to create flat file schemas and dictionaries to parse and validate inbound flat files and produce outbound flat files. Identifies storage locations for services on the webMethods Integration Server using the convention folder.About This Guide About This Guide The webMethods Integration Server provides the WmFlatFile package to enable you to exchange and process flat files using its built–in services. Identifies characters and values that you must type exactly or messages that the system displays on the console.1 7 . Identifies terms the first time they are defined in text. Do not type the [ ] symbols in your own code. Identifies variable information that you must supply or change based on your specific situation or environment. Identifies keyboard keys. Directory paths use the “\” directory delimiter unless the subject is UNIX‐specific. Document Conventions Convention Bold Italic Description Identifies elements on a screen. Keys that you must press simultaneously are joined with the “+” symbol. you should be familiar the basic concepts described in the webMethods Integration Server Administrator’s Guide and the webMethods Developer User’s Guide. Optional keywords or values are enclosed in [ ]. To use this guide effectively.subfolder:service. Narrow font Typewriter font UPPERCASE \ [ ] Flat File Schema Developer’s Guide Version 7. Also identifies service input and output variables. you can find documentation for all webMethods products on the webMethods Bookshelf.webmethods.” located by default under webMethods installation directory.About This Guide Additional Information The webMethods Advantage Web site at http://advantage. Starting with 7. Additional Documentation.0. To provide feedback on webMethods documentation. Flat File Schema Developer’s Guide Version 7. In addition. go to the Documentation Feedback Form on the webMethods Bookshelf. The webMethods Knowledge Base provides troubleshooting information for many webMethods products.1 8 . Documentation Feedback.com provides you with important sources of information about webMethods products: Troubleshooting Information. you have the option of downloading the documentation during product installation to a single directory called “_documentation. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Concepts Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 What Type of Flat File Constraints Can You Define? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 How Is a Flat File Schema Used to Parse Records? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 What Is a Flat File Dictionary? . . 19 What Is the Flat File Schema Editor? . . . . . . . . . . . . . . . . . . . . . . . . 10 What Is a Flat File Schema? . 10 What Is a Flat File? . . . . . . . . . . . . . . . . . . . . . . . . . . .1 9 . . . . . . 19 Flat File Schema Developer’s Guide Version 7. . .Chapter 1. . . . . . . . . . . . . . . . . . . . . . . . . . 18 When Should I Create a Flat File Dictionary? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . To set up the translation. Field Rec1*C1Field1+C1Field2*FieldA*C2Field1+C2Field2! Composite Record Composite record delimiter = ! field delimiter = * subfield delimiter = + To communicate using flat files. A single logical record of application data is externalized as a set of records without any structural information. ID and ID qualifier. users must create a flat file schema that contains a particular flat file’s structural information. the application receiving the flat file must have knowledge of the structure of the flat file. The fields within a composite are referred to as subfields. except that composites are not allowed inside composites. Therefore. In other words. and fields) within a flat file can be identified. the following flat file data and its list of delimiters enables you to see how elements (records. What Is a Flat File? When different applications attempt to communicate with one another. composites. By nesting records in the flat file schema (adding a record to a record) you can represent the hierarchical structure of the data in the flat file schema. All flat files consist of a list of records containing fields and composites: Fields are atomic pieces of data (for example. Flat files present complex hierarchical data in a record–based storage format. which unlike XML does not embed structural information (metadata) within the data. This enables receivers of flat file documents to parse and validate Flat File Schema Developer’s Guide Version 7. This structural information identifies the parent–child relationships between different records in the flat file. they may not speak the same “language. through the flat file schema. Concepts Overview The webMethods Flat File package (WmFlatFile) is a set of services that enables you to translate documents into and from flat file formats.” Flat files enable you to send data to any application in a mutually agreed upon format so that the data in the files can be read and processed. to read the flat file. Date and time). the metadata of a flat file is separated from the data and contained in a flat file schema. postal code).1. For example. Composites contain multiple fields (for example. The actual data has been “flattened” by removing this hierarchical relationship. A composite definition contains the same information as a record definition. you use a flat file schema to define how to identify individual records within a flat file and what data is contained in each of those records. Records (also known as segments) are sequences of fields and/or composites.1 10 . including how to identify records and separate those records into fields. and the Nth delimited field is identified in the record. Each record is preceded by two bytes that indicate the length of the record. Variable length. What Types of Flat Files Does webMethods Support? The WmFlatFile package can exchange all types of flat files but can process only certain types of flat files. To parse a flat file that does not conform to these restrictions. Fixed length. This can be used regardless of whether a field delimiter has been specified. mainframe punch or print records). Each field is separated by a delimiter. Records in the flat file can have different lengths. you can create a custom service using webMethods Developer. Each distinct record structure has a record identifier. the record identifiers must be located in the same location in all records in the file. If the flat file contains record identifiers. The WmFlatFile package then can identify fields in these records based on either: Delimiters. For more information. This can be used only when a field delimiter (and. Each record is a fixed number of bytes (for example. Byte position. Flat File Schema Developer’s Guide Version 7.1 11 . subfield delimiter) has been specified. see “Default Records” on page 18. the record must be parsed using a default record definition. if necessary. or if no record identifier is present. The WmFlatFile package can process flat files in which: The records in the flat file are defined using one of the following methods: Delimiters.1. see the webMethods Developer User’s Guide. For more information about default records. Each field is defined by 1) the number of bytes from the beginning of the record and 2) the field length. Each record in the flat file is separated by a delimiter. Concepts inbound flat files for use by their back–end systems. and senders of documents to convert outbound documents to flat file format for delivery to another back–end system. “Validation Errors” in this guide. and field levels of flat files. A flat file schema also acts as the model against which you can validate an inbound flat file. A flat file schema consists of hierarchical elements that represent each record. and fields in a flat file. For more information about data validation. including delimiters. and either a definition or reference. What Type of Flat File Constraints Can You Define? Flat file schemas contain information about the document. You define structural constraints for each parent element in the flat file schema. These types of constraints are referred to as validators. the validation engine in the WmFlatFile package compares the records. see Chapter 3. Each element is a record. Concepts What Is a Flat File Schema? A flat file schema is the blueprint that contains the instructions for parsing or creating a flat file and is created as a namespace element in the webMethods Integration Server. and subfield in a flat file. For more information about setting flat file schema constraints. Conditional constraints describe the valid combinations of fields and subfields allowed in records and composites. followed by a City field. the State field might have a content constraint specifying that its value must be exactly two digits.1. Content type constraints describe the possible values or minimum/maximum values for elements in a flat file. record. “Creating and Editing Flat File Schemas and Dictionaries” in this guide. composites. and repeated record structures.1 12 . records. composite. in this guide. or field. you can use the Required (R) conditional validator to require that at least one of the specified fields be present. “Creating and Editing Flat File Schemas and Dictionaries”. see Appendix A. You then configure each element with the necessary constraints. During data validation. you can define validators only for parent records. a flat file schema might describe an address record that consists of a Street Address field. and ZIP Code field. For instructions to create a flat file schema. For example. An inbound flat file is considered valid when it complies with the constraints outlined in its related flat file schema. For example. see Chapter 3. For example. In flat file dictionaries. This blueprint details the structure of the document. State field. composites. field. Flat File Schema Developer’s Guide Version 7. and fields in a flat file with the constraints described for those records and fields in the flat file schema. A flat file schema can define three types of constraints: Structural constraints describe the sequence of records. Fields within a character–delimited composite are separated by a subfield delimiter. Level Document Constraint How the records are parsed What records can appear in the document Whether the records are record definitions or record references The order in which the records can appear Whether a record is mandatory or optional Whether a record can repeat. and field levels. Concepts The following table identifies the types of flat file schema constraints you can set for the document. how many times Record/ Composite How fields and composites are extracted from a record Delimited field. not character lengths and positions.1 13 .1. Whether a field or composite is mandatory or optional How to conditionally validate each field Field Minimum and maximum field lengths List of valid values Range of valid values Partition of valid values Important! All lengths and positions specified in a flat file schema refer to byte lengths and positions. record. This can be used regardless of whether a field delimiter has been specified. Flat File Schema Developer’s Guide Version 7. and if so. Positional field. This can be used only when a field delimiter has been specified. Each field is defined by an offset from the beginning of the record and length. This is important to note because the byte count can differ from the character count for encodings that have multi–byte characters. Extracts the Nth delimited field from the record. 0X09) Octal value (for example. Flat File Schema Developer’s Guide Version 7. The field values then are pulled from the record using the extractors defined in the flat file schema.1 14 . !) or character representation (for example. Finally. you can choose from one of its four record parsers: Delimited Record Parser. the parsed record is placed in the output data based on the structure defined in the flat file schema. Record Parsers A record parser breaks a flat file into individual records. This process is repeated until all records in the flat file have been parsed. If the record cannot be identified and you have not selected a default record. This is done using the record identifier. as defined in the flat file schema using the Flat File Schema Editor. which uses a flat file schema to parse flat files inbound to the Integration Server. \r\n for carriage return) Hexidecimal value (for example. After each record in a flat file has been parsed. each record must be identified. Concepts How Is a Flat File Schema Used to Parse Records? The WmFlatFile package provides the pub. 009) Unicode characters (for example. For information about how to specify field format services.1. see “Format Services” on page 66. This parser expects a specific delimiter to indicate the end of a record. you can specify: A character (for example. \uXXXX. where XXXX represents the unicode value of the character) The occurrence of the record delimiter signals the end of one record and the beginning of the next record. In the WmFlatFile package. For a record delimiter.flatFile:convertToValues service. Identifying the record provides the definition of that record. Fixed Length. You also can format flat file data to meet the requirements of your back–end system or application using the Format Service property on the Flat File Structure tab of the Flat File Schema Editor. the field values are not extracted from the record. the field values are extracted from the record using the definition of the default record. If the record cannot be identified (known as undefined data) and you have selected a default record. The convertToValues service uses a record parser (Delimited. or Variable Length) to parse the records in a flat file. This parser splits a file into records of the same pre‐specified length.1.4 or later. The WmFlatFile package uses that identifier to connect the record definition in a flat file schema with a particular record in the flat file. The parser supports both single‐byte and multi‐byte encodings. the third field is used as the record identifier. You must enter carefully the exact Unicode character values you want to search for in an instance of the flat file you are describing. not the WmFlatFile package. Another example is the use of Unicode Flat File Schema Developer’s Guide Version 7. In this case. For example. Concepts Fixed Length Record Parser. see Appendix B. (The behavior of delimited fields and records remain the same. you can choose from one of two methods of record identification: Starts at position record identifiers compare the value that occurs in the record.” some instances of “Rec1” may be identified as “Rec. there is no functional difference between specifying bytes or characters. if 2 is specified. “Flat File Byte Count Parser”. This change does not affect users who currently parse/compose flat files using single‐byte encodings because one byte equals one character. The name of the record definition must match the value obtained by the record identifier. Documents using this record parser should be created using the webMethods EDI Module. Note that the Starts at position identifier cannot distinguish between all types of record names. Service Pack 2.” Nth Field record identifiers use the value of the specified field as the record identifier.5. These identifiers count from zero (0). Note: This parser measures the lengths and positions of records in terms of bytes.) For details. at the specified offset. Each record may be a different length. EDI Document Type Record Parser. see the webMethods EDI Module User’s Guide. The WmFlatFile package does not perform any kind of normalization on input provided in the flat file schema or when comparing or processing values retrieved from a file. to all the record names defined in the flat file schema. This parser is used only for EDI flat files and provides additional functionality needed to properly parse EDI documents. Prior to 6. the parser measured lengths and positions in terms of characters. you should differentiate wide (sometimes called multi–byte or zenkaku) characters from their narrow (or single–byte) equivalents when processing Asian characters. Record Identifiers A record identifier looks at a record and extracts an identifier out of the data. This parser expects each record to be preceded by two bytes that indicate the length of the record. rather than characters. Variable Length Record Parser. Multi‐byte encoded files must run on JVM version 1.” because “Rec1” begins with “Rec. For more information.1 15 . For example. if you name records “Rec1” and “Rec. In the WmFlatFile package. For example. If extractors are not defined in the flat file schema.1 16 . Undefined Data In some cases. not the start of the record.flatFile:convertToValues service. For example.flatFile:convertToValues service might contain records that were not recognized. the data resulting from the pub. When the convertToValues service processes an unrecognized record. the Shift–JIS and MS932 encodings commonly used with Japanese language text are very similar. If a value is a composite. and so on. known as undefined data. it puts a Flat File Schema Developer’s Guide Version 7. In all cases.1. or of the lack of detail in the flat file schema (such as no record identifier). they can have field delimiters. Instead of a field delimiter. This could be a result of the complexity of the flat file. fields are matched using a strict binary comparison of Unicode character values in the separate fields. From the first field delimiter to the second field delimiter is the second field in the record. Remember that all positions used in extracting fields from a composite are referenced from the beginning of the composite. a subfield delimiter is used to separate a composite into fields. The user specifies the start of the field by specifying the number of bytes from the beginning of the record to the start of the field and specifying the number of bytes from the beginning of the record to the end of the field. Extractors Extractors take data out of a parsed record and place it in the output of the pub. Note: Although fixed length and variable length record parsers do not use record delimiters. You also should exercise care when selecting the encoding of the file being processed. From the beginning of the record to the first field delimiter is the first field in the record. Fields are extracted from a composite based on either the position of the subfield delimiter in the composite or on a substring of the composite. This can result in the WmFlatFile package not finding a match where you otherwise would expect one to exist. Everything from the last field delimiter to the record delimiter (the end of the record) is considered part of the final field. Fields and composites are extracted from a record based on the position of the field delimiter. Some encodings are very similar to one another. the parser returns a series of records that contain no fields or composites. Concepts combining and pre–composed sequences. it is simply a field that can be further parsed into more fields. but they map some characters differently. Fields also can be extracted from a record based on a substring of the original record starting at a particular byte count and ending at a particular byte count. 1. but with fixed field and record delimiters. unrecognized records will be placed into the output IS document with the undefined data tag. and if you use a fixed length or variable length parser.1 17 . Working with undefined data involves three steps: 1 2 3 Configuring the flat file schema and record–level Allow Undefined Data settings. Writing logic to handle the parsed data. In still other cases. By selecting a default record. no errors will be generated if the record contains undefined data. errors will be generated if the record contains undefined data. Note: If your flat file does not contain record identifiers. which it is not the default. Flat File Schema Developer’s Guide Version 7. which might produce errors. Any record that cannot be recognized will be parsed using this default record. You do so using a combination of two fields: The Allow Undefined Data check box on the Settings tab The Allow Undefined Data check box for each record in the flat file schema on the Flat File Structure tab When the Allow Undefined Data check box on the Settings tab is selected. undefined data is expected and should not generate validation errors. and the Allow Undefined Data check box for a particular record is selected. OR parsing the undefined data in each record based on the document structure. such as logic to map the parsed data to another service or perform error handling. Note: If the file is encoded using a multi‐byte encoding. you must select a default record. as described in “Default Records” on page 18. If a default record is not selected. all unidentified records should be parsed using a default record definition. a CSV (comma separated values) file can be parsed as a special case of record with no record identifier. undefined data should not be allowed in the document and if encountered should generate validation errors in the output. In other cases. You can select a default record when creating a flat file schema. For some types of documents. Ignoring undefined data. the service puts two placeholders into the pipeline: unDefData and unDefBytes. If either the Allow Undefined Data check box on the Settings tab or the Allow Undefined Data check box for a particular record is cleared. You can choose whether you want errors to be generated for a flat file schema when undefined data is encountered. Concepts placeholder named unDefData in the resulting IS document (IData object) and stores the record as a string in the pipeline. see “Customizing the Flat File Configuration Settings” on page 74. When creating an element definition in a flat file dictionary. and fields. By default. the record does not have a record identifier). If a default record has not been specified. if you have a CSV (comma separated values) flat file that simply lists the name. This allows you to create record definitions in a dictionary that can be used across multiple flat file schemas. if your flat file schema does not contain any record identifiers. You then specify the remaining properties in the instance of the element definition in a particular flat file schema. 321 Oak Dr Memphis TN. 888–555–1111. Concepts Default Records If the pub. each recordWithNoID record appears as a child of the record above it. A flat file dictionary is simply a repository for elements that you reference from flat file schemas. To modify this default behavior. Flat file dictionaries are created as namespace elements in the Integration Server and contain definitions of records. the record will be treated as undefined data unless you specify a default record definition to be used to parse all unrecognized records of a particular type. in an array. address. Reusing record definitions reduces the amount of memory consumed by a flat file schema. If you specified a default record definition to parse this particular type of record. the record will be treated as undefined data. 123 Main St Washington DC. the element definition is updated automatically in all of the flat file schemas.1 18 . A default record can only be defined in a flat file dictionary. Flat File Schema Developer’s Guide Version 7.1. you must specify a default record. the file can be properly parsed and converted to an IS document (IData object) of the name recordWithNoID. 800–555–2222. and phone number of a group of customers. none of the records would have a record identifier: John Doe. as described in “Undefined Data” on page 16. For example. When you change a definition in a flat file dictionary that is referenced in multiple flat file schemas. you specify only certain properties. Note: You can reference a flat file dictionary definition in any flat file schema regardless of whether the dictionary and schema are located in the same package. composites.flatFile:convertToValues service cannot recognize a record (for example. What Is a Flat File Dictionary? A flat file schema can contain either record definitions or references to record definitions that are stored elsewhere in the namespace in a flat file dictionary. In fact. Jane Smith. An example of this is EDI ANSI X12 and UN/EDIFACT documents. This allows for the entire document to be edited in a single view. In this way. EDI ANSI X12 also has different versions of these documents (for example.1 19 . Reusing definitions reduces the amount of memory consumed by the webMethods Integration Server. A more complex scenario would involve multiple families of documents and multiple versions of those families. without referencing a flat file dictionary. The definitions then can be reused at a later time. or composite between versions are maintained. Defining these records. 4010). All flat file schemas in one version of the same family should use the same dictionary. field. the best approach is to create the definitions in the flat file dictionary and reference them in a flat file schema. Developer displays the contents of the flat file schema or dictionary in the Flat File Schema Editor. Each version of the document set should have its own dictionary. and composites in a dictionary allows for them to be reused throughout the entire set of EDI ANSI X12 document flat file schemas. In a scenario in which you intend to parse only one flat file. One dictionary should be created for each version of EDI ANSI X12 documents and one dictionary should be created for each version of EDI UN/EDIFACT documents. composite. and composite definitions many times. What Is the Flat File Schema Editor? When you select a flat file schema or dictionary from the Navigation Panel of webMethods Developer.1. or flat files that do not share record. If a clear choice does not exist between these two scenarios. A separate dictionary would not be required for each flat file schema in the same version. you can define these elements directly in the flat file schema. you can be certain that changes to a record. field. fields. Concepts When Should I Create a Flat File Dictionary? The decision to define records in a flat file dictionary versus in a flat file schema depends on the type of flat files that you intend to parse. Flat File Schema Developer’s Guide Version 7. The Electronic Document Interchange (EDI) ANSI X12 standard defines a large set of document structures that reuse the same record. or field definitions. 1. content type.1 20 . Identifies a flat file schema in the Navigation Panel. Note: A green check mark next to a flat file schema or dictionary ( ) indicates that the flat file schema or dictionary is locked and available to be edited. the schema or dictionary is unlocked and cannot be edited. Flat File Dictionary. For detailed information. see “Flat File Structure Tab” below. When the check mark is absent. Flat File Structure tab. Symbol Description Flat File Schema. The Flat File Schema Editor is divided into the following sections: Flat File Definition tab. This tab enables you to specify the structural. This tab enables you to specify what type of flat file you are parsing or creating. and conditional constraints of your flat file schema. Concepts Identifying Flat File Schemas and Dictionaries Name of Flat File Schema Navigation Panel Flat File Schema Editor The following table identifies the symbols for flat file schemas and dictionaries in the Navigation Panel of webMethods Developer. Flat File Schema Developer’s Guide Version 7. Identifies a flat file dictionary in the Navigation Panel. composite. your reference is broken. Identifies a composite reference in a flat file schema. either delete the reference or re–create the definition in the appropriate dictionary. Flat file schemas that contain broken references will not parse correctly. Identifies a field reference in a flat file schema. Composite Definition. Composite Reference. Field Reference. If you create a composite and then select that composite. Flat File Schema Developer’s Guide Version 7. you can add only a field reference or field definition. For example. See Record Reference in this table for information about “Reference not found. A composite definition contains the same information as a record definition. except that composites are not allowed inside of a composite. Identifies a record reference in a flat file schema. when you have a record selected. If “Reference not found” appears after the reference name. The Flat File Schema Editor uses unique symbols to represent the components of flat file schemas and dictionaries. A broken reference indicates that the referenced element no longer exists. composites and fields. See Record Reference in this table for information about “Reference not found. you can add record.1. when you add a new element it will be added as a child of the selected element. Record Reference. An element reference refers to an element definition in a flat file dictionary. To fix a broken reference. allow undefined data. Flat File Structure Tab When creating your flat file schema.1 21 . Identifies a field definition in the flat file. This panel enables you to configure a default record.” Field Definition. or field references or definitions to this record. you will create new records. The appropriate new element selections will be displayed for that element level. Symbol Description Record Definition. and set up the ACL (access control lists) permissions for your flat file schema or dictionary.” An element definition is an element that is contained in a flat file schema or dictionary. add areas. For the element name you have selected in the Flat File Schema Editor. Concepts Properties panel. The following table identifies the symbols for each component that can appear in a flat file schema. Identifies a record definition in a flat file schema. Identifies a composite definition in a flat file schema. and then click to move the element up or down in the flat file schema structure. “Processing Flat Files Overview” of this guide. Concepts You use the buttons at the top of this tab to edit the structure of your schema. The following table provides a description of each of these buttons. For more information. and then click to move the element left or right in the flat file schema structure.1 22 . and then click to delete the selected element. The IS document type is used to map the output of the convertToValues service to another format. see “Mapping Flat File Data” on page 27 of Chapter 2.1. Select the desired element. Select the desired element. Button Description Select the desired element. Creates an IS document type for this flat file schema. Flat File Schema Developer’s Guide Version 7. Chapter 2. Processing Flat Files Overview Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 Processing Inbound Flat Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 Processing Outbound Flat Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 Flat File Schema Developer’s Guide Version 7.1 23 2. Processing Flat Files Overview Overview As discussed in Chapter 1, “Concepts” in this guide, the webMethods WmFlatFile package enables you to exchange all types of flat files and process certain types of flat files. You create flat file schemas to convert and validate inbound flat files and to create outbound flat files. The following diagram summarizes the services that the WmFlatFile package provides to process flat files: pub.flatFile:convertToValues and pub.flatFile:convertToString. For descriptions, see the table that follows the diagram below. Note: If you also are using Trading Networks, see the sections about flat file TN document types in the webMethods Trading Networks Concepts Guide and webMethods Trading Networks Administrator’s Guide for information about how Trading Networks processes flat files. Processing Flat Files webMethods Integration Server Flat File Package Conversion/Validation Services Flat File (ffData) Inbound Receive flat file convertToValues (optional validation) Process IS Document Flat File Schema Process IS Document convertToString Flat File (ffData) Send/Process Flat File IS Doc (ffValues) IS Doc (ffValues) Outbound Item Flat File (ffData) Description Flat file input with type of String, InputStream, or ByteArray (received by the Integration Server via File Polling, HTTP, FTP, etc. For more information, see Chapter 4, “Sending and Receiving Flat Files” in this guide.) Flat File Schema Developer’s Guide Version 7.1 24 2. Processing Flat Files Overview Item Conversion/ Validation Services Description WmFlatFile package provides services (pub.flatFile:convertToValues and pub.flatFile:convertToString) that parse, validate, and convert inbound flat files to IS documents (IData objects), and construct outbound documents from IS documents. For more information about these services, see Chapter 5, “WmFlatFile Built–in Services Reference” in this guide. Flat File schema containing the structure of the flat file. An IS document (IData object) represents the structure and values of your flat file for eventual mapping or other processing. All inbound documents must be converted to IS documents before being processed further. Flat File Schema IS Doc (ffValues) Formatting Inbound and Outbound Data You can format flat file data to meet the requirements of your back–end system or application. The Format Service property in the Flat File Schema Editor enables you to specify the service you want to invoke for a particular field when convertToValues or convertToString is called. For example, when using the convertToValues service to convert a date field in a flat file into an IS document, you can specify that a particular format service be invoked for that field during parsing. To alter the format of the date field, you might invoke a service that changes the format of the field from YYYYMMDD to MMDDYYYY. For information about how to specify field format services, see “Format Services” on page 66. Processing Inbound Flat Files The WmFlatFile package provides the pub.flatFile:convertToValues service, which uses a flat file schema to parse flat files inbound to a webMethods Integration Server. The input of this service is a flat file and the name of a flat file schema, and the output of this service is an IS document (IData object). The output IS document is created based on the structure defined in the flat file schema. You can also specify to validate the flat file against the flat file schema, which generates errors as output based on the constraints placed on the records and fields in the flat file schema. Note: Validation is turned off by default. To enable validation, you must set the validate variable of the convertToValues service to true. You should use this service as part of customized flow services. You then can use webMethods Developer services to process the resulting data as necessary, (for example, map data from one format to another). For more information about creating flow services, Flat File Schema Developer’s Guide Version 7.1 25 For more information. Processing Flat Files Overview see the webMethods Developer User’s Guide. the flat file parser ignores any data that appears before the first valid record in the file. “Creating and Editing Flat File Schemas and Dictionaries” in this guide. Flat File Schema Developer’s Guide Version 7. and validate inbound flat files. Use the webMethods Developer to create the flat file schemas used to parse.2. The general process for inbound flat files is as follows: Inbound Flat File Process Conversion/Validation Flat File (ffData) convertToValues (optional validation) IS Doc (IData) Process IS Document Flat File Schema Is Valid errors The flat file schema provides the convertToValues service with the information necessary to detect the boundaries between records and fields. convert. “Sending and Receiving Flat Files” in this guide. For more information about mapping data. Note: When parsing a file. the service matches the record in the flat file with a record defined in the flat file schema using the record identifier. see “Mapping Flat File Data” on page 27. Step 1: Create Appropriate Flat File Schema Before you start working with an inbound flat file. see Chapter 4. Step 2: Receive the Flat File The webMethods Integration Server provides a number of ways to send and receive flat files. After a record boundary is detected. you must create a flat file schema to be used for conversion and validation of the document. see Chapter 3.1 26 . For steps to create flat file schemas. you must set the validate variable of the convertToValues service to true. For more information about the convertToValues service. During flat file parsing.2. To set or change the constraints for a particular flat file schema.1 27 . record. Step 4: Process the IS Document webMethods Developer provides tools for processing IS documents (IData objects). and Validate Flat File Data to an IS Document To parse a flat file using a flat file schema. These steps enable you to map data into other formats. see Chapter 5. Mapping Flat File Data In many cases it is necessary to map the output of the convertToValues service to another format. or user– defined format. which returns errors describing how the given ffData violates the constraints described in the flat file schema. see Chapter 3. Creating an IS document type from your flat file schema enables you to reference and view the document structure in a flow service. and/or field constraints you defined in a flat file schema. see “What Type of Flat File Constraints Can You Define?” on page 12. and to convert the data into IS documents (IData objects). Processing Flat Files Overview Step 3: Parse. “Creating and Editing Flat File Schemas and Dictionaries” in this guide. “Validation Errors” in this guide. To validate a flat file against the flat file schema used to parse the file. it is an option to validate the flat file against the document. such as your back–end. For a list of the constraints you can set. Flat File Schema Developer’s Guide Version 7. “WmFlatFile Built– in Services Reference” in this guide. Convert. including mapping data into other formats. For a list of validation error codes and messages. you call the convertToValues service. see Appendix A. For the flow service you are creating or editing. as shown in the figure above. Processing Flat Files Overview To map flat file data 1 In the Developer Navigation Panel.1 28 . if your flat file schema name is “PurchaseOrder. with “DT” appended. This creates an IS document type in the same folder as This IS document type is named the same as the flat file schema. and then click the schema. select the saved flat file schema. For example.flatFile:convertToValues flow operation.2. . Flat File Schema Developer’s Guide Version 7. on the Flow Editor of the Developer select the INVOKE pub.” the related IS document type name is “PurchaseOrderDT. click the Flat File Structure tab.” 2 3 Click to save the IS document type. 2. Select Document 5 In the Select dialog box. “Test:PurchaseOrder”). Flat File Schema Developer’s Guide Version 7. Perform the following to add a Document Reference to the IS document type that is based on the flat file schema. . in the ffSchema variable specify the location and name of the flat file schema (for example. The name appears in the Name box. then click Reference to add a new document reference variable. Processing Flat Files Overview 4 On the Pipeline tab under Service In. “PurchaseOrderDT”). navigate to the IS document type created in step 1 of this procedure (for example. a b On the Pipeline tab click under Pipeline Out.1 29 . Click OK. Specify other inputs as necessary. the WmFlatFile package receives a flat file and keeps the file content in memory during processing. out–of–memory errors might occur. Flat File Schema Developer’s Guide Version 7. the WmFlatFile package processes all flat files in the same manner. the WmFlatFile package can encounter problems when working with these files because the system does not have enough memory to hold the entire parsed file. map the value of the ffValues variable to the document reference variable created in this procedure. this object becomes null.1 30 . 7 Click to save the service. The service generates an output object (ffIterator variable) that encapsulates and keeps track of the input records during processing.2. That is. you can set the iterator variable in the pub. the convertToValues service returns and the iterator moves to the top level of the next record in the schema. you should exit from the repeat step to discontinue processing. If some or all of the files that you process using the WmFlatFile package encounter problems because of memory constraints. until all records are parsed. If the results were kept in the pipeline. if you receive large files. the results are mapped and dropped from the pipeline to conserve memory.wmflatFile:convertToValues service to true to process top level records (children of the document root) in the schema one at a time. When the ffIterator variable is null. However. Handling Large Flat Files As installed. After all child records of the top level record are parsed. This parsing should be done in a repeat step where each time the convertToValues service returns. Processing Flat Files Overview 6 On the Pipeline tab under Service Out. When all input data has been parsed. regardless of their size. If you specified only certain parts of the flat file to translate to the IS document (via the flat file schema). and subfield separators as well as optionally specify an outputFileName so that the output also will be written to a file. Processing Flat Files Overview Processing Outbound Flat Files The WmFlatFile package provides the pub. The general process for outbound documents is as follows: Outbound Flat File Process Conversion IS Doc (IData) convertToString Send/Process Flat File Flat File (ffData) Flat File Schema Step 1: Create Appropriate Flat File Schema Before you start working with an IS document (IData object). only those parts will be translated back to the flat file.1 31 . which uses a flat file schema to create a flat file outbound from a webMethods Integration Server. “Creating and Editing Flat File Schemas and Dictionaries” of this guide. you must create a flat file schema to be used for conversion of the object.flatFile:convertToString service. Flat File Schema Developer’s Guide Version 7. You use webMethods Developer to create the flat file schemas used to create outbound flat files. Step 2: Convert the IS Document to a Flat File The WmFlatFile package provides the convertToString service to convert flat file IS documents (IData objects) to outbound flat files using the flat file schema you created. Note: The flat file resulting from convertToString will be only as complete as the information translated from the original flat file to the IS document.2. and the output of this service is a flat file. field. This service enables you to specify delimiters to be used as record. of course. see Chapter 3. The input of this service is an IS document (IData object) and a flat file schema. For steps to create flat file schemas. on the Flow Editor of the Developer select the INVOKE pub. in the ffSchema variable specify the location and name of the flat file schema (for example. This creates an IS document type in the same folder This IS document type is named the same as the flat file schema. select the saved flat file schema. Flat File Schema Developer’s Guide Version 7. Specify other inputs as necessary.flatFile:convertToString flow operation. as shown in the figure above.” 2 3 4 Click to save the IS document type.2. To convert an IS document to flat file data 1 In the Developer Navigation Panel.1 32 . For the flow service you are creating or editing. click the Flat File Structure tab. The following steps provide an example of how you might convert an IS document to a flat file. On the Pipeline tab under Service In. if your flat file schema name is “PurchaseOrder. “Test:PurchaseOrder”). .” the related IS document type name is “PurchaseOrderDT. For example. and then click as the schema. with “DT” appended. Creating an IS document type from your flat file schema enables you to reference and view the document structure in a flow service. Processing Flat Files Overview Example In many cases it is necessary to map the output of the convertToString service to another format. including via HTTP. see Chapter 4. navigate to the IS document type created in step 1 of this procedure (for example. For more information. . and FTP. Select Document Reference On the Select dialog box. Click OK. The name appears in the Name box.1 33 . click under Pipeline In.2. a b On the Pipeline tab. Processing Flat Files Overview 5 Perform the following to add a Document Reference to the IS document type that is based on the flat file schema. “Sending and Receiving Flat Files” in this guide. Step 3: Send/Process the Flat File After the flat file is created. 7 Click to save the service. SMTP. Flat File Schema Developer’s Guide Version 7. you can send or process the file as necessary. then click to add a new document reference variable. “Test:PurchaseOrder”). map the document reference variable created in this procedure to the value of the ffValues variable under Service Out. You can send a flat file using many methods. 6 On the Pipeline tab. 1 34 .2. Processing Flat Files Overview Flat File Schema Developer’s Guide Version 7. . . . . . . . . . . . . . . . . . . . . . 72 Managing Flat File Dictionary Dependencies . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72 Setting Access Permissions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 Step 4: Test the Flat File Schema . . . . . .1 35 . . . . . . . . . . . . . . . . . . . 73 Customizing the Flat File Configuration Settings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 Step 2: Specify Flat File Properties . . . . . . . . . . . . . . . . . . . . . . . . . 74 Flat File Schema Developer’s Guide Version 7. . . . 41 Step 3: Define the Structure of the Flat File Schema . . . . . . . . . . . 36 Step 1: Add and Configure the Flat File Schema . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Creating and Editing Flat File Schemas and Dictionaries Creating a Flat File Schema . . . . . . . . . . . . .Chapter 3. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68 Creating a Flat File Dictionary . . . . . . . . . 69 Editing a Flat File Schema or Dictionary . and then click Next. select the type of parser for this flat file schema: Delimiter. 7 On the Flat File Definition tab under Record Parser. see the webMethods Developer User’s Guide. Type the name of the new flat file schema. create a flat file dictionary. Variable Length. and the Flat File Schema Editor displays in the right pane. Flat File Schema Developer’s Guide Version 7. select its location (the folder you created in the WmFlatFile–dependent package). The first two bytes of the input data stream contains the length of each record.1 36 . or composite definitions should use a common dictionary. see “Creating a Flat File Dictionary” on page 69. To simplify the steps needed to create a flat file schema. 2 3 4 5 6 In the New dialog box. The flat file schema you created is automatically selected. and then click Finish. click File New in the menu bar. If you want to reuse element definitions in other flat file schemas.3. fields.) For more information about creating and using a flat file dictionary. mainframe punch or print records). Create a new folder within the new package. In webMethods Developer. Each record is of a fixed length (for example. If you need instructions for creating packages within the Developer. Fixed Length. select Flat File Schema. (Note that any flat file schemas sharing records. Each record is separated by a delimiter. this procedure is broken down into sections: “Step 1: Add and Configure the Flat File Schema” on page 36 “Step 2: Specify Flat File Properties” on page 41 “Step 3: Define the Structure of the Flat File Schema” on page 48 “Step 4: Test the Flat File Schema” on page 68 Step 1: Add and Configure the Flat File Schema To add a new flat file schema 1 Create a package with a dependency on the WmFlatFile package by clicking and typing WmFlatFile in the Package box and its version number in the Version box. Creating and Editing Flat File Schemas and Dictionaries Creating a Flat File Schema Creating a flat file schema consists of a number of steps. 8 For all types of record parsers. Description Optional – Character that separates fields in a flat file document. you should use the wm. Although you can create EDI flat file schemas using the Flat File Schema Editor. Flat File Schema Developer’s Guide Version 7. 009. \uXXXX.3.1 37 . you can also select carriage return line feed (or specify \r\n) if a record ends with the two–character CRLF. Software AG does not recommend it. Do not select this option. 013) Unicode characters (for example. Note: In subsequent steps you can specify delimiters using the Character property. The EDI Document Type option is displayed for you to view existing EDI flat file schemas. if you specify 4 as the Character position. Creating and Editing Flat File Schemas and Dictionaries EDI Document Type. see the webMethods EDI Module User’s Guide. you have indicated that the field delimiter appears in the fifth character position from the beginning of the document.b2b. For more information and steps. For the Record delimiter. use the following syntax: One character or character representation (for example. When you specify delimiters. Important! If you are using the webMethods EDI Module to process EDI documents. 0X13) Octal value with prefix “0” or decimal value (for example. \t for tab). For example. This guide does not provide information about creating EDI flat file schemas for use with the webMethods EDI Module. the character position at which the field delimiter for this document is located. where XXXX represents the unicode value of the character) The space character is allowed as a delimiter.edi services to create your flat file schemas. \n for line terminator. Hexidecimal value with prefix “0X” (for example. 0X09. *. specify the following fields: a For Field or Composite: Property Character –OR– Character position Optional – Starting from the beginning of the document and counting from zero (0). the record would appear as a\+b\+c+d\+e\+f. –OR– Character position Optional – Starting from the beginning of the document and counting from zero (0). you have indicated that the release character appears in the sixth character position from the beginning of the document. the value of the record would be a+b+c and d+e+f. When using the convertToString service to create a\+b\+c+d\+e\+f. if you specify 5 as the Character position. Flat File Schema Developer’s Guide Version 7. The character following the release character will not be treated as a delimiter.1 38 . you have indicated that the subfield delimiter appears in the sixth character position from the beginning of the document. the convertToString service uses Quoted Release Character. you must preface it with your release character. Creating and Editing Flat File Schemas and Dictionaries b For Subfield: Property Character –OR– Character position Optional – Starting from the beginning of the document and counting from zero (0). When using + within a field as text. For example. Description Optional – Character that separates subfields in a flat file document. original meaning. the character position at which the subfield delimiter for this document is located. your field delimiter is + and your release character is \.3. Property Character Description Optional – Character used to enable a delimiter to be used for its intended. the character position at which the release character for this document is located. For example. If you specify both. For example. c For Release Character: Specify either Release Character –or– Quoted Release Character. if you specify 5 as the Character position. When using the convertToValues service to create the strings a+b+c and d+e+f. For example. the value of the record would be Doe. if you specify 3 as the Character position. you have indicated that the record delimiter appears in the fourth character position from the beginning of the document. If you specify both. the Quoted Release Character will be used.“Doe. Flat File Schema Developer’s Guide Version 7. Jane”. When you want to use (. Any delimiter characters that appear within this section will not be treated as delimiters. the character position at which the record delimiter for this document is located. if you specify 5 as the Character position. –OR– Character position Optional – Starting from the beginning of the document and counting from zero (0). the convertToString service uses Quoted Release Character. if you have specified both the Release Character and the Quoted Release Character.3. complete the following Record fields: Property Character –OR– Character position Starting from the beginning of the document and counting from zero (0). John”. Creating and Editing Flat File Schemas and Dictionaries d For Quoted Release Character: Specify either Release Character –or– Quoted Release Character. John and Doe. Description Character that separates records in a flat file document. When using the convertToString service. you have indicated that the quoted release character appears in the sixth character position from the beginning of the document.1 39 .) Property Character Description Optional – Character used to enable a section of text within a field to be represented as its literal value. 9 If you selected Delimiter for Record Parser.) and your release character is “. When using the convertToValues service to create the strings Doe. you must preface it with your quoted release character. Jane”. When using the convertToString service to create “Doe.“Doe. For example. your field delimiter is (.) within a field as text. For example. John”. the record would appear as “Doe. Jane. the character position at which the quoted release character for this document is located. John and Doe. Jane. complete the appropriate Record Identifier property: Property Starts at Position Description Counting from zero (0). This value cannot be null and must be an integer greater than or equal to zero (0). Flat File Schema Developer’s Guide Version 7. or \t (tab). in characters. set the useReadableDelimiterReporting variable to false.1 40 . For example.3. Creating and Editing Flat File Schemas and Dictionaries Important! If records use a fixed position extractor. such as \r (carriage return). 11 To define the record identifier for this flat file schema. You will not be able to extract the record delimiter character in a fixed position field. Important! If you use the webMethods EDI Module. –OR– Nth Field Counting from zero (0). complete the following Record Parser field: Property Record length Description Length. indicates which field in each record you want used as the record identifier. you have indicated that the record identifier appears in the sixth character position in each record. see “Customizing the Flat File Configuration Settings” on page 74. if you specify 5 as the Starts at Position. This field is available only if you have specified a field delimiter. the Delimiter record parser does not include the record delimiter character in the parsed record. The default for this field is zero (0). of each record in the flat file. \n (line feed). 10 If you selected Fixed Length for Record Parser. For details. the character position at which the record identifier is located. This variable controls how the Delimiter record parser parses non‐readable characters. 3. click Delete to delete the default record for this flat file schema. Note: If the floating record has an alternate name. This record is used to parse an undefined data record when the convertToValues service fails to find a match between the flat file and the flat file schema.1 41 . Displays the name of the flat file dictionary that contains the default record. If a default record is not selected. Displays the name of the record reference that will be used as the default record. Optional – The name of the record that is defined in the schema as a floating record. Creating and Editing Flat File Schemas and Dictionaries Step 2: Specify Flat File Properties To specify properties for the flat file schema 1 2 View the Properties panel. For more information about the Undefined Data property. convertToValues will generate errors when it encounters undefined data. see “Floating Records” on page 43. specify the alternate name in this field. Under Default Record. Note: If the flat file you are parsing does not contain record identifiers. Delete Under Value. configure the following properties: Property Set Description Optional – Under Value. If the default record is specified when creating the flat file schema. Dictionary Name Floating Record Flat File Schema Developer’s Guide Version 7. The actual record definition still exists. but is no longer assigned to this flat file schema. By selecting a default record. the record will be treated as undefined data. you must select a default record. click Set to select the default record for this flat file schema from a flat file dictionary. If the Undefined Data property is set to False and the validate variable of the convertToValues service is set to true. any record that cannot be recognized will be parsed using this default record. see page 42. a CSV (comma separated values) file can be parsed as a special case of record with no record identifier. For details about how the parser handles floating records. but with fixed field and record delimiters. you would assign the appropriate area to a record to identify in which section of the document the record belongs. Click Choices to display the Areas dialog box. 4 Under Settings. which enables you to use the following buttons to add and edit areas. Note: For a file that is encoded using a multi‐byte encoding. For more information about the record–level property. Click to insert a new area in a specific location in the list. the Areas property enables you to add and edit areas for this flat file schema. you may have an address record that needs to specify the shipping address in the document header. Creating and Editing Flat File Schemas and Dictionaries 3 Under Settings. see the Allow Undef Data property on page 57. it puts a placeholder named unDefData in the resulting IS document and stores the record as a string in the pipeline. This is the default. If you want to allow undefined data. the behavior is different. If you want to re‐parse such a file to extract fixed byte position fields. You now can choose whether to allow undefined data at the record level.3. To differentiate these two records. Property Description Click to add a new area to this flat file schema. Note: Areas are used primarily for EDI document parsing. If the validate variable of the convertToValues service is set to true. For example. the convertToValues service will generate errors when undefined data is encountered. Flat File Schema Developer’s Guide Version 7. select True. Click to delete an existing area. You must save the flat file schema before the new area will be available for use in your flat file structure. the Undefined Data property helps control the generation of undefined data errors at any location in the flat file schema. Then when defining a record in “Step 3: Define the Structure of the Flat File Schema” on page 48. If you do not want to allow undefined data in any location in this flat file schema. An area is a way to associate an arbitrary string with a given record. the service places unDefData and unDefBytes into the pipeline. you would create “Header” and “Detail” areas. but needs to specify the billing address in the document detail. use unDefBytes. When the convertToValues service processes an undefined record.1 42 . select False. When you use a fixed length or variable length parser (but not a delimited parser) to parse such a file. Creating and Editing Flat File Schemas and Dictionaries Floating Records You can use the Floating Record property to designate any single record of a given flat file schema to be a floating record. This property appears in the Properties panel of the Flat File Schema Editor (see the table in step 8 on page 55). Flat File Schema Developer’s Guide Version 7.1 43 . (The position in which it appears in the parsed record is explained in the following sections.3. you would designate NTE to be a floating record so it may appear anywhere in the EDI document without causing a validation error. and places each NTE record that appears in an EDI document into this container at run time.e. The parser supports floating records for both inbound and outbound parsing (i. By designating a floating record. while executing the convertToValues and convertToString services. If a flat file schema contains multiple instances of the designated floating record at multiple record levels. For examples. For example.. you enable that record to appear in any position within a flat file without causing a parsing validation error. it ignores Rec2 and Rec3.) The parser creates a container for NTE records. respectively). If you do not use this property. the system creates a container for each record level. see “Examples: Parsing Inbound Floating Records” on page 44 and “Examples: Parsing Outbound Floating Records” on page 47. In addition. not the second record. validation errors will occur if the record structure of an inbound document does not match the record structure defined in its flat file schema. To solve this problem. This problem can also occur while converting outbound IS documents (IData objects) into string documents. consider the following EDI document and its flat file schema (where all records are mandatory except the record NTE): Flat file schema definition Rec1 Rec2 Rec3 Input EDI document Rec1 NTE Rec2 Output IS document Rec1 NTE NTE Rec3 The parser generates a validation error because it expects NTE to be the last record. and places NTE (1). A validation error is generated if more than 99 NTE records appear in the document. Example 1: Flat file schema definition Rec1 NTE [] Max Occurs 99 Rec2 Rec3 Rec4 Rec5 Input EDI document Rec1 Rec2 Rec3 Rec4 NTE (1) NTE (2) NTE (3) Rec5 Output IS document Rec1 NTE [] NTE (1) NTE (2) NTE (3) Rec2 Rec3 Rec4 Rec5 In accordance with the schema definition. the parser handles them as shown in the following examples. the parser creates an NTE array as the first record. NTE (2). Creating and Editing Flat File Schemas and Dictionaries Examples: Parsing Inbound Floating Records When the convertToValues service receives a document that includes floating records. and NTE (3) into it. NTE records are not allowed prior to the Rec1 record.1 44 . Assume that the Floating Record property is set to the record NTE.3. Example 2: Flat file schema definition Rec1 NTE [] Max Occurs 99 Rec2 [] Max Occurs 99 NTE [] Max Occurs 99 Rec3 Rec4 Rec5 Input EDI document Rec1 NTE (1) Rec2 Rec3 NTE (2) Rec4 NTE (3) Rec2 NTE (4) Rec5 NTE (5) Output IS document Rec1 NTE [] NTE (1) NTE (5) Rec2 [] Rec2 NTE [] NTE (2) NTE (3) Rec3 Rec4 Rec2 NTE [] NTE (4) Rec5 Flat File Schema Developer’s Guide Version 7. Flat File Schema Developer’s Guide Version 7. Thus. and Rec2) match the schema. as specified in the schema definition. the parser places NTE (2) in this container. in the Rec2 array. as specified in the schema definition. Creates another NTE container (an array) under Rec2. the next record in the document is Rec3 (followed by NTE (2)). This is valid.1 45 . In accordance with the schema definition. in accordance with the schema definition. To determine which container to put NTE (2) in. Creates a Rec2 array. NTE (2) Rec3 Rec4 a The positions of the first three records (Rec1. the parser looks for the last defined container at the current level. Rec4. b Even though the schema definition says the next record should be an NTE (followed by Rec3). the parser: Creates an NTE container (an array) under Rec1. NTE (1). the parser simply: Places Rec3 into the Rec2 array. NTE (1) Rec2 [] Rec2 NTE [] <== NTE container for Rec2 array. and places NTE (1) into it. Creating and Editing Flat File Schemas and Dictionaries How Example 2 was Parsed 1 The first six records of the EDI document were parsed as follows: Input EDI document Rec1 NTE (1) Rec2 Rec3 NTE (2) Rec4 Output IS document Rec1 NTE [] <== NTE container for Rec1. c The parser places the next record.3. and places Rec2 into it. the parser adds another Rec2 to the Rec2 array. the parser also creates another NTE container. the parser places NTE (3) in the same container as NTE (2). Just as with the first Rec2 in the array. Thus. Creating and Editing Flat File Schemas and Dictionaries 2 Parsing NTE (3): Input EDI document Rec1 NTE (1) Rec2 Rec3 NTE (2) Rec4 Output IS document Rec1 NTE [] NTE (1) Rec2 [] Rec2 NTE [] NTE (2) NTE (3) <== added to this container at current level Rec3 Rec4 NTE (3) To determine which container to put NTE (3) in. 3 Parsing Rec2 and NTE (4): Input EDI document Rec1 NTE (1) Rec2 Rec3 NTE (2) Rec4 NTE (3) Rec2 Output IS document Rec1 NTE [] NTE (1) Rec2 [] Rec2 NTE [] NTE NTE Rec3 Rec4 Rec2 NTE [] Rec2 NTE (2) (3) NTE (4) <== creates an NTE container for second (4) In accordance with the schema definition. for the second Rec2. the parser looks for the last defined container at the current level.1 46 . Flat File Schema Developer’s Guide Version 7.3. To determine which container to put NTE (5) in. assume that the Floating Record property is set to the record NTE.3. the parser places Rec5 under Rec1.1 47 . Thus. the parser places each floating record immediately following its parent record (as defined in the IS document). the parser places NTE (5) in the same container as NTE (1). the parser looks for the last defined container at the current level. Creating and Editing Flat File Schemas and Dictionaries 4 Parsing Rec5 and NTE (5): Input EDI document Rec1 NTE (1) Rec2 Rec3 NTE (2) Rec4 NTE (3) Rec2 NTE (4) Rec5 Output IS document Rec1 NTE [] NTE (1) NTE (5) <== this container is same level as Rec5 (current level) Rec2 [] Rec2 NTE [] NTE (2) NTE (3) Rec3 Rec4 Rec2 NTE [] NTE (4) Rec5 NTE (5) a b In accordance with the schema definition. Example 1: Flat file schema definition Rec1 Rec2 NTE [] Rec3 Rec4 Input IS document Rec1 Rec2 Rec3 NTE [] NTE(1) NTE(2) Rec4 Output string Rec1!Rec2!Rec3!NTE(1)!NTE(2)!Rec4 Flat File Schema Developer’s Guide Version 7. In the following examples. Examples: Parsing Outbound Floating Records When the convertToString service converts an IS document (an IData object) to a string. you must set the validate variable of the convertToValues service to true. Validator. and Undefined Data properties. This enables errors to be generated for the Ordered. see Chapter 5. the parser places them after Rec1 in the string. click the Flat File Structure tab of the Flat File Schema Editor.1 48 . Example 2: Flat file schema definition Rec1 Rec2 NTE [] Rec3 Rec4 Input IS document Rec1 Rec2 Rec3 Rec4 NTE [] NTE(1) NTE(2) Output string Rec1!NTE(1)!NTE(2)!Rec2!Rec3!Rec4 Because NTE(1) and NTE(2) are children of Rec1. Mandatory. For more information about this service. To enable validation. To define the structure of a flat file schema 1 With the flat file schema name selected in webMethods Developer Navigation Panel. Step 3: Define the Structure of the Flat File Schema Important! Validation is turned off by default. “WmFlatFile Built–in Services Reference” of this guide. Creating and Editing Flat File Schemas and Dictionaries Because NTE(1) and NTE(2) are children of Rec3. Flat File Schema Developer’s Guide Version 7. the parser places them after Rec3 in the string.3. click the name of the flat file schema in the Name column. select the dictionary.3. . Select the element that you want to reference and then click Next. and then click Next. After selecting Record Reference. Navigate to the flat file dictionary in which the record is located. You also can right–click an element and 3 Select one of the following.1 49 . click Next. After selecting Record Definition. Select to create a reference to a record definition in a flat file dictionary. Creating and Editing Flat File Schemas and Dictionaries 2 To add the first record. The Select New wizard appears. Flat File Schema Developer’s Guide Version 7. Property Record Definition Record Reference Description Select to create a record definition to be used one time in this flat file schema. and then click select Add. click Next. The name of the record definition in the flat file dictionary does not need to match the record identifier that appears in the flat file. When you have added all of the records for this level. If the element is a definition.1 50 . The name of a record reference will be matched to the record identifier in the record. Creating and Editing Flat File Schemas and Dictionaries 4 In the Enter Record Definition Name(s) dialog box. Flat File Schema Developer’s Guide Version 7. these two fields are empty. The name of a record reference does not have to match the name of the record definition in the flat file dictionary. see the table in step 8 on page 55. 5 In the Properties panel of the Flat File Schema Editor. The Dictionary field indicates the flat file dictionary to which the record reference refers. The Referring To field indicates the record definition to which the record reference refers. click and type the record name. To add another record definition at this time. The record(s) is added to the flat file schema structure.3. specify the particular properties for this record. For a list and further explanation of these properties. Important! This name must match the value of its record identifier exactly as it will appear in the flat file. type the name of the record. click Finish. and one for the element definition in the flat file dictionary. The remaining fields must be set in the particular instance of the element in the flat file schema. You cannot edit the dictionary definition detail line. The valid element selections display for the element you have selected. type the Name of the record in the Enter Record Definition Name(s) dialog box. Creating and Editing Flat File Schemas and Dictionaries For element definitions. you see only one line of detail. Flat File Schema Developer’s Guide Version 7. For element references. select the element to which you want to add a child and click . see “Creating a Flat File Dictionary” on page 69. you will see two lines of detail: one for the instance of that element in this flat file schema. You also can right–click an element and select New. In a flat file dictionary you can specify only certain fields for each element. For information about creating flat file dictionaries. 6 To add more elements. If you are adding a record definition.3.1 51 . Note: The name(s) must match the value of the identifier for each record exactly as it will appear in the flat file. For a description of composite extractors. and Mandatory properties in the Enter Composite Definition Name(s) dialog box. click .3. Creating and Editing Flat File Schemas and Dictionaries To add additional record definitions at this level. see “Extractors” on page 61. Property Name Position Description Type the name of the composite. If you are adding a composite definition. Flat File Schema Developer’s Guide Version 7. This pulls the subfield data from the composite. Type the field number in the record that contains the composite you want to extract. specify the Name. Position. the composite will not be extracted.1 52 . If you leave this property empty. Note: The extractor works only if a field and subfield delimiter have been defined for this flat file schema. If is not selected. If it is not selected. Creating and Editing Flat File Schemas and Dictionaries Property Mandatory Description Optional – Select the check box to require that this composite appear in the flat file. Type the first byte to extract from the record. Start. Name Start End Type the name of the field.3. If it is selected and the convertToValues service validate variable is set to true. see “Extractors” on page 61.1 53 . and Mandatory properties in the Enter Field Definition Name(s) dialog box. the composite is not required to appear in the flat file. Optional – Select the check box to require that this field appear in the flat file. Mandatory Flat File Schema Developer’s Guide Version 7. Extractor Type Fixed Position Property Description Counting from zero (0). For more information about field extractors. the extractor returns all bytes from the byte specified in Start to the last byte in the record or composite. Name. Type the first byte that is not included in the extraction. If you are adding a field definition. –1). errors will be generated if the field does not appear in the flat file. If it is selected and the convertToValues service validate variable is set to true. To add additional composite definitions at this level. If you enter a negative number (for example. click . End. errors will be generated if the composite does not appear in the flat file. extracts a fixed number of bytes from a record. specify the Extractor Type. the field is not required to appear in the flat file. click Finish. 7 When you have added all of the elements for this level. To add additional field definitions at this level. This extractor returns the field as a key–value pair. Navigate to the flat file dictionary in which the element is located. This option is available only if you specified a field delimiter when configuring your flat file schema. For more information about field extractors. click Next.3. Name Position Type the name of the field. if you type 1. errors will be generated if the field does not appear in the flat file. select the dictionary. the field is not required to appear in the flat file. Creating and Editing Flat File Schemas and Dictionaries Extractor Type Nth Field Property Description Counting from zero (0). indicates the field that you want to extract from the record. If is not selected. If you are adding an element reference. Flat File Schema Developer’s Guide Version 7. If it is selected and the convertToValues service validate variable is set to true. see “Extractors” on page 61. the second field will be extracted. Type a value to indicate the position of the field that you want to extract from the record. and then click Next. click . Mandatory Optional – Select the check box to require that this field appear in the flat file. The key is the name of the field.1 54 . complete the following steps: After selecting Reference. For example. This value cannot be null and must be an integer greater than or equal to zero (0). Select the element that you want to reference and then click Next. The value is the String value of the field. you can specify the following properties in the Properties panel of the Flat File Schema Editor: Element Record Definition Property Ordered Mandatory Max Repeat Validator Area Position Allow Undef Data Check Fields Alternate Name Description Ordered Mandatory Max Repeat Area Position Allow Undef Data Local Description Mandatory * Extractor Validator * Check Fields * Alternate Name * Description * ID Code * Local Description ** For details..3. page 60 page 60 page 60 page 61 page 57 page 61 page 57 page 58 page 57 page 58 page 60 page 60 page 60 page 57 page 61 page 57 page 59 page 60 page 58 page 61 page 58 page 57 page 58 page 59 page 59 Record Reference Composite Definition * not available for composite definitions in record references ** not available for composite definitions in flat file schemas Composite Reference Mandatory * Extractor Alternate Name * Local Description page 60 page 58 page 57 page 59 * not available for composite references in record references Flat File Schema Developer’s Guide Version 7. see .. Creating and Editing Flat File Schemas and Dictionaries 8 For each of the following element levels and type.1 55 . “Processing Flat Files Overview” of this guide. page 60 page 58 page 61 page 59 page 58 page 57 page 58 page 59 page 59 * only available for field definitions in composite references or record references Field Reference Mandatory * Extractor * Local Description page 60 page 58 page 59 * not available for field definitions in composite references or record references 9 After you have added all of the necessary elements to this flat file schema. 10 To map the output of the convertToValues service to another format. see “Mapping Flat File Data” on page 27 of Chapter 2. see .3. click on the Flat File Structure tab. Creating and Editing Flat File Schemas and Dictionaries Element Field Definition Property Mandatory Extractor Validator Format Service DataType Alternate Name Description ID Code Local Description * For details.. For more information about mapping flat file schemas.. click . You now can use this flat file schema to parse and convert inbound flat files to IS documents (IData objects) and convert outbound documents to flat files. Flat File Schema Developer’s Guide Version 7.1 56 . Use in record definitions and record references in flat file schemas. in alphabetic order. field definitions in composite definitions and record definitions. composite references in record definitions. Creating and Editing Flat File Schemas and Dictionaries Flat File Schema Property Descriptions The flat file schema properties that you can define using the Flat File Schema Editor are described below.3. select the area you want to use for this record.1 57 . If the validate variable of the convertToValues service is set to true. select True to allow undefined data at the record level and not generate errors when undefined data is encountered. see the Areas property on page 42. For more information about the Undefined Data property. from the Area drop–down list. see “Displaying Element Descriptions and Alternate Names in the Flow Editor” on page 67. composite. The default is True. This name will appear as the document name in the document type that is generated by this flat file schema. This name will also appear in the Flow Editor. For details. Use this field to provide a more meaningful name that can be helpful when mapping the record. Use in record descriptions and record references in flat file schemas. For more information. This field is used primarily for EDI document parsing. Select False to not allow undefined data at the record level. the convertToValues service will generate errors when undefined data is encountered. Alternate Name Optional. see page 42. Flat File Schema Developer’s Guide Version 7. Use in: record definitions and composite definitions in flat file schemas. and field definitions in flat file dictionaries. If the schema–level Undefined Data property is set to True. It will also appear as a tool tip comment in the Flow Editor. Property Allow Undef Data Description Optional. For example. If you have created areas for the flat file schema on the Settings tab. record. instead of using the record name ST. Area Optional. An alternate name for the record definition. you could specify the alternate name Transaction Start. composite. record. and field definitions in flat file dictionaries. field definitions and field references in composite definitions or record definitions. DataType Use in: field definitions in composite definitions and record definitions. For more information. For details. It will also appear as a tool tip comment in the Flow Editor. Flat File Schema Developer’s Guide Version 7. Describe the purpose of the record. Select False to allow extra fields at the end of a record or composite. or pulls the subfield data from the composite. Use in: record definitions and composite definitions in flat file schemas.3. The default is False. and then type the field number in the record that contains the composite you want to extract. see “Displaying Element Descriptions and Alternate Names in the Flow Editor” on page 67. For details.1 58 . see “Extractors” on page 61. It will also appear as a tool tip comment in the Flow Editor. record. If you leave this property empty. composite. composite. Note: The extractor works for a field only if field delimiters have been defined for this flat file schema. Use in: record definitions and composite definitions in flat file schemas. see “Displaying Element Descriptions and Alternate Names in the Flow Editor” on page 67. Description Optional. fields in flat file dictionaries. Creating and Editing Flat File Schemas and Dictionaries Property Check Fields Description Optional. or field. Click the Extractor field. This description will appear in the comments section of the document type that is generated for this flat file schema. Extractor Use in: composite definitions in flat file schemas and record references. field definitions in composite definitions and record definitions. composite references in record definitions and record references. The extractor works for a composite only if field delimiters and subfield delimiters have been defined for this flat file schema. Select the appropriate data type. This pulls the field or composite data from the record. the composite will not be extracted. Select True to report as errors more fields at the end of the record or composite than are defined in the flat file schema. and field definitions in flat file dictionaries. fields in flat file dictionaries. To clear the format service. and then click OK. which is provided by your SEF file. to alter the format of the date field. composite. For the service to be visible in the browser. Since the record that is being referenced is stored in a flat file dictionary. For example. see “Displaying Element Descriptions and Alternate Names in the Flow Editor” on page 67. composite references in record definitions or record references. Click the Format Service field to select the service you want to invoke for a particular field when convertToValues or convertToString is called. The IDCode.flatFile:FormatService. Describe the record. composite definitions in record references. field definitions and field references in composite references or record references. Creating and Editing Flat File Schemas and Dictionaries Property Format Service Description Use in: field definitions in composite definitions or record definitions. It will appear in the comments section of the document type that is generated for this flat file schema. Flat File Schema Developer’s Guide Version 7. the template specification for the service on its Input/Output tab must be pub. field definitions in composite definitions or record definitions. For information about format services. Use in: record references in flat file schemas.3. composite and field definitions in flat file dictionaries. Local Description Optional. simply clear the text box. it may be used differently in different flat file schemas. Local descriptions will also appear as a tool tip comment in the Flow Editor. For details. is used by the WmEDI package. or field as it is used in this particular flat file schema. For details. see “Format Services” on page 66. ID Code Use in: composite definitions in flat file schemas. It will also appear as a tool tip comment in the Flow Editor.1 59 . you might invoke a service that changes the format of the field from YYYYMMDD to MMDDYYYY. see “Displaying Element Descriptions and Alternate Names in the Flow Editor” on page 67. Select True to require that this record. If you set this property and the convertToValues service validate variable is set to true. field definitions and field references in composite definitions or record definitions. If you select True and the convertToValues service validate variable is set to true. Use in record definitions and record references in flat file schemas. composite.3.1 60 . errors will be generated if the number of record instances exceeds the maximum repeat value. composite. You can select Unlimited or type any positive integer. or field appear in the flat file. If you select True and the convertToValues service validate variable is set to true. errors will be generated if the records do not appear in this order. For all default records. Select True to require that the child records of this record appear in the flat file in the order that they appear in the flat file schema. The default value is 1. Creating and Editing Flat File Schemas and Dictionaries Property Mandatory Description Optional. Max Repeat Optional. the value is always Unlimited and cannot be changed. and composite definitions in flat file schemas. Use in record definitions and record references in flat file schemas. not composites or fields. or field to appear in the flat file. errors will be generated if the record does not appear in the flat file. Maximum number of times this record can repeat within the flat file. Ordered Optional. Use in: record definitions. composite references in record definitions. Select False to allow the child records to appear in any order in the flat file. This property applies only to records. record references. Flat File Schema Developer’s Guide Version 7. Select False to not require the record. except for default records. This value cannot be null and must be an integer greater than or equal to zero (0). Position indicates the position of the field that you want to extract from the record. the field values will not be returned correctly. To use these extractors for a field in a composite. This extractor returns the field as a key–value pair. Counting from zero (0). The key is the name of the field. field definitions in composite definitions or record definitions. record definitions Click the Validator field. The value is the String value of the field. This extractor is a variation of the Nth Field extractor and is available for backward compatibility for users of the webMethods EDI Module. Software AG recommends that you use this extractor instead of ID node. For example. the field delimiter must be specified.3. if you type 1. ID Node. the second field will be extracted. The value is an IS document (IData object) containing a key–value pair in which the key is always “code. see “Validators” on page 62.” and the value is the String value of the field. The key is the name of the field. or of a subfield within a composite. If these extractors are used without the appropriate delimiter set. Counting from zero (0). or Fixed Position extractors. This value cannot be null and must be an integer greater than or equal to zero (0). You extract fields from a composite using a Nth field extractor. ID Node. Position indicates the position of the field that you want to extract from the record. Important! Validation is disabled by default. or field in the flat file. To enable validation.1 61 . Software AG does not recommend that you use the ID node extractor. composite. you must set the validate variable of the convertToValues service to true. Use in: record definitions and composite definitions in flat file schemas. Creating and Editing Flat File Schemas and Dictionaries Property Position Validator Description Reserved for future use. Nth Field. Extractors Extractors represent the location of a field within a record. This option is available only if you specified a field delimiter when configuring your flat file schema. and then type the desired validation you want to be performed on this record. Optional. while you extract fields from a record using Nth field. For a list of valid validators. Note: To use Nth Field or ID Node extractors for a field or composite in a record. the subfield delimiter must be specified. Flat File Schema Developer’s Guide Version 7. This extractor returns the field as a key–value pair. End Position. Multi‐byte encoded records. Creating and Editing Flat File Schemas and Dictionaries Fixed Position. where n is the number of the field in the composite or record. composites.040. Both of these validators indicate that if Flat File Schema Developer’s Guide Version 7. In these rules. and multi‐byte encoded records. For example. –1). in the following flat file: Record1*FieldA*FieldB*FieldC*FieldD*FieldE. First byte that is not included in the extraction. you might enter the following in the Validator property: D5(010.050) A B C D E Code Field The record definition has five fields defined. the extractor returns all bytes from the byte specified in the Start Position to the last byte in the record or composite. 0n and 0n0 represent the number of the field defined in the record or composite. If you enter a negative number (for example. For example: record = webMethods Start Position = 1 End Position = 7 Extracted bytes = ebMeth Validators Different types of validators are available for records. Fields using either length or code list validators.020) D5(030. the second field B and so on. you might enter the following in the Validator property: C0102C030405 A B C D E Code Field To validate the appropriate fields using the UN/EDIFACT conditional validator. First byte to extract from the record. Conditional Validators Regardless of what type of flat file you are processing. fields.1 62 . the first extracting field A. Counting from zero (0).3. To validate fields using the ANSI X12 conditional validator. extracts a fixed number of bytes from a record. you use the byte count validator. Each with an Nth Field extractor. Start Position. you follow the syntax rules created by the EDI Standards bodies ANSI X12 or UN/EDIFACT to specify conditional validators for a flat file record or composite. You validate: Records and composites using conditional validators. then all (D5) If a specified field is present. Field B is required. If Field C is present.040.050) Flat File Schema Developer’s Guide Version 7. if you switched the extractors for the first and second field such that the first field extracted the value Field B and the second field extracts the value Field A. ANSI X12 Example: C030405 UN/EDIFACT Example: D5(030. If you switched the position of these fields in the record.040. ANSI X12 Example: R030405 UN/EDIFACT Example: D3(030. if Field D and Field E are present. The conditional validator refers to the location of the field in the definition. the conditional validator would indicate that if Field B is present Field A is required. only one of the specified fields can be present. position 1 This now indicates that if Field B is present Field A also must be present.1 63 . the first specified field need not be present. However. Example: Record1 – conditional validator C0102 FieldB – Nth field extractor. position 1 FieldB – Nth field extractor. all of the fields specified in a dependent set of fields also must be present. ANSI X12 Rule Name (and Code) Required (R) UN/EDIFACT Rule Name (and Code) One or more (D3) Definition At least one of the specified fields must be present. Field D and Field E are required. Creating and Editing Flat File Schemas and Dictionaries Field A is present. position 2 FieldA – Nth field extractor. you would get the following. For example.050) Conditional (C) If first. Example: Record1 – conditional validator C0102 Field A – Nth field extractor. Field C need not be present. ANSI X12 Example: E030405 UN/EDIFACT Example: D4(030.050) Exclusion (E) One or none (D4) At most. position 2 This indicates that if FieldA is present Field B also must be present. If a dependent field is present.3. not the location of the data in the flat file.040. If a dependent field is present. all others cannot be included. UN/EDIFACT Example: D7(030. the first specified field need not be present.040. Minimum length. Code List Validator In the Conditions box. UN/EDIFACT Example: D1(030. The code list is a comma– separated list of the allowed values for this field. ANSI X12 Example: P030405 UN/EDIFACT Example: D2(010. type the appropriate code list conditions. you specify the maximum and minimum number of characters this field can contain to be considered valid. then at least one (D6) Definition If a specified field is present. –1). a maximum length error will never be generated for this field. then none (D7) Exactly one field may be present. If the field contains more characters than the number entered. If you enter a negative number (for example.050) N/A Field Validators You validate fields using either a length validator or a code list validator. Maximum number of characters that this field can contain to be considered valid. Note: This validator validates only in ascending order and according to the ASCII values. Minimum number of characters that this field can contain to be considered valid.050) If the first field is present. at least one of the fields specified in a dependent set of fields also must be present. Maximum length. an error will be generated. If the value of the field is not contained in the code list.020) N/A One and only one (D1) If first.1 64 . Length Validator For a length validator.050) Paired (P) All or none (D2) All of the specified fields must be present or absent.040. Flat File Schema Developer’s Guide Version 7. ANSI X12 Example: L030405 UN/EDIFACT Example: D6(030.3. Creating and Editing Flat File Schemas and Dictionaries ANSI X12 Rule Name (and Code) List Conditional (L) UN/EDIFACT Rule Name (and Code) If first. an error will be generated.040. You can enter zero (0). errors will be generated. If the field contains fewer characters than the number entered. regardless of its value. Values are considered to be valid for a given range if all of the following conditions are true: The value is the same length as the start and end strings of the range. The extra comma in 1. If the field contains fewer bytes than the number entered. The value is lexically greater than or equal to the start string and lexically less than or equal to the value of the end string. and DEF2. The range is specified as start string:end string. if you enter ABC. which can occur within any type of code list. Minimum number of bytes that this field can contain to be considered valid. and the second character of each string comes from the set 0–9. Creating and Editing Flat File Schemas and Dictionaries You can specify three different types of code lists: Simple Code List. the allowed values of the field are ABC1. the allowed values of the field are: ABC1. ABC. Each set of code lists must have the same number of bytes. separated by a pipe (|). Byte Count Validator You use the byte count validator for multi‐byte encoded records. If the field contains more bytes than the number entered.DEF|1. an error will be generated. a maximum length error will never be generated for this field. Range List. Partition List.1 65 . DEF1. A comma separated list of valid codes. A partition joins together multiple code lists within one field. The code list validator allows for the right hand side of the partition to be optional. You can enter zero (0). A2:2B is not valid because the first character of the start string does not come from the same character set as the first character of the end string. For example.2. and DEF. For example. DEF2. –1).2 indicates that the values 1 and 2 are optional. Minimum length. You specify the maximum and minimum number of bytes this field can contain to be considered valid. Maximum length. For example A0:Z9 is valid. ABC2. A–Z or 0–9).2. The character value in the same position in the start and end string comes from the same character set (a–z. an error will be generated. if you enter ABC. A range list. ABC2. because the first character of each string comes from the set A–Z.DEF|1. validates that a string value is between a given start string and end string. Maximum number of bytes that this field can contain to be considered valid. Flat File Schema Developer’s Guide Version 7. If you enter a negative number (for example.. regardless of its value.3. DEF1.. 1 66 . you will receive an error message in the errorMessage output variable of the format service indicating why this field could not be validated.flatFile:FormatService” on page 88 in Chapter 5. see “pub. when using the convertToValues service to convert a date field in a flat file into an IS document (IData object). Flat File Schema Developer’s Guide Version 7. Creating and Editing Flat File Schemas and Dictionaries Format Services You can use the Format Service property on the Flat File Structure tab of the Flat File Schema Editor to specify the service you want to invoke for a particular field when convertToValues or convertToString is called. you might invoke a service that changes the format of the field from YYYYMMDD to MMDDYYYY. A format service formats the string and optionally ensures that the value of the string meets the restrictions specified in the format service. you can specify that a particular format service be invoked for that field during parsing. you simply clear the text box and save the flat file schema or dictionary. Creating Format Services To create a format service for use with a field in a flat file schema or dictionary. For more information. To alter the format of the date field. “WmFlatFile Built–in Services Reference”. the service must implement the pub.cnf and set the enableFormatting variable to false. Working with Format Error Messages If the validate input variable of your format service was set to true to validate the format and value of a field. For example. a value is not returned in an IS document (IData object) for convertToValues or is not present in the input data for convertToString) the format service assigned to that field will not be executed. To disable all format services within the WmFlatFile package regardless of what is specified in each field definition. and that field does not meet the criteria specified in the service. For more detailed information about format services.3.flatFile:FormatService service as its template specification for the format service (located on its Input/Output tab). open IntegrationServer_directory\packages\WmFlatFile\config\ff. Disabling Format Services To disable the format service for a particular field. you can use the built–in format services provided in the WmEDI package to format fields. see the webMethods EDI Module User’s Guide and the webMethods EDI Module Built‐in Services Reference. Note: If you are using the webMethods EDI Module. Important! If a particular field does not have a value (that is. If you delete a format service. Enable the Show Variable’s Comment option in the webMethods Developer’s Flow Editor as follows: a b c Click File New in the menu bar.3. Displaying Element Descriptions and Alternate Names in the Flow Editor The webMethods Developer Flow Editor will display the values of several properties that you specified for the elements of your schema. the Integration Server’s dependency manager will ask whether it should update all the flat file schemas and flat file dictionaries that use that format service with the new location or name of the format service. The Flow Editor will display the following properties: Element Record definition Record reference Composite definition Property Description Alternate Name Local Description Description Alternate Name ID Code Alternate Name Local Description Description Alternate Name IDCode DataType Local Description Composite reference Field definition Field reference To display properties in the Flow Editor 1 2 Define values for the properties as described in step 8 of “Step 3: Define the Structure of the Flat File Schema” on page 48. They are visible as tool tips when you move the cursor over the elements. the dependency manager will list all schemas and dictionaries that will be impacted by the deletion. and prompts you to confirm the deletion.1 67 . Flat File Schema Developer’s Guide Version 7. Creating and Editing Flat File Schemas and Dictionaries Managing Dictionary Dependencies on Format Services If you move or rename a format service. Click Show Variable’s Comment. Use these optional properties to provide helpful comments and more meaningful names when mapping elements in flow services. Select Flow Editor in the navigation area. To test a flat file schema 1 2 In webMethods Developer Navigation panel. click OK. you may find that it is necessary to edit your flat file schema. see Chapter 5. 4 5 6 After you have reviewed the results. For information about validation errors. Flat File Schema Developer’s Guide Version 7. Any errors found when parsing the flat file appear in the Errors section of the Flat File Schema Editor. To run the test. testing a flat file schema always performs validation regardless of you settings. “Validation Errors” of this guide. Note: Although validation is turned off by default. 3 To select a flat file with which to test the flat file schema. and then click Open. see Appendix A. Note: If you make a change to the test file you are parsing. For more information about this service. Click . The test response you receive contains the same information that would result from processing and validating a flat file. click . double–click the flat file schema that you want to test. Creating and Editing Flat File Schemas and Dictionaries Step 4: Test the Flat File Schema Testing a flat file schema involves viewing a flat file schema in a readable structure. you must set the validate variable of the convertToValues service to true. The name of your test flat file appears in the top portion of the Test tab.3. From the Encoding drop–down list. navigate to and select the test flat file. The Select file and encoding dialog box appears. select the encoding for the flat file you are testing. “WmFlatFile Built–in Services Reference” of this guide. The parsed and converted IS documents appear in the Results panel. you must reload the file before running a test.1 68 . To enable validation in the processing of an actual flat file schema. This enables you to locate errors in your flat file schema that are keeping your flat file documents from being parsed correctly. composites. and fields that can be used across multiple flat file schemas. you edit the element and its child elements just as you would elements in a flat file schema. except that you cannot add a record to a record. Like a flat file schema. a flat file dictionary contains definitions of records. Creating and Editing Flat File Schemas and Dictionaries Creating a Flat File Dictionary You can create a flat file dictionary for use with flat file schemas.3.1 69 . Reusing these definitions reduces the amount of memory consumed by a flat file schema. Flat File Dictionary After you have created elements. Flat File Schema Developer’s Guide Version 7. “Concepts” of this guide. Flat file dictionaries can also contain references to composite and field definitions in this dictionary and/or in other dictionaries. see “When Should I Create a Flat File Dictionary?” on page 19 in Chapter 1. For more information about the circumstances for which you might want to create and use a flat file dictionary. The flat file dictionary you created is automatically selected. select Flat File Dictionary. and the Flat File Schema Editor displays in the right pane of the Developer. or Field Definition) and click an element and select New.3. You now can use the Flat File Schema Editor to configure the flat file dictionary. .1 70 . click File New in the menu bar. Type the name of the new flat file dictionary. Creating and Editing Flat File Schemas and Dictionaries To create a flat file dictionary 1 In webMethods Developer. and then click Next. select the element type to which you want to add a child (Record Definition. 4 To add elements. You also can right–click Flat File Schema Developer’s Guide Version 7. select its location (a folder in a WmFlatFile–dependent package). and then click Finish. 2 3 In the New dialog box. Composite Definition. see “Flat File Schema Property Descriptions” on page 57.. (For a list of these properties. Composite Definition Validator Check Fields Alternate Name Description ID Code page 61 page 58 page 57 page 58 page 59 Define all other composite definition properties in the composite reference instance in the flat file schema. To add additional element definitions at this level. Creating and Editing Flat File Schemas and Dictionaries The valid element selections display for the element you have selected. see .. page 61 page 58 page 57 page 58 Define all other record definition properties in the record reference instance in the flat file schema. For each of the following element levels.1 71 . Flat File Schema Developer’s Guide Version 7.) You define child field definitions and references within a composite the same way you define the elements in a flat file schema.3. see “Flat File Schema Property Descriptions” on page 57. click 5 . you can specify the following properties in the Properties panel of the Flat File Schema Editor: Element Record Definition Property Validator Check Fields Alternate Name Description For details. You cannot define child elements for a field definition. Field Definition Validator Format Service DataType Alternate Name Description ID Code page 61 page 59 page 58 page 57 page 58 page 59 Define all other field definition properties in the field reference instance in the flat file schema.) You define child composite and field definitions and references within a record the same way you define them in a flat file schema. except that you cannot add a record to a record. you edit the element and its child elements just as you would elements in a flat file schema. (For a list of these properties. After you have created elements. Re–structure the elements. the dependency manager will list all flat file schemas and dictionaries that will be impacted by the deletion. and click to move the element up or down in the flat file schema structure. Creating and Editing Flat File Schemas and Dictionaries 6 After you have added all of the elements to this flat file dictionary.1 72 . To rearrange the structure of your flat file schema. Rename existing elements. it does not identify the names of the records. To do so. that is your responsibility. and click to delete. To do so. to save Note: Elements added the dictionary cannot be referenced until the dictionary has been saved. see “Creating a Flat File Schema” on page 36. You now can create flat file schemas based on this flat file dictionary. and then select Rename. or composites that reference the dictionary. the Integration Server’s dependency manager will ask whether it should update all the flat file schemas and dictionaries that use this dictionary with the new location or name of the dictionary. make the necessary changes on the Flat File Structure tab and then save the flat file schema or dictionary. Editing a Flat File Schema or Dictionary Important! To edit a flat file schema or dictionary. Flat File Schema Developer’s Guide Version 7. right–click the element. For flat file schemas and dictionaries. Managing Flat File Dictionary Dependencies If you move or rename a dictionary. use the buttons at the top of the Flat File Structure tab. If you delete a dictionary.3. Select the element you want to move. Button Description Select the element you want to delete. Select the element you want to move. fields. However. For information about access control lists (ACLs) see “Setting Access Permissions” on page 73. you must have the proper access permissions to do so and have locked the flat file schema. you can do the following: Edit any element properties. For a list of these settings and properties. and prompts you to confirm the deletion. click the dictionary. and click to move the element left or right in the flat file schema structure. select the ACL level to which you want to grant write access. Setting Access Permissions Administrators of the Integration Server can set access control list (ACL) permissions to control user access and editing privileges for each flat file schema or flat file dictionary. under Permissions. This enables the ACL you select to view this flat file schema or dictionary. double–click the flat file schema for which you want to set permissions. Creating and Editing Flat File Schemas and Dictionaries The dependency manager also manages dictionary dependencies on format services in a similar way. Click to save the flat file schema permissions. see “Managing Dictionary Dependencies on Format Services” on page 67.3. This enables the ACL you select to view and edit this flat file schema or dictionary. select the ACL level to which you want to grant read access.1 73 . from the List ACL drop–down box. 4 Flat File Schema Developer’s Guide Version 7. In the Properties panel. To set access privileges for a flat file schema or dictionary 1 2 From the webMethods Developer Navigation Panel. 3 From the Write ACL drop–down box. true: Attempt to match the order of the fields in composites and records to the order of the fields in composites and records in the flat file schema.3. false: Do not enable the use of alternate code sets. You implement these flags in the configuration file: IntegrationServer_directory\packages\WmFlatFile\config\ff.1 74 . Creating and Editing Flat File Schemas and Dictionaries Customizing the Flat File Configuration Settings The WmFlatFile package provides the following flags you can use to customize some aspects of the package’s default behavior.cnf Flag alwaysSortFields Value Determines whether the pub. true (the default): Enable the use of alternate code sets. Example: useAlternateCodeSets=true Flat File Schema Developer’s Guide Version 7. Example: alwaysSortFields=true useAlternateCodeSets Determines whether to enable the use of alternate code sets. false (the default): Assume that the fields in composites and records are in the same order as the flat file schema.flatFile:convertToString service checks the order of the fields in composites and records that it receives as input (in ffValues) against the flat file schema that is specified in the ffSchema input parameter. the value reported will be the non‐readable carriage return code (decimal 13 or hexidecimal OD). such as \r (carriage return). false: The parser reports the delimiters as the actual delimiter character.1 75 . This impacts how you can use the delimiter information in flow mapping. the resulting value is abc\ndef If useReadableDelimiterReporting=false.g. set this variable to false. Note: If you use the webMethods EDI Module. the resulting value is abc def Flat File Schema Developer’s Guide Version 7. If you use the delimiters directly in flows with variable substitution. non‐printable characters will not be substituted correctly when useReadableDelimiterReporting=true. \n (line feed). This variable does not impact human‐readable delimiters such as | or *. Creating and Editing Flat File Schemas and Dictionaries Flag useReadableDelimiter Reporting Value Controls how the Delimiter record parser parses non‐readable delimiters. or \t (tab). if the delimiter is a carriage return. when the output of the convertToValues service shows that the record delimiter is \n and a user flow has an input set to the following: abc%@delimiters\record%def the resulting value will be as follows: If useReadableDelimiterReporting=true. true (the default): The parser reports the delimiters as human‐readable characters.3. e. the carriage return character is represented as \r. For example.. For example. 3.b2b. spacePad is set to right. fixed length fields are left justified. If spacePadJustifies=true and: spacePad is set to left. fixed length fields are right justified.b2b. fixed length fields are right justified.flatFile:convertToString and wm. If spacePadJustifies=false (the default) and: spacePad is set to left. Creating and Editing Flat File Schemas and Dictionaries Flag spacePadJustifies Value Controls how the input parameter spacePad justifies fixed length fields handled by the services pub. and spacePad is set to left or right. spacePadJustifies has no effect when spacePad is set to none.edi:convertToString when the parameter spacePad is set to left or right. Example: spacePadJustifies=false dontTrimControl Characters Determines how whitespace and control characters are handled by the service wm. Example: dontTrimControlCharacters=true Flat File Schema Developer’s Guide Version 7.1 76 . and spacePad is set to left or right. If dontTrimControlCharacters=true. If dontTrimControlCharacters=false. control characters are treated as whitespace and truncated. fixed length fields are left justified. the service does not truncate control characters from delimited fields.edi:convertToString. spacePad is set to right. . . . . . . . .Chapter 4. . . . . . . . . . . . . . . . . 78 Flat File Content Handler and Content Type . . . . . . . . . . . . . . . . . . . . . . . 81 Submitting a Flat File to Integration Server via File Polling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Sending and Receiving Flat Files Overview . . . . . . . . . . . . . . . . . . . . . . 84 Flat File Schema Developer’s Guide Version 7. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79 Submitting a Flat File to Integration Server via HTTP . . . . . . . . . . . . . . . . . . .1 77 . . . . . . . . . . 79 Submitting a Flat File to Integration Server in a String Variable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 Submitting a Flat File to Integration Server via an E–mail Message . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80 Submitting a Flat File to Integration Server via FTP . . . . . . 78 Choosing the Service to Receive the Flat File from the Content Handler . . . For more information about File Polling. the InputStream is read and the results are returned to the invoker of the service. Note: If you use Trading Networks. These services are described in “Choosing the Service to Receive the Flat File from the Content Handler” in this chapter. which the target service can convert into an IData object using pub. Send a flat file to a service as an e–mail message attachment.1 78 .” This content handler passes the contents of the flat file to the service specified in the submit method in an InputStream named ffdata. The WmFlatFile package provides services that can be called within customized flow services or the File Polling processing service to initially accept and consume inbound flat files. for example. For more information about how Trading Networks processes flat files.flatFile:convertToValues. see the “Configuring Ports” section of the “Configuring the Server” chapter in the webMethods Integration Server Administrator’s Guide. HTTP. Submit a flat file to a service in a String variable (of any name). see sections about flat file TN document types in the webMethods Trading Networks Concepts Guide and webMethods Trading Networks Administrator’s Guide Flat File Content Handler and Content Type You submit a flat file to a flow service using one of the methods discussed in this chapter. Flat File Schema Developer’s Guide Version 7. Sending and Receiving Flat Files Overview The webMethods Integration Server provides the following automated mechanisms for sending and receiving any type of flat file. see “Submitting a Flat File to Integration Server via File Polling” on page 84. etc. you can send flat files directly to Trading Networks. The WmFlatFile package registers a content handler for the content type “application/x– wmflatfile. Submit a flat file to a service via File Polling.4. FTP. which is not included in this guide. Post a flat file to a service via HTTP. If an InputStream or ByteArray named ffreturn is present when the service completes execution. FTP a flat file to a service. For general steps to configure ports. wm.1 79 . public class ArbitraryFlatFileClient . This approach does not use the flat file content handler. IDataCursor inputsCursor = inputs.wm.*. you should code the target service to execute pub.insertAfter(“orders”. Sending and Receiving Flat Files Choosing the Service to Receive the Flat File from the Content Handler Those methods that use the flat file content handler must do the following: Accept an InputStream object called ffdata.insertAfter(“authCode”. . inputsCursor. the client 1) loads the flat file into a String.create().4. import com. Flat File Schema Developer’s Guide Version 7.app.data.io. The invoked service then processes the input data and can place parameters in the pipeline that will be returned to the java client as determined by the specific scenario. “Processing Flat Files Overview” of this guide. import java. 2) puts the String into the element orders in an IS document (IData object) named “inputs..b2b. When you use this approach. inputsCursor. see Chapter 5. Instead. The WmFlatFile package provides the pub.getcursor(). In this example. import com. inputsCursor. //––Load FF into orders string String orders = YourLoadFlatFileMethod(orderFile). the invoked service must expect the contents of the flat file to be in a specific pipeline variable.wm.” and 3) invokes purch:postOrder on the server at localhost:5555. The java client must place the source file in the pipeline as a String.*. orders). //––Put input values into IData object IData inputs = IDataFactory. authCode).util.last().*.*. the flat file) to an IS document (IData object). For more information about using convertToValues. Return data in an InputStream or a ByteArray called ffreturn. “WmFlatFile Built–in Services Reference” of this guide. Submitting a Flat File to Integration Server in a String Variable One way to submit a flat file to the Integration Server is to pass the entire document to a service in a String variable. so the restrictions outlined in the previous section do not apply. The following code fragment illustrates how a Java client might submit a flat file to the purch:postOrder service on the Integration Server. import com.e.client.flatFile:convertToValues to convert the String variable (i. Details about using this service to process inbound documents are provided in “Processing Inbound Flat Files” on page 25 of Chapter 2.flatFile:convertToValues service to be used within flow services to initially accept inbound flat files. if (inputsCursor.” When the Integration Server receives an HTTP POST request where Content–Type is application/x–wmflatfile. –AND– Set the value of the Content–Type request–header field to “application/x–wmflatfile. “Processing Flat Files Overview” of this guide. you must specify certain information. pub. Address the request to the URL of an service (for example. it passes the body of the request as an InputStream to the service specified in the request’s URL. null).” Contain flat file data in the body of the message. Flat File Schema Developer’s Guide Version 7.. if you want to post a flat file to a service through HTTP. The data must be the only text that appears in the body of the request.connect(“localhost:5555”. “null”.1 80 . “postOrder”. they are not suitable clients for this type of submission. As discussed in Chapter 2. Building a Client that Posts a Flat File to a Service Regardless of which client you use. you must have a client that can do the following: Send a string of data (a flat file) to the Integration Server using the HTTP POST method. IData outputs = c.disconnect().invoke(“purch”. http://rubicon:5555/invoke/purch/postOrder). c.process response } The Integration Server invokes postOrder to pass the flat file to convertToValues. Submitting a Flat File to Integration Server via HTTP A client can post a flat file to a service via HTTP. To build a client 1 2 3 4 Submit a POST request to the Integration Server. To use this approach. Because most browsers do not allow you to modify the Content–Type header field. Set the Content–Type header field to “application/x–wmflatfile.client:http. Clients that you might use to submit a flat file in this manner include PERL scripts (which allow you to build and issue HTTP requests) or the Integration Server service.first(“response”)) { //.. Sending and Receiving Flat Files //––Submit request to server c. inputs). Do not assign it to a name=value pair. This will produce an “orders” string that can be mapped to the ffdata input variable in the convertToValues service. this service will produce an IS document (IData object).4. where hostname is the name of the machine running the Integration Server. folder. By default the FTP port is assigned to port “8021.client:http to POST a flat file to a service. When the Integration Server receives a flat file on the FTP listening port. To submit a flat file to the Integration Server via FTP. port is the port on which the Integration Server is running.” However.1 81 . url To.bytes You also will set any optional HTTP variables. Set this Variable. such as authorization information.. this assignment is configurable.subfolder is the path to the service folder names.string –OR– data. Submitting a Flat File to Integration Server via FTP You can FTP a flat file to the Integration Server’s FTP listening port. so you should check with your Integration Server administrator to see which port is used for FTP communications on your Integration Server.. This is the URL of the service that you want to invoke. data.. The format for specifying the URL is http://hostname:port/invoke/ folder. and service name is the name of the service to invoke.subfolder/service name. it passes it as an InputStream to the service in the directory to which the file was FTP’d. Flat File Schema Developer’s Guide Version 7. The invoked service will have an InputStream ffdata object in the pipeline that contains the flat file data.Content– Type “post” Name: Content–type Value: The specific content type for the document (application/ x–wmflatfile) This is the flat file that you want to post. that are required by your application.4.. the service to which you want to pass the document must take an InputStream as input for the ffdata variable. webMethods services can be invoked via a URL. Sending and Receiving Flat Files The following example describes the values that you set if you use pub.” Example: http://rubicon:5555/invoke/MyFFProcessing/ ProcessFlatFile method headers. The following value would invoke the “ProcessFlatFile” flow service located in the “MyFFProcessing” package on the “rubicon” server with port number “5555. txt destinationflatfile. Therefore. not IntegrationServer_directory\ns\Purchasing\ServiceName.txt Partner1PO. The file you send and the output file it produces (see below) are written to a virtual directory system maintained in your Integration Server session. 3 Copy the flat file to this directory using the following command: put sourceflatfile. Each folder in the Developer is treated as a directory when FTPing to the Integration Server. For example.txt. serverhost serverport username To set.client folder contains built–in services that you can use to FTP a file from the Integration Server. Point to the directory that contains the service to which you want to pass the flat file. For example.purchaseRequests:rfq service. to put a document called PurchaseOrder. Sending and Receiving Flat Files If you want to submit a flat file to a service through FTP. you would use the following FTP command: Example: put PurchaseOrder. destinationflatfile.txt. Set this variable. not the root directory of the target machine.4.txt on the Integration Server as Partner1PO.. the directory name would be \ns\purchasing\purchaseRequests\rfq.txt is the name of the destination file.client:ftp service. Flat File Schema Developer’s Guide Version 7. This is the valid user name on the target machine..txt is the name of source file that you want to pass to the Integration Server. FTPing a File From a webMethods Integration Server The pub.txt. This is the port on the Integration Server that is listening for FTP traffic. This is the name of the machine running the Integration Server. the application must specify certain information.file content type Where sourceflatfile. and application:x–wmflatfile indicates the content type of the file submitted. To submit a flat file via FTP 1 2 Initiate an FTP session on the Integration Server’s FTP listening port. you must set the variables listed in the following table. To use the pub. if you want to FTP a file to a service in the Purchasing folder.application:x–wmflatfile Note that the file you FTP to the Integration Server is never actually written to the server’s file system. Example: cd \ns\Purchasing\SubmitOrder Important! Note that the root directory for this operation is your Integration Server’s namespace directory (ns). for the purchasing..1 82 . you use \ns\Purchasing\ServiceName as the path to that service.. For example. Important! When you end the FTP session..txt. “put” If you are sending to the Integration Server.txt. the Integration Server automatically deletes the original file and its results from your session. For example. localfile remotefile For more information about these services.1 83 .out” is the name of the flat file initially FTP’d to the service. If you are sending to the Integration Server. Getting Results from an FTP’d Document The results from a service executed by an FTP request are written to the same virtual directory to which the flat file was initially FTP’d.. Flat File Schema Developer’s Guide Version 7. You retrieve this document using the FTP “get” command. destinationflatfile. This file contains the value of the output variable ffreturn of the invoked service.txt” on the Integration Server..txt. If sending to another type of server.out “PurchaseOrder. \ns\Purchasing\SubmitOrder. this is the working directory of the FTP server. The name of the output file to which results are written is sourcefile. Sending and Receiving Flat Files Set this variable. if you put a document called “PurchaseOrder. This is the name of the remote file in which you want to save the data you sending..out. For example.4.application:x–wmflatfile. For example. you would use the following FTP command to get its results: Example: get PurchaseOrder. This is the name of the source file. this is the local path to the service that should be invoked after receiving the flat file.txt.txt. password command dirpath To set. It is a good practice to make each file name that you FTP to the Integration Server unique (perhaps by attaching a timestamp to the name) so that you do not inadvertently overwrite other FTP’d documents or their results during an FTP session. This is the valid password for the username in username. destinationflatfile. the file name should be followed by the content–type. see the webMethods Integration Server Built‐In Services Reference. see the “Configuring Ports” section of the “Configuring the Server” chapter in the webMethods Integration Server Administrator’s Guide. To do this. To submit a flat file via email 1 2 3 Put the flat file in an e–mail attachment. (Consult your Integration Server administrator to see whether an email port has been set up on your Integration Server.” Specify the name of the service that will process the file in the e–mail’s subject line. the Integration Server executes the service that you specified as the Processing Service. the document will be processed by the global service if one is defined or. it passes the document as an InputStream to the service configured in the pipeline variable ffdata. if not. When a file with this content type is posted to the directory on the Integration Server that you are monitoring for flat files (Monitoring Directory). Because the content type is “application/x–wmflatfile”. Sending and Receiving Flat Files Submitting a Flat File to Integration Server via File Polling You can send a flat file to the Integration Server via a File Polling processing service. when the Integration Server receives the flat file in the appropriately configured Monitoring Directory. Requirements for Submitting a Flat File Document via an E-mail Message To submit a flat file to the Integration Server via an e–mail message. your Integration Server must be configured with an e–mail port that monitors the mailbox to which the flat file will be sent. the Integration Server automatically retrieves the message and passes that document as an InputStream to the service specified on the e–mail’s subject line (or. the e–mail port’s default service).) When a flat file arrives in the e–mail port’s mailbox.4. by the default service assigned to the e–mail port (if one has Flat File Schema Developer’s Guide Version 7. your client program must specify certain information. For general steps to configure the File Polling listener port. Submitting a Flat File to Integration Server via an E–mail Message You can send a flat file document as an attachment to an e–mail message to an e–mail mailbox and have the Integration Server automatically retrieve the e–mail message and process the flat file it contains. Set the e–mail’s Content–Type header to “application/x–wmflatfile.1 84 . if a service is not specified on the subject line. To poll specifically for flat files. If you leave the subject line empty. you must specify the Default Content Type as “application/x– wmflatfile”. and then sent as an attachment of an e–mail message to the sender of the original message. For more information about specifying the port’s default service. you must explicitly configure it to do so. Flat File Schema Developer’s Guide Version 7. A String specifying the fully qualified name of the service to which the Integration Server will pass the attached document. This file contains the value of the output variable ffreturn of the invoked service. the results from a service invoked through the port are written to sourcefile. the e–mail port does not return any results from requests that it receives. filename A String containing the e–mail address to which the results of the service will be sent. the e–mail port invokes its default service (if one has been assigned to it). Getting Results from an Emailed Document If your e–mail port has been configured to return results. ffreturn can be either an InputStream or a byte array.. For more information about configuring the e–mail port to return results. Example: orders:ProcessPO If you do not specify subject.out. see the webMethods Integration Server Administrator’s Guide.. to subject To. see your webMethods Integration Server Administrator’s Guide. contenttype attachments. The specific content type for the document (“application/x– wmflatfile”).. The service that will process the flat file must take an InputStream as input in the ffdata variable.. Sending and Receiving Flat Files been assigned). see the webMethods Integration Server Built‐In Services Reference. A string specifying the fully qualified name of the file containing the flat file.1 85 .client:smtp to email a flat file to a service. from attachments. Set this Variable. If you want the port to return results.4. For more information about using this service.txt. A String specifying the e–mail address monitored by the Integration Server’s e–mail port. The following example describes the values that you would set if you used pub. Important! By default. 1 86 . Sending and Receiving Flat Files Flat File Schema Developer’s Guide Version 7.4. Chapter 5. WmFlatFile Built–in Services Reference Flat File Conversion Services . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88 Flat File Generation Services . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98 Flat File Generation IS Document Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107 Flat File Generation Sample Services . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111 Flat File Schema Developer’s Guide Version 7.1 87 5. WmFlatFile Built–in Services Reference Flat File Conversion Services Use the services in the pub.flatFile folder when converting between Flat File documents and IS documents (IData objects). pub.flatFile:FormatService Use this specification when you create format services for fields in a flat file schema or dictionary. The format service is invoked for a field when the pub.flatFile:convertToValues and pub.flatFile:convertToString services are invoked. You create a format service to format the field String and ensure that the value of the String meets the format restrictions of the format service. When creating a particular format service for use with the Format Service property in a flat file schema or dictionary, the service you select must implement the pub.flatFile:FormatService specification (located on its Input/Output tab). Important! If a particular field does not have a value (that is, a value is not returned in the IS document (IData object) for the pub.flatFile:convertToValues service or is not present in the input data for the pub.flatFile:convertToValues service) the format service assigned to that field will not be executed. Input Variables value direction String The field value to format. String Indicates the type of formatting to be applied to the field. Specify one of the following: Value convertToString Description This field is in an outbound document and needs its internal format converted to its external format. This field is in an inbound document and needs its external format converted to its internal format. convertToValues validate String The value of the input parameter validate from the pub.flatFile:convertToValues service. true The value of the convertToValues validate parameter is true (validate). The value of the convertToValues validate parameter is false (do not validate). This value is always false when the value of the direction parameter is convertToString. false minLength String Enables you to validate the minimum length of a field. If the field is extracted via a Fixed Position Extractor, this is the number of bytes that are extracted. If the field is not extracted via the Fixed Position Extractor and a Length Validator is associated with this field, this is the minimum length that will be considered valid. Otherwise, this parameter will not be present in the pipeline. Flat File Schema Developer’s Guide Version 7.1 88 5. WmFlatFile Built–in Services Reference maxLength String Enables you to validate the maximum length of a field. If the field is extracted via a Fixed Position Extractor, this is the number of bytes that are extracted. If the field is not extracted via the Fixed Position Extractor and a Length Validator is associated with this field, this is the maximum length that will be considered valid. If the maximum length is unlimited (–1) or there is no Length Validator, this parameter will not be present in the pipeline. Document Information that can be used by individual formatting services. This information can be obtained from one of 3 locations: convertToString – You can specify FormatInfo in addition to the delimiter information for a call to this service. convertToValues – If delimiter information is explicitly passed into the convertToValues service, FormatInfo can be specified. From the UNEDIFACT UNA segment – The EDI document type automatically extracts the decimal separator from the UNA segment. The only format services that use this feature are the decimal formatting services (for implied decimal and decimal formats). The FormatInfo IS document should contain a string called DecimalCharacter. If the decimal character is ‘,’ the number would be formatted as 100,10 (European format) instead of 100.10, as is common in the US. Note: Changes to the data in this object will be reflected in all other format services that are invoked during execution of convertToString and convertToValues. FormatInfo Output Variables formattedValue meetsFormat String The field value with appropriate formatting applied. String Whether the value could be formatted properly. Value true false Description Indicates that the value could be properly formatted. Indicates that the value could not be properly formatted. errorMessage valueToValidate String If meetsFormat is false, this parameter provides a text message describing the formatting error. String The value that will be used by the validator for this field. If this value is not present, the value passed in the input variable value will be validated. This field is used only for situations in which the input variable validate is set to true. Flat File Schema Developer’s Guide Version 7.1 89 This is the default. Value left Meaning Left justify the records (add blank spaces to the right of the records) before the records are written to the output. Value false true Important! If you are upgrading from webMethods Integration Server version 4. Flat File Schema Developer’s Guide Version 7. WmFlatFile Built–in Services Reference pub. Note: This service does not validate the document.5. to enable left or right justification you must add the following line to the IntegrationServer_directory\packages\WmFlatFile\config\ff file: spacePadJustifies=false Then. By default. Create errors in output. Meaning Do not create errors in output. For details. String (optional) How to position the records in the flat file. Input Variables ffValues ffSchema spacePad Document The IData object representing the flat file. see “Customizing the Flat File Configuration Settings” on page 74. No spaces added. but you can set a flag to optionally return the document as a byte array instead. right none signalError String Whether to create errors in the output.flatFile:convertToString Converts an IS document (IData object) to a flat file document based on the flat file schema that you specify. String Namespace name of the flat file schema to use to convert the given IS document to a string. this service returns the document as a string.6. Right justify the records (add blank spaces to the left of the records) before the records are written to the output.1 90 . reload the WmFlatFile package so that this configuration setting will take effect. String Character to use to ignore a record. field. 0X09. 013) Unicode characters (for example. field.1 91 . and the quoted release character is “. Value true Description Trailing empty fields will be removed from the output. the string appears as “a*b”.5. If a release character occurs in a field or subfield before the delimiter. A field separator remains to denote an empty field. WmFlatFile Built–in Services Reference noEmptyTrailing Fields String Whether trailing empty fields are to be removed from the output. String Character to use to separate fields. false delimiters Document (optional) The separator characters used to construct the output string. String Character to use to ignore a record. or subfield delimiter in a field. For example. you can specify: One character or character representation (for example. For example. This is the default. field subfield release quotedRelease Flat File Schema Developer’s Guide Version 7. if it is set to true. *. If a quoted release character occurs in a field or subfield before the delimiter. To specify a delimiter. it will be prefixed with release before being written to the output string. it will be prefixed with quotedrelease before being written to the output string. \n for line terminator. For example. or subfield delimiter in a field. 0X13) Octal value with prefix “0” or decimal value (for example. If you want to specify the two–character carriage return line feed (CRLF) characters. specify \r\n. if it is set to false. the output for a record with empty trailing fields looks like the following: AAA*01*02********! (where ! is used as segment terminator). \uXXXX where XXXX represents the unicode value of the character) Value record Meaning String Character to use to separate records. 009. the output for a record with empty trailing fields looks like the following: AAA*01*02! (where ! is used as segment terminator). The string is pre‐ and appended with the quoted release character. the field value is a*b. Used only with records that have delimited fields. \t for tab) Hexidecimal value with prefix “0X” (for example. if * is a delimiter. String Character to use to separate subfields. String The type of encoding used to write data to the output file. You should specify true for sortInput if the data in ffValues is not in the same order as defined by ffSchema. The order of the undefined records appear in the final document is random. note that: The service will run slower. WmFlatFile Built–in Services Reference FormatInfo Document Any values mapped to the FormatInfo variable will be passed unmodified to all format services invoked by convertToString and convertToValues. Important! If you select to sort the input records. This is the default. String (optional) Whether you want the service to sort the input records to match the flat file schema specified in ffSchema. false You do not want the service to sort the input records to match the flat file schema.1 92 . The default encoding is UTF–8. the order they appear in the final document is random. Returns the document as a byte array instead of a string. All undefined records will be sorted after the defined records. This setting is useful (but optional) when parsing multi‐byte encodings. Value true Encoding sortInput Description You want the service to sort the input records to match the flat file schema. If there are multiple records at the same level with the same name. returnAsBytes Value false true Flat File Schema Developer’s Guide Version 7. provide the name of the file you want created as a result of this service.5. Description Returns the document as a string. The input records must match the order of the flat file schema. This is the default. outputFileName String (optional) If you want the output returned in a file instead of in the string output variable. It is used only when the iterate variable has been set to true. Variable record Description String Character used to separate records. The string value is not returned.1 93 . Object String array containing messages pertaining to errors that occurred during conversion. \uXXXX where XXXX represents the unicode value of the character) The space character. String The full name of the flat file schema object used to parse the ffData object. If the delimiter is null.5. 0X13) Octal value with prefix “0” or decimal value (for example. InputStream. 0X09. Flat File Schema Developer’s Guide Version 7. WmFlatFile Built–in Services Reference Output Variables string bytes errorArray String Data that represents the flat file document. The default encoding is UTF–8. returns the output as a byte array encoded using the specified encoding. *. Specifying one of these values will override any information set in the flat file schema. If you want to specify the two–character carriage return line feed (CRLF) characters. Document (optional) An IData object that contains the segment terminator and the field and subfield separators. you can specify: One character or character representation (for example. \t for tab) Hexidecimal value with prefix “0X” (for example. it will be located using the information defined in the flat file schema. this contains a value of null. \n for line terminator. 011. 023) Unicode characters (for example. pub.flatFile:convertToValues Converts a flat file document to an IS document (IData object) based on the input flat file schema. To specify a delimiter. you must specify all values. specify \r\n. Input Variables ffData ffSchema ffIterator encoding delimiters Object The flat file input with type of String. or ByteArray. Object (optional) An object that encapsulates and keeps track of the input data during processing. Object If the input variable returnAsBytes=true. String (optional) The encoding of the InputStream passed in to ffData. Important! If you specify one delimiter value. If no errors are encountered. field. This is the default. until all records are processed. and the quoted release character is “. If a quoted release character occurs in a field or subfield before the delimiter. The string is pre‐ and appended with the quoted release character.5. String Character to use to ignore a record. iterate String (optional) Whether you want to process the input all at one time or not. Processes all input data at one time. the string appears as “a*b”. it will be prefixed with the release before being written to the output ffValues. After all child records of the top level record are processed. String Character used to ignore a record. field. or subfield delimiter in a field. This is the default. Always create IS document even though all the fields are null. the iterator moves to the top level of the next record in the flat file schema. Description No IS document (IData object) will be created if all the fields are null. if * is a delimiter. Value true false Flat File Schema Developer’s Guide Version 7. quotedRelease FormatInfo Document Any values mapped to the FormatInfo variable will be passed unmodified to all format services invoked by convertToString and convertToValues.1 94 . WmFlatFile Built–in Services Reference field subfield release String Character used to separate fields. or subfield delimiter in a field. it will be prefixed with quotedrelease before being written to the output string. the field value is a*b. Description Processes top level records (children of the document root) in the flat file schema one at a time. String Character used to separate subfields. Value true false createIfNull String (optional) Whether to create the IData object if all the fields are null. For example. If a release character occurs in a field or subfield before the delimiter. Use this option when validating the structure of the ffData against the given flat file schema. ffValues will not return data.5. Validation errors are returned only if validate is set to true. false keepResults String (optional) Whether to return the parsed data in the ffValues output parameter. true returnErrors String (optional) Whether to return the validation errors. Value asArray Description Return any validation errors with the ffData in an array called errors. Note: The fixed length record parser ignores skipWhiteSpace. it preserves white space. This is the default. Value true Description Ignore white spaces at the beginning of a record. When the flat file parser encounters more than the maximum number of errors within a record. Return validation errors in the ffValues object. inResults both maxErrors String (optional) The maximum number of errors that can be returned from one record.1 95 . false validate String (optional) Whether to return error messages that describe how ffData differs from the flat file schema. Value true Description The parsed ffData will be returned in the output ffValues. This is the default. This is the default. Value false Description Do not return error messages describing how ffData differs from the specified flat file schema. This is the default. Flat File Schema Developer’s Guide Version 7. Record is used as it is identified (useful for positional data record). Return validation errors in both errors and ffValues. the parser will stop parsing and return the parsed data and errors processed up until that point. WmFlatFile Built–in Services Reference skipWhiteSpace String (optional) Whether white space at the beginning of records will be ignored. Validation errors are returned only if validate is set to true. Return errors describing how the given ffData violates the constraints described in the flat file schema. the count of the next defined record will reflect the undefined data. WmFlatFile Built–in Services Reference flags Document (optional) Flags that you can set to govern convertToValues options. the second is 2. For example. This is the default. Value true Description The @record–count field is added to each parsed record. Value true Description When a conditional validation error occurs. the @record–count field for the next defined record will be 8. If there are records that are undefined data. The @record–count field is used to identify the record number of each parsed record. etc. This is the default. detailedErrors String Whether you want detailed conditional validation error information. When a conditional validation error occurs. “Validation Errors”.5. if the @record–count field for a record is 2 and that record contains 5 undefined records. the service does not provide detail error information. This flag is only used when validate is true. false The @record–count field is not added to each parsed record. Variable addRecordCount Description String Whether you want the service to add an additional field (@record–count) to each parsed record in the resulting IData object (ffValues). For more information. This field contains the number of the parsed record. Conditional validators report only whether a condition failed validation with no additional information about the conditions that were violated. The first parsed record is 1. false Flat File Schema Developer’s Guide Version 7. the output errors variable will contain detail information about all the conditions that were violated. see Appendix A.1 96 . The service will report invalid records as errors prior to locating the first valid record. Object (optional) An object that encapsulates and keeps track of the input records during processing. This is the default. at the end of fields. left right both Output Variables ffValues ffIterator Document The IData object that represents the input flat file data. When the ffIterator variable is null. isValid String (optional) An array containing the validation errors. The validate input variable was set to true and errors were found.5. Value true Description The service will wait until it finds the first valid record before reporting invalid records as errors. “Validation Errors” of this guide. WmFlatFile Built–in Services Reference skipToFirst Record String Whether you want the service to wait until it finds the first valid record before reporting invalid records as errors. String Whether flat file contains validation errors. When all input data has been processed. This is the default. The service will delete all blank spaces at the beginning and end of all fields. It is used only when the iterate variable has been set to true. For more information about validation error codes see Appendix A. or both. The service will delete all blank spaces at the end of all fields. Value none Description The service will not delete any blank spaces from fields.1 97 . Value true false errors Description The validate input variable was set to true and no errors were found. the object becomes null. false trimWhitespace String Whether you want the service to delete any blank spaces at the beginning of fields. or the validate input variable was set to false. if any. you should exit the LOOP to discontinue processing. Flat File Schema Developer’s Guide Version 7. that were found in ffData. The service will delete all blank spaces at the beginning of all fields. Input Variables None Output Variables encodings String List A list of supported encodings.flatFile. WmFlatFile Built–in Services Reference pub. Input Variables FlatFileSchema PackageName DocumentTypeName String The fully–qualified name of the flat file schema for which you want to generate an IS document type. which are described in “Flat File Generation Sample Services” on page 111. Flat File Generation Services Use the services in the pub.flatFile.flatFile. The sample services are the sample.jar installed. The sample.generate folder to create. and delete flat file dictionary entries.generate folder.generateFFSchema:fixedLength service.generate:createDocumentType Creates an IS document type that defines the XML representation of a flat file schema. contains sample services that illustrate how to use the services in the pub.generateFFSchema folder.5. String The fully–qualified name that you want to assign to the created IS document type. That is.flatFile. “Programmatically Creating Flat File Schemas and Dictionaries”. if you do not have converters.flatFile:getSupportedEncodings This service returns a list of supported encodings. pub. modify.1 98 . String The name of the Integration Server package in which you want the created IS document type to be placed. entire flat file dictionaries.generateFFSchema:delimited service and the sample. not Java defaults. and flat file schemas. see Appendix C. which is in the WmFlatFileSamples package. For more information about how to use these services. it returns null.flatFile. Output Variables None Flat File Schema Developer’s Guide Version 7.flatFile. This service will only report webMethods encodings. the Integration Server determines if other dictionaries depend on the dictionary being deleted. deleted will be either true or false. Input Variables FFDictionaryName Output Variables deleted String Whether the flat file dictionary was successfully deleted. Value true false String The fully qualified name of the flat file dictionary that you want to delete. Output Variables None pub. The flat file dictionary was not successfully deleted.generate:createFFDictionary Creates an empty flat file dictionary. Flat File Schema Developer’s Guide Version 7.generate:findDependants service to return the names of all flat file schemas and dictionaries that are dependent on the dictionary you are deleting. Before deleting the dictionary. This service throws an exception is if the flat file dictionary you want to create already exists when the service is invoked.1 99 . String The name of the Integration Server package in which you want the created flat file dictionary to be placed. Input Variables FFDictionaryName PackageName String The fully–qualified name of the flat file dictionary you want to create. and gives the user the option of cancelling the deletion. Description The flat file dictionary was successfully deleted.flatFile.flatFile.generate:deleteFFDictionary Deletes a flat file dictionary. Usage Note Before you run this service. WmFlatFile Built–in Services Reference pub.flatFile. you should run the pub.5. WmFlatFile Built–in Services Reference pub. deleted will be either true or false. Input Variables FFDictionaryName EntryName EntryType String The fully–qualified name of the flat file dictionary that contains the entry that you want to delete. Description The flat file schema was successfully deleted. The flat file schema was not successfully deleted. Value true false Description The flat file dictionary entry was successfully deleted. Flat File Schema Developer’s Guide Version 7. pub. String The name of the entry that you want to delete. The flat file dictionary entry was not successfully deleted. Output Variables deleted String Whether the flat file dictionary entry was successfully deleted.generate:deleteFFSchema Deletes a flat file schema.flatFile. Input Variables FFSchemaName Output Variables deleted String Whether the flat file schema was successfully deleted. or Field.5. Value true false String The fully–qualified name of the flat file schema that you want to delete.generate:deleteFFDictionaryEntry Deletes a single entry from a flat file dictionary. String The type of entry that you are deleting. Composite. deleted will be either true or false.flatFile. Specify Record.1 100 . Output Variables references Document List The referenced objects and the packages that contain them.flatFile. String The name of the dependant object. String The name of the flat file dictionary whose dependants you want to find.generate:findDependants Returns the names of all flat file schemas and dictionaries that are dependent on a given flat file dictionary.1 101 . Input Variables name String The name of the flat file dictionary or flat file schema whose references you want to find.5. Variable packageName name Description String The name of the package that contains the dependant object.flatFile. WmFlatFile Built–in Services Reference pub. String The name of the referenced object.generate:findReferences Returns the names of all flat file dictionaries that are referenced by a given flat file dictionary or flat file schema. Flat File Schema Developer’s Guide Version 7. pub. Input Variables FFDictionaryName String The fully–qualified name of the flat file dictionary that you want returned as XML. Input Variables ffDictionaryName Output Variables dependants Document List The dependant objects and the packages that contain them. Variable packageName name Description String The name of the package that contains the referenced object. pub.flatFile.generate:getFFDictionaryAsXML Returns a dictionary as an XML string. pub.generate:getFFDictionaryEntryAsXML Returns a single dictionary entry as an XML string. The returned XML string conforms to the pub. The returned XML string conforms to the pub.generate:FFSchema IS document type. String The name of the entry that you want to returned as XML. Specify Record.1 102 . pub. Input Variables FFSchemaName String The fully–qualified name of the flat file schema that you want returned as XML. Input Variables FFDictionaryName EntryName EntryType String The fully–qualified name of the flat file dictionary that contains the entry that you want returned as XML. The returned XML string conforms to the pub.generate:FFDictionary IS document type. Composite.flatFile.flatFile.flatFile.generate:getFFSchemaAsXML Returns the specified flat file schema as an XML string.flatFile. WmFlatFile Built–in Services Reference Output Variables FFXML String The returned flat file dictionary as an XML string. Flat File Schema Developer’s Guide Version 7. or Field.generate:FFDictionary IS document type. String The type of entry that you want returned. Output Variables FFXML String The returned flat file schema as an XML string.5. Output Variables FFXML String The returned flat file dictionary entry as an XML string.flatFile. Input Variables FFDictionaryName EntryType String The fully–qualified name of the flat file dictionary that contains the entries that you want listed.flatFile. “Programmatically Creating Flat File Schemas and Dictionaries”. Output Variables EntryNames String List The list of returned flat file dictionary entries. use the pub.flatFile. String The type of entries that you want listed. Flat File Schema Developer’s Guide Version 7.5.generate:FFDictionary IS document type. String The flat file dictionary (as an XML string) that you want to create in the Integration Server namespace. see the samples provided in the WmFlatFileSamples package and that are described in “Flat File Generation Sample Services” on page 111.flatFile.1 103 .generate:deleteFFDictionary service to delete the flat file dictionary before invoking this service. WmFlatFile Built–in Services Reference pub.generate:listFFDictionaryEntries Lists all entries in a specified flat file dictionary that are of a specified type. Specify Record. Composite.generate:saveXMLAsFFDictionary Creates a flat file dictionary in the Integration Server namespace by converting the specified flat file dictionary that is in XML format into a namespace flat file dictionary. pub. If a flat file dictionary with the same name already exists in the Integration Server namespace. String The name of the Integration Server package in which to save the flat file dictionary. Input Variables FFDictionaryName PackageName FFXML String The fully–qualified name of the flat file dictionary that you want to create in the Integration Server namespace. see “Creating a Service that Retrieves the XML File” on page 140 in Appendix C. The XML string must conform to the pub. For sample code that shows how to retrieve the data for FFXML from an XML file in the local file system. This service throws an exception is if a flat file dictionary with the same name already exists when it is invoked.flatFile. Note: To see examples of how to supply the XML string in FFXML by mapping data from another file. or Field. Output Variables saved String Whether the flat file dictionary was saved successfully. the service reports the structural validation errors. It will have one of the following values. the service proceeds with logical validation and reports any logical validation errors. The flat file dictionary was not successfully saved. pub. If a flat file schema with the same name already exists in the Integration Server namespace. When the XML string contains no structural validation errors.generate:saveXMLASFFSchema Creates a flat file schema in the Integration Server namespace by converting the specified flat file schema that is in XML format into a namespace flat file schema.generate:deleteFFSchema service to delete the flat file schema before invoking this service.flatFile. The default is 100. String List (optional) Warnings about the flat file dictionary that was created.flatFile. Logical validation of the XML contents. The validation occurs in two stages. 1 2 Structural validation of the XML. WmFlatFile Built–in Services Reference maxNumOfErrors String (optional) The maximum number of errors that you want returned.5. This service throws an exception is if a flat file schema with the same name already exists when it is invoked. but does not proceed with logical validation. The service ensures the flat file dictionary is valid before saving it in the Integration Server namespace. Flat File Schema Developer’s Guide Version 7. Description The flat file dictionary was successfully saved.flatFile. Value true false Errors Warnings Usage Note Use this service to add a new flat file dictionary. String List (optional) Errors that occurred while attempting to save the flat file dictionary to the Integration Server namespace. Use the pub.generate:updateFFDictionaryEntryFromXML if you want to update one or more entries in a flat file dictionary rather than creating a new flat file dictionary.1 104 . If structural validation errors occur. use the pub. 1 105 . The flat file schema was not successfully saved. The service ensures the flat file schema is valid before saving it in the Integration Server namespace. maxNumOfErrors String (optional) The maximum number of errors that you want returned. the service proceeds with logical validation and reports any logical validation errors. see “Creating a Service that Retrieves the XML File” on page 140 in Appendix C. String List (optional) Errors that occurred while attempting to save the flat file schema to the Integration Server namespace. Note: To see examples of how to supply the XML string in FFXML by mapping data from another file. String The name of the Integration Server package in which to save the flat file schema. The default is 100.flatFile. Value true false Errors Warnings Description The flat file schema was successfully saved. It will have one of the following values. String List (optional) Warnings about the flat file schema that was created. WmFlatFile Built–in Services Reference Input Variables FFSchemaName PackageName FFXML String The fully–qualified name of the flat file schema that you want to create in the Integration Server namespace. If structural validation errors occur. String The flat file schema (as an XML string) that you want to create in the Integration Server namespace. Flat File Schema Developer’s Guide Version 7. When the XML string contains no structural validation errors. The XML string must conform to the pub. see the samples provided in the WmFlatFileSamples package and that are described in “Flat File Generation Sample Services” on page 111.5.generate:FFSchema IS document type. but does not proceed with logical validation. For sample code that shows how to retrieve the data for FFXML from an XML file in the local file system. “Programmatically Creating Flat File Schemas and Dictionaries”. The validation occurs in two stages. Output Variables saved String Whether the flat file schema was saved successfully. the service reports the structural validation errors. Logical validation of the XML contents. 1 2 Structural validation of the XML. The dictionary entry was not successfully saved. The validation occurs in two stages. If structural validation errors occur. Logical validation of the XML contents. see “Creating a Service that Retrieves the XML File” on page 140 in Appendix C. but does not proceed with logical validation. It will have one of the following values. If the entry does not already exist. This service goes through all entries that you specify in the FFXML variable. If an entry with the same name and type already exists in the flat file dictionary. Value true false Description The dictionary entry was successfully saved. For sample code that shows how to retrieve the data for FFXML from an XML file in the local file system. The XML string in FFXML must conform to the pub. Input Variables FFDictionaryName FFXML String The fully–qualified name of the flat file dictionary that contains the entries that you are replacing and/or adding.generate:updateFFDictionaryEntryFromXML Updates one or more entries in a flat file dictionary in the Integration Server namespace. When the XML string contains no structural validation errors. “Programmatically Creating Flat File Schemas and Dictionaries”. Note: To see examples of how to supply the XML string in FFXML by mapping data from another file. Output Variables saved String Whether the dictionary entry was saved successfully. 1 2 Structural validation of the XML. the service proceeds with logical validation and reports any logical validation errors.flatFile. Flat File Schema Developer’s Guide Version 7.generate:FFDictionary IS document type.1 106 . this service overwrites the existing entry. the service reports the structural validation errors. String The dictionary entries (as an XML string) that you want to use to replace an existing entry or that you want to add to the flat file dictionary. maxNumOfErrors String (optional) The maximum number of errors that you want returned. this service creates the entry in the specified flat file dictionary. WmFlatFile Built–in Services Reference pub. This service ensures the entries are valid before saving them in the flat file dictionary.5. The default is 100.flatFile. see the samples provided in the WmFlatFileSamples package and that are described in “Flat File Generation Sample Services” on page 111. For more information about how to use these IS document types. Flat File Schema Developer’s Guide Version 7.flatFile.xsd Variables FFDictionary Document The dictionary entries that you want to add or update.5. entire flat file dictionaries.1 107 . Document The definition of the record. WmFlatFile Built–in Services Reference Errors Warnings String List (optional) Errors that occurred while attempting to save the entry to the flat file dictionary. The information you specify in a record definition is the same as the information that you specify when creating a flat file dictionary using the Flat File Schema Editor.flatFile. String List (optional) Warnings about the dictionary entry that was updated or added. Variable EntryName RecordDefinition Description String The name of the record. see Chapter 3. see Appendix C. pub. Leave this null if you do not want to add or update record entries.generate folder define the format of the information that you must provide to add or update dictionary entries. Flat File Generation IS Document Types The IS document types in the pub.generate:FFDictionary This IS document type defines the format to use when supplying a flat file dictionary or dictionary entry (in the FFXML variable) and the format that services return (in the FFXML variable) when you are retrieving a flat file dictionary or dictionary entry. FFDictionary has the following structure: RecordDictionary Entry Document List (optional) The dictionary entries for records that you want to add or update in the flat file dictionary. The structure for this IS document type is defined in the following XML schema: IntegrationServer_directory\packages\WmFlatFile\pub\FFGeneration. For descriptions of the fields. “Programmatically Creating Flat File Schemas and Dictionaries”. “Creating and Editing Flat File Schemas and Dictionaries”. and flat file schemas. “Creating and Editing Flat File Schemas and Dictionaries”. The information you specify in a field definition is the same as the information that you specify when creating a flat file dictionary using the Flat File Schema Editor.flatFile. WmFlatFile Built–in Services Reference Composite DictionaryEntry Document List (optional) The dictionary entries for composites that you want to add or update in the flat file dictionary.5. Document The definition of the composite. FieldDictionary Entry Document List (optional) The dictionary entries for fields that you want to add or update in the flat file dictionary. see Chapter 3. be sure to supply all dictionary entries.generate:updateFFDictionaryEntryFromXML to update the flat file dictionary. see Chapter 3. For descriptions of the fields. Document The definition of the field. Usage Notes If you are using this IS document type to supply a flat file dictionary as input to the pub.generate:saveXMLAsFFDictionary. Variable EntryName FieldDefinition Description String The name of the field.1 108 .flatFile. Leave this null if you do not want to add or update composite entries. For descriptions of the fields. If you are using this IS document type to update an existing dictionary. provide only the entries that you want to add or update and invoke the pub. Leave this null if you do not want to add or update field entries. The information you specify in a composite definition is the same as the information that you specify when creating a flat file dictionary using the Flat File Schema Editor. Flat File Schema Developer’s Guide Version 7. “Creating and Editing Flat File Schemas and Dictionaries”. Variable EntryName Composite Definition Description String The name of the composite. Document Structure RecordStructure RecordUsage Flat File Schema Developer’s Guide Version 7. For a description of the fields.flatFile. The information that you specify for DocumentStructure corresponds to the data you specify on the Flat File Structure tab in the Flat File Schema Editor. WmFlatFile Built–in Services Reference pub. including either the dictionary reference for this record or the definition of the record. For a description of the fields.5. Variable Ordered Description String Whether the child records appear in the flat file in the order they are defined in the flat file schema. Variable Ordered Description String Whether the child records appear in the flat file in the order they are defined in the flat file schema.xsd Variables FFSchema Document The flat file schema that you want to add or update. see “Step 3: Define the Structure of the Flat File Schema” on page 48. The structure for this IS document type is defined in the following XML schema: IntegrationServer_directory\packages\WmFlatFile\pub\FFGeneration. Document Information about how the record is used. Document List Definitions of the records within the flat file.1 109 . see “Step 1: Add and Configure the Flat File Schema” on page 36.generate:FFSchema This IS document type defines the format to use when supplying a flat file schema (in the FFXML variable) and the format that services return (in the FFXML variable) when you are retrieving a flat file schema. FFSchema has the following structure: Variable Delimiters Description Document The delimiters used in the flat files that adhere to this flat file schema. Document The structure of the flat files that adhere to this flat file schema. The information that you specify for Delimiters corresponds to the data you specify on the Flat File Definition tab in the Flat File Schema Editor. Document Where to locate the identifier to use to correlate a record in the flat file to a record definition in the flat file schema. RecordParser Document The type of record parser. WmFlatFile Built–in Services Reference RecordStructure Document List Child records of this record. Document Areas String List Areas for this flat file schema. An area is a way to associate an arbitrary string with a given record. If you specify a default record.1 110 . DefaultRecord Reference Record Identifier Undefined DataAllowed String Whether you want the pub. For DelimitedParser.flatFile:convertToValues service to flag undefined data errors. Document (optional) The dictionary name and entry name that identifies the default record for the flat file schema. Specify either the NthFieldIdentifier variable or the FixedPositionIdentifier variable: Use NthFieldIdentifier to identify the field in the record (counting from zero) that contains the identifier. VariableLengthParser. Use FixedPositionIdentifier to identify the character position in the record (counting from zero) where the record identifier is located. the default record is used for any record that cannot be recognized. and EDIParser. you do not need to specify a value. Flat File Schema Developer’s Guide Version 7. when using the flat file schema to parse a flat file schema. In this IS document. specify only the one variable that corresponds to the type of record parser to use.flatFile:convertToValues service to generate undefined data errors when you use this flat file schema to convert a flat file to an IData object. Specify true if you want to allow undefined data and do not want the pub. specify one of FixedLengthParser. VariableLengthParser. or EDIParser. just have the variable in the pipeline. DelimitedParser.5. That is.flatFile:convertToValues service to flag undefined data errors. This is a recursive reference to the RecordStructure defined in FFSchema/DocumentStructu re. Specify false if you do not want to allow undefined data and you do want the pub. which is where the field occurs in the record Flat File Schema Developer’s Guide Version 7.flatFile. name. which is in the WmFlatFileSamples package. Note: If the floating record has an alternate name.txt definition file. The created flat file schema references a flat file dictionary for record definitions.flatFile.1 111 . for example. contains sample services that illustrate how to use the services in the pub. which follows a RecordDefinition and defines the child records of the previous record that was defined by a RecordDefinition. address Field position. sample. which this service also creates. which is the maximum number times this child record can appear after its parent record FieldDefinition. specify the alternate name. The WmFlatFileSamples package is located in the Knowledge Base on the Advantage Web site. which is a brief description of the contents of the field.txt definition file contains comma–separated data. which follows either a RecordDefinition or a ChildRecord. which defines a type of record that is contained in the flat file.generateFFSchema:delimited Creates a flat file schema for parsing a delimited flat file.flatFile. which is the identifier for the child record being defined. A ChildRecord contains the following: ChildRecord keyword Child record identifier. Each record in the . There are three types of definitions in the . Flat File Generation Sample Services The sample.5.generateFFSchema folder. A RecordDefinition contains the following: RecordDefinition keyword Record identifier. WmFlatFile Built–in Services Reference FloatingRecord String (optional) The name of the record that is defined in the schema as a floating record.txt file: RecordDefinition. The flat file schema will be created based on data in a . Description String Description of the flat file schema. It defines the fields that are in the previous record that was defined by a RecordDefinition or a ChildRecord. A FieldDefinition contains the following: FieldDefinition keyword Field name.generate folder. Repeat count. which is the identifier for the record being defined ChildRecord. String The name of the flat file dictionary associated with the flat file schema you are creating.txt definition file to parse. WmFlatFile Built–in Services Reference The sample. String The name of the Integration Server package in which to create the flat file schema and dictionary. which is an example of a delimited flat file that can be parsed using the flat file schema created from the data in the FFDefinition. referencing a dictionary entry that does not exist.5. Each record will contain the fields defined by the corresponding FieldDefinitions. An error is generated if this flat file schema already exists.1 112 . String The field number that contains the record identifier. String Character used to separate fields. Records will be nested as indicated by the ChildRecords.txt definition file that you can use as input to this service FFExample. String Character used to separate subfields.txt definition file and loops over each RecordDefinition creating a flat file dictionary entry for each. Input Variables TXTFilename SchemaName DictionaryName PackageName RecordId Delimiters String The name of the . which is a sample . The dictionary will be created if it does not already exist. The first RecordDefinition defined in the . If a record is listed in the .txt. The WmFlatFileSamples\pub\sample\flatFile\generateFFSchema\delimited directory contains the following files to use with the sample: FFDefinition.generateFFSchema:delimited service parses the . Variable record field subfield Output Variables None Description String Character used to terminate records.txt file.txt. that record will appear in the flat file schema. Document An IData object that contains the segment terminator and the field and subfield separators used by the flat files that the flat file schema will be used to parse.txt definition file will be considered the root node of the flat file document. Flat File Schema Developer’s Guide Version 7. All other records must be children of that record. String The fully–qualified name of the flat file schema to create.txt definition file as a ChildRecord only (and not defined as a RecordDefinition).flatFile. The created flat file schema contains record definitions rather than referencing a flat file schema.csv. Field length. String The name of the Integration Server package in which to create the flat file schema and dictionary. String The fully–qualified name of the flat file schema to create. Input Variables CSVFilename SchemaName PackageName RecordLength RecordId Output Variables None String The fully–qualified name of the CSV definition file to parse. Each record in the CSV definition file contains the following fields: Record identifier. address. name. The WmFlatFileSamples\pub\sample\flatFile\generateFFSchema\fixedLength directory contains the following files to use with the sample: FFDefinition. which is a brief description of the contents of the field.1 113 . Field name. which is a sample CSV file that you can use as input to this service FFExample. which is the identifier for the record being defined.csv file. The flat file schema will be created based on data in a CSV definition file.txt. which is number of bytes in the field. which is an example of a fixed length flat file that can be parsed using the flat file schema created from the data in the FFDefinition. The sample.flatFile.generateFFSchema:fixedLength service reads the CSV file and creates the flat file schema to parse a fixed length flat file.generateFFSchema:fixedLength Creates a flat file schema for parsing a fixed length flat file. String The number that indicates where in the record the record identifier starts. for example. String The number indicating the length of each record defined by the flat file schema. Field start position. An error is generated if this flat file schema already exists. The CSV file must be sorted by the record identifier. Flat File Schema Developer’s Guide Version 7.flatFile. WmFlatFile Built–in Services Reference sample.5. which is the position of the first byte to extract from the record. WmFlatFile Built–in Services Reference Flat File Schema Developer’s Guide Version 7.1 114 .5. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .Appendix A. . . . . . . . Validation Errors Validation Error Contents . . . . 116 Validation Error Codes . . . . . . . . . . . . . . . . . . . . . 120 Flat File Schema Developer’s Guide Version 7. . . . . .1 115 . . . . . . . . . . . . . . . . . flatFile:convertToValues service is set to true and an object within the flat file does not conform to the flat file schema. If the service finds that an object is invalid.1 116 . which appears nested in the error array in the variable childErrors.flatFile:convertToValues service only generates details about violated conditions when the flag/detailedErrors input variable of the pub. the service generates errors when validating the flat file.flatFile:convertToValues Flat File Schema Developer’s Guide Version 7. Example of Validation Results This errors array contains the following types of information about the errors that occurred in a record during validation. The pub.A. Validation Errors Validation Error Contents When the validate variable of the pub. Errors with conditional validators can generate detail information about the conditions violated in a child errorDetails array. it returns validation errors in the errors output of the convertToValues service. see “General Error Entries in the errors Array” on page 117. Each error in a child record also generates one item within the parent record. Each error in a record generates one entry in the errors array. For more information about the fields in the errors array. one entry in the array for each violated condition. General Error Entries in the errors Array An entry in the errors array contains the following information. this indicates the position of the field within the composite. see “Entries for Conditional Validator Errors in errorDetails Array” on page 117. For a record. which contains details about violated conditions. (Array).flatFile:convertToValues service to true. this indicates the position of the field within the record. For information about errorDetails entries. A brief description of the error. For a composite. see “Validation Error Codes” on page 120. The name of the element in the flat file schema that contained the error. Variable in errors errorPosition Description Indicates where the error occurred within the parent element. this indicates the position of the record within the flat file. errorMessage errorCode reference badData childErrors Entries for Conditional Validator Errors in errorDetails Array The errorDetails array includes detail information about the conditions that were violated when the following are true: When you set the validate and flag/detailedErrors input variables of the pub. The value of the data that failed validation. For more information. See the table below the sample for more information. Flat File Schema Developer’s Guide Version 7. see “Entries for Conditional Validator Errors in errorDetails Array” on page 117.flatFile:convertToValues service encounters errors with conditional validator The following shows a sample of the errors array that includes the errorDetails array. A number indicating the type of error. For a nested child record. For a list. –AND– The pub.A. Validation Errors service is set to true. Indicates that a field or subfield within the record or composite generated a validation error.1 117 . flatFile:convertToValues service generates the detail in errorDetails array described below. Validation Errors Example of Validation Results with Conditional Validation Errors 1 2 3 Portion of the array 1 Description For a description of this portion of the errors array.A. the pub. When the flag/detailedErrors is true. errors Flat File Schema Developer’s Guide Version 7.1 118 .flatFile:convertToValues service is set to false. see “General Error Entries in the errors Array” on page 117. this is the only information generated in the errors array about violated conditions. When the flag/detailedErrors input variable of the pub. A. Validation Errors Portion of the array 2 Description To provide information about the conditions that were violated, the convertToValues service generates an entry in the errorDetails array for each violated condition. Variable in errorDetails errorPosition errorMessage errorCode reference badData condition errorDetails Description Always zero; the errorPosition is not meaningful at this level of the errorDetails array. A brief description of the condition that was violated. A number indicating the type of error. For a list, see “Validation Error Codes” on page 120. Always null; the reference is not meaningful at this level of the errorDetails array. Always null; the badData is not meaningful at this level of the errorDetails array. The condition that was violated. Details about how the condition was violated. See the description below. errorDetails 3 errorDetails The child errorDetails array contains detail about how the condition was violated. The convertToValues service generates an entry for each way the condition was violated. Variable in errorDetails errorPosition errorMessage errorCode reference badData Description Indicates the position in the record that contains the field that caused the condition to be violated. A brief description of the condition that was violated. A number indicating the type of error. For a list, see “Validation Error Codes” on page 120. The name of the element in the flat file schema that contained the error. The value of the data that failed validation. Flat File Schema Developer’s Guide Version 7.1 119 A. Validation Errors Validation Error Codes The following table describes the validation error codes that you might receive when the validate variable of the pub.flatFile:convertToValues service is set to true and you are validating a flat file or testing a flat file schema. Error Code 1 Description In the flat file schema, the Mandatory drop‐down menu was set to true for this element, but the element does not occur in the flat file. Reserved for future use. Unexpected element. This field is not allowed in the record or composite in which it appears. In the flat file schema, a length validator was specified in the Validator property for this field. The value in the flat file exceeded the maximum length specified. In the flat file schema, a length validator was specified in the Validator property for this field. The value in the flat file did not meet the minimum length specified. Reserved for future use. In the flat file schema, a code list validator was specified in the Validator property for this field. The value in the flat file was not listed in the flat file schema as a valid value. Reserved for future use. Reserved for future use. In the flat file schema, a conditional validator was specified in the Validator property for this composite or record. The contents of this composite or record did not meet the conditional requirements. The errorMessage variable contains the number of the condition that failed. If you had a validation string of C010203R0405 and both conditions failed, the error message would state that rules 0 and 1 were violated. If only the second is violated, it states that the rule 1 was violated. If you require more detail about conditional validator errors, set the flag/detailedErrors input variable of the pub.flatFile:convertToValues service to true. For a description of the error details that convertToValues service generates when you set flag/detailedErrors to true, see “Entries for Conditional Validator Errors in errorDetails Array” on page 117. 2 3 4 5 6 7 8 9 10 Flat File Schema Developer’s Guide Version 7.1 120 A. Validation Errors Error Code 11 Description Indicates that this record is not defined anywhere in the flat file schema. You will receive this error only when you have not specified a Default Record or selected Allow Undefined Data where this record appears in the flat file. If you have specified either of these properties, you will not receive this error. Indicates that this record is defined in this flat file schema, but it occurs in the flat file in a location prohibited by the flat file schema. Reserved for future use. In the flat file schema, you specified a maximum repeat value in the Max Repeat property for a particular record. The number of record instances in the flat file exceeded the specified maximum number of repeats. Reserved for future use. Within a record, this indicates that the record contains a composite or field error. For a composite, this indicates the that composite contains a subfield error. A string could not be formatted into the intended format. A format service reported that the data could not be formatted properly. For information about field format services, see “Format Services” on page 66 of Chapter 3, “Creating and Editing Flat File Schemas and Dictionaries” of this guide. Indicates that a conditional validation rule requires a field, but that field is not present in the data. Indicates that a field is excluded by a conditional validation rule, but the field is present in the data. 12 13 14 15 16 17 18 19 Flat File Schema Developer’s Guide Version 7.1 121 Validation Errors Flat File Schema Developer’s Guide Version 7.1 122 .A. . . . . . . . . . . 127 Flat File Schema Developer’s Guide Version 7. . . 124 Stateful Encodings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Flat File Byte Count Parser Overview . . . . . . . . . . . . . . . . . . . . 124 Handling Partial Characters . .1 123 . . . . . . . . . . . . . . . . . . . . . .Appendix B. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A delimiter may be a single character.g. However. Flat File Schema Developer’s Guide Version 7. not characters. Important! Multi‐byte encoded files must run on JVM version 1. Partial characters are characters that violate character boundary conditions. The parser still uses the String. Handling Partial Characters The parser reads and writes only complete characters. the byte count validator validates the total number of bytes in a field. Both the convertToValues and the convertToString services support byte‐count parsing for multi‐byte encodings. Thus.1 124 . The field length validator.flatFile:convertToString” on page 90). In addition. there is no functional difference between parsing bytes and characters. Flat File Byte Count Parser Overview The flat file parser measures the lengths and positions of all records and fields in flat file schemas in terms of bytes. COMP‐3 COBOL fields).B. Important! The parser does not support the writing or reading of binary data (e. Delimiter and release character extractors still extract the specified character from the input file based on a character position.. nor does it support multiple kinds of encodings within one file. Note: This change does not affect users who currently parse flat files using single‐byte encodings because one byte equals one character. This parser supports both single‐byte encodings (equivalent to character encodings) and multi‐byte encodings.length() method to validate field lengths (in characters). There is no change in the way in which the parser handles the following entities: Delimited fields and records. as described below. With multi‐byte encodings.5. a byte count can differ from a character count since a single character can be encoded to multiple bytes. convertToString now includes an optional setting that returns a document as a byte array instead of a string (see “pub.4 or later. Service Pack 2. but may not be byte based. the parser measured all lengths and positions in characters. Prior to Version 6. Note: If the bytes that begin or end the record are encoded to a valid character. consider the following multi‐byte encoding: 12121212 These eight bytes represent four two‐byte characters. 121 212 12 Flat File Schema Developer’s Guide Version 7. Record 2 contains one character. an exception is thrown. and cannot be properly decoded. The character formed by the third and fourth bytes is lost because these bytes span Records 1 and 2. producing an undesirable result: Record 1: Record 2: Record 3: Note that: Record 1 contains one character.1 125 . Reading a fixed position field that ends in the middle of a multi‐byte character. The partial character is not included in the field. formed by the seventh and eighth bytes. The last byte is a partial character. To illustrate a case where the parser reads fixed position records that begin and end in the middle of a multi‐byte character. the parser ignores it. If we specified a fixed length file with a record length of three bytes instead of two bytes.B. Reading a fixed position record that begins or ends in the middle of a multi‐byte character. the parser would read this encoding as follows. The partial character is ignored. formed by the first two bytes of the file. How the Parser Handles the Condition The field starts on the next complete character. formed by the fifth and sixth bytes of the file. it will be the wrong character. The field ends on the previous complete character. Flat File Byte Count Parser Reading Partial Characters The following table describes how the parser reads partial characters: Character Boundary Condition Reading a fixed position field that begins in the middle of a multi‐byte character. Record 3 contains one character. If the bytes encode to an invalid character. For an example. and is replaced by one or more pad characters. only complete characters are written to the output file. Writing to a fixed position field that ends in the middle of a multi‐byte character. but the string for that field encodes to more than 10 bytes. the parser always truncates a string on a character boundary. The field ends on the previous complete character.B. The following table describes how the parser writes partial characters: Character Boundary Condition Writing a string to a fixed position field where the string is longer than the fixed position field (where it breaks at a character boundary). Thus. Parsing the created file will likely result in an encoding error. Does not generate an error during creation of the file. Keep this in mind when writing multi‐byte encodings to fixed length fields because it is possible to specify a field or record that does not end on a character boundary. To illustrate a case where the parser writes to a fixed position field that ends in the middle of a multi‐byte character. consider the following multi‐byte encoding: Number of Bytes in Field 4 4 Field Field1 Field2 Character 1 12 12 Character 2 12 345 The parser encodes this multi‐byte encoding as follows: Field Field1 Field2 Value 1212 12PP Flat File Schema Developer’s Guide Version 7. Flat File Byte Count Parser Writing Partial Character Encodings Partial characters present a similar problem when writing to a fixed length file. Writing to a fixed position field in the middle of a delimited field that contains a stateful encoding. see below. This could result in the creation of invalid characters. the parser will truncate the byte array to fit into 10 bytes. This means that all encoding information for a fixed position field is contained in the byte range specified for the field. In this case.1 126 . How the Parser Handles the Condition Truncates the string to fit the field. Consider a fixed length field that is 10 bytes. The partial character is not included in the field. The parser considers all fixed position fields to be “self contained”. it considers character 1 and character 2 to be complete characters. 3. B 4 8 The parser encodes this record as follows: |12O|45O Flat File Schema Developer’s Guide Version 7. Stateful Encodings The parser can read any well‐formed document that adheres to the rules of the document’s particular kind of encoding. and 5 because those three bytes would extend beyond the end of the field. The character “A” is represented by bytes 1 and 2. The character “B” is represented by byte 3. It truncates bytes.1 127 . the parser considers character 2 to be a partial character.B. Note: Escape encodings behave similarly to stateful encodings. Stateful encodings have two specific bytes that indicate when the record’s state has changed: | is a “shift‐in” byte that indicates a change from the normal state to an alternate state O (the character O. The parser truncates characters preceding the escape sequence so that the integrity of the escape sequence is maintained. Flat File Byte Count Parser The parser encodes Field1 properly. The parser encodes Field2 as follows: It considers character 1 to be a complete character Since byte 3 does not begin on a character boundary. 4. The parser can only write to files that have fixed length fields or delimited records. Character value “C” encodes to 4 btyes: |45O. It replaces these three bytes with two pad characters (represented by PP). not zero) is a “shift‐out” byte that indicates a change from the alternate state to the normal state Writing Stateful Encodings Consider a record definition with the following four‐byte fields: Start Position 0 End Position 3 Field A Record Value Character value “AB” encodes to 5 bytes: |123O. Thus. This truncation occurred on the character boundary between the characters A and B. All fixed position fields must be encoded as if they were a stand‐alone sequence of bytes. Note: A different method of encoding. In contrast. The parser does not use this method of encoding. However. creating a properly encoded record. Using this method. Flat File Byte Count Parser Notice that the parser truncated byte 3 (the character “B”) from the first field so that the field would fit within the four‐byte limit. extracting the value for the second field produces: 45OP The parser cannot properly write this byte sequence. delimited fields may carry stateful information from one field to the next field. No stateful encoding information may be carried from one fixed position field to any other fixed position field. but delimited records are. delimited records may not carry stateful information from one record to the next record. would have produced this result: |12345OP where P is an added padding byte. to extend the record length to the required eight bytes. delimited fields are not necessarily “self contained”. using a “padding” byte.1 128 .B. Flat File Schema Developer’s Guide Version 7. . . 140 Flat File Schema Developer’s Guide Version 7. . . . 130 Creating Flat File Dictionary Entries. . . . . 140 Sample Flow Services for Working with XML Files . 134 Deleting Flat File Dictionary Entries. . . . . . . . . . . . . . . .Appendix C. . . . . . . . . and Schemas . . . Dictionaries. . . . . . . . . . . . . . . . . . . . . . . . . . . . . Dictionaries. . . . . . . . . . . . . and Schemas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Programmatically Creating Flat File Schemas and Dictionaries Overview . . . . . . . . . . . . . 130 Modifying Flat File Dictionary Entries. . . . . . . . . . and Schemas . . . . . . . . . . . . . . . . . . . . . . . Dictionaries. . . . . . . . . . . . . .1 129 . . . . and delete: flat file dictionary entries entire flat file dictionaries flat file schemas To specify the data for the flat file dictionary entries. Dictionaries.generate folder.generate:FFSchema IS document type. it should conform to the following XML schema: IntegrationServer_directory\packages\WmFlatFile\pub\FFGeneration.flatFile.C.flatFile. convert the IData object to an XML string. which is in the WmFlatFileSamples package.1 130 . contains sample services that illustrate how to use the services in the pub.flatFile. Creating Flat File Dictionary Entries.flatFile. you supply the data for the item you want to create. use the pub.xsd Create a service that maps the data to an IS document (IData object).flatFile.flatFile. Flat File Schema Developer’s Guide Version 7. which are described in “Flat File Generation Sample Services” on page 111. and Schemas To create a flat file dictionary entry. When creating the XML data.generate folder to make the changes in the Integration Server namespace. The sample services are the sample.generateFFSchema:fixedLength service. For a flat file schema. then invoke the appropriate service to create the item in the Integration Server namespace. or flat file schemas. modify.generateFFSchema folder. entire flat file dictionaries. use the pub.generate folder to make the changes in the Integration Server namespace. entire flat file dictionary.generate folder of the WmFlatFile package to programmatically create. Programmatically Creating Flat File Schemas and Dictionaries Overview You can use the services in the pub.flatFile.generateFFSchema:delimited service and the sample. then invokes the appropriate services in the pub. The sample. and then invoke the appropriate services in the pub.generate:FFDictionary IS document type. The IS document type to which the IData object must conform is provided in the WmFlatFile package: For a flat file dictionary entry or dictionary. you can: Create the information in an XML file and execute a service you create that retrieves the XML data from the XML file.flatFile. or flat file schema.flatFile. flatFile.flatFile. For more information about the pub. For more information. see “Creating a Service that Retrieves the XML File” on page 140. When you invoke this service: Set the encode input variable to true.flatFile.xsd 2 Retrieve the contents of the XML file as an XML string.generate:FFDictionary.flatFile. 3 Mapping Data 1 2 3 Create the entries in the Integration Server namespace by invoking the pub.generate:updateFFDictionaryEntryFromXML service. Programmatically Creating Flat File Schemas and Dictionaries Creating Flat File Dictionary Entries The following describes the basic steps to create flat file dictionary entries when using either an XML file or mapping data: Using this method XML File Follow this procedure 1 Supply the data for the entries you want to create by creating the XML file that contains the data and that conforms to the XML schema: IntegrationServer_directory\packages\WmFlatFile\ pub\FFGeneration. Flat File Schema Developer’s Guide Version 7. Convert the IData object to an XML string by invoking the pub. Set the documentTypeName input variable to pub. see the webMethods Integration Server Built‐In Services Reference.generate:FFDictionary IS document type.1 131 .xml:documentToXMLString service.generate:updateFFDictionaryEntryFromXML service. Map the data for the entries you want to create to an IData object that conforms to the pub.C. Create the entries in the Integration Server namespace by invoking the pub.xml:documentToXMLString service. generate:saveXMLAsFFDictionary service throws an exception. When you invoke this service: Set the encode input variable to true. This procedure describes how to create a flat file dictionary that contains data.flatFile. Using this method XML File Follow this procedure 1 Supply the data that includes all entries for the dictionary you want to create by creating an XML file that contains the data and that conforms to the XML schema: IntegrationServer_directory\packages\WmFlatFile\ pub\FFGeneration. Map the data for all entries for the dictionary you want to create to an IData object that conforms to the pub. Important! The flat file dictionary you are creating must not already exist in the Integration Server namespace.flatFile.generate:FFDictionary IS document type. For more information. the pub.xml:documentToXMLString service. see “Creating a Service that Retrieves the XML File” on page 140. Flat File Schema Developer’s Guide Version 7.flatFile. If the flat file dictionary already exists. see “Creating an Empty Flat File Dictionary” on page 133. If you want to create an empty flat file dictionary.xml:documentToXMLString service. Set the documentTypeName input variable to pub. 3 Mapping Data 1 2 3 Create the dictionary in the Integration Server namespace by invoking the pub.generate:saveXMLAsFFDictionary service.C.1 132 .xsd 2 Retrieve the contents of the XML file as an XML string. Programmatically Creating Flat File Schemas and Dictionaries Creating an Entire Flat File Dictionary with Data The following describes the basic steps to create an entire flat file dictionary when using either an XML file or mapping data.flatFile.generate:saveXMLAsFFDictionary service. see the webMethods Integration Server Built‐In Services Reference. Convert the IData object to an XML string by invoking the pub.flatFile. For more information about the pub. Create the dictionary in the Integration Server namespace by invoking the pub.generate:FFDictionary. Using this method XML File Follow this procedure 1 Supply the data for the flat file schema you want to create by creating an XML file that contains the data and that conforms to the XML schema: IntegrationServer_directory\packages\WmFlatFile\ pub\FFGeneration. Follow this procedure 1 Create the empty dictionary in the Integration Server namespace by invoking the pub.xsd 2 Retrieve the contents of the XML file as an XML string.C. Programmatically Creating Flat File Schemas and Dictionaries Creating an Empty Flat File Dictionary The following describes how to create an empty flat file dictionary. see “Creating a Service that Retrieves the XML File” on page 140. Important! The flat file dictionary you are creating must not already exist in the Integration Server namespace.generate:saveXMLASFFSchema service. If the flat file dictionary already exists. Creating a Flat File Schema The following describes the basic steps to create a flat file schema when using either an XML file or mapping data: Important! The flat file schema you are creating must not already exist in the Integration Server namespace.flatFile. the pub. see “Creating an Entire Flat File Dictionary with Data” on page 132.flatFile. For more information. 3 Flat File Schema Developer’s Guide Version 7.generate:createFFDictionary service throws an exception. If the flat file schema already exists.flatFile.generate:saveXMLASFFSchema service throws an exception.generate:createFFDictionary service.1 133 . If you want to create a flat file dictionary that contains data. the pub.flatFile. Create the flat file schema in the Integration Server namespace by invoking the pub. 1 134 . and Schemas This section describes how to modify an existing flat file dictionary entry.xml:documentToXMLString service. You make your modifications to the data. Programmatically Creating Flat File Schemas and Dictionaries Using this method Mapping Data Follow this procedure 1 Map the data for the flat file schema you want to create to an IData object that conforms to the pub. Modifying an Existing Flat File Dictionary Entry To modify an existing flat file dictionary entry. entire flat file dictionary. 2 Modifying Flat File Dictionary Entries.generate:FFSchema. see the webMethods Integration Server Built‐In Services Reference.flatFile. 3 Create the dictionary in the Integration Server namespace by invoking the pub. For more information about the pub.generate:saveXMLASFFSchema service. you first retrieve from the Integration Server namespace the dictionary entry that you want to modify.flatFile. When you invoke this service: Set the encode input variable to true. Dictionaries. or flat file schema. then invoke the appropriate service to write the changes back to Flat File Schema Developer’s Guide Version 7. Convert the IData object to an XML string by invoking the pub.flatFile.generate:FFSchema IS document type.xml:documentToXMLString service.C. Set the documentTypeName input variable to pub. This creates an IData object that conforms to the pub. The data is returned as an XML string in the FFXML variable. 4 Mapping Data 1 2 3 Map data to the IData object to make your changes.flatFile.xml:XMLNodeToDocument service to convert the XML node to an IData object.xml:xmlStringToXMLNode and pub. The following describes the basic steps to modify a dictionary entry either using an XML file or mapping data. Set the documentTypeName input variable to pub.flatFile.1 135 .flatFile. For more information about the pub. Invoke the pub.xml:XMLNodeToDocument services.xml:xmlStringToXMLNode service to convert the XML string to an XML node. For more information. Programmatically Creating Flat File Schemas and Dictionaries the Integration Server namespace. Retrieve the existing information for the dictionary entry from the Integration Server namespace by invoking the pub.flatFile. When you invoke this service: Set the makeArrays input variable to false. Update the data for the dictionary entry in the XML file. see “Retrieving Namespace Data to Write to an XML File” on page 141.generate:getFFDictionaryEntryAsXML service.generate:getFFDictionaryEntryAsXML service and write it to an XML file. To convert the XML string in the FFXML variable to an IData object: a b Invoke the pub. Update the dictionary entry in the Integration Server namespace by invoking the pub.generate:FFDictionary.C.flatFile.generate:updateFFDictionaryEntryFromXML service. For more information. see the webMethods Integration Server Built‐In Services Reference. The XML file must conform to the XML schema: IntegrationServer_directory\packages\WmFlatFile\ pub\FFGeneration. Using this method XML File Follow this procedure 1 Retrieve the existing information for the dictionary entry from the Integration Server namespace by invoking the pub.generate:FFDictionary IS document type. Flat File Schema Developer’s Guide Version 7.xsd 2 3 Retrieve the contents of the XML file as an XML string. see “Creating a Service that Retrieves the XML File” on page 140. flatFile.generate:findDependants service and write it to an XML file. 5 Update the dictionary entry in the Integration Server namespace by invoking the pub.flatFile. Set the documentTypeName input variable to pub. you first retrieve from the Integration Server namespace the item that you want to modify. For more information. For more information. Create the flat file dictionary in the Integration Server namespace again by invoking the pub.generate:FFDictionary.xml:documentToXMLString service.generate:deleteFFDictionary service. Programmatically Creating Flat File Schemas and Dictionaries Using this method Follow this procedure 4 Convert the IData object to an XML string by invoking the pub. You make your modifications to the data. Delete the dictionary from the namespace before invoking the appropriate service to write the changes back to the Integration Server namespace. 4 5 Flat File Schema Developer’s Guide Version 7.C. Modifying an Existing Flat File Dictionary To modify an existing flat file dictionary.1 136 . see “Creating a Service that Retrieves the XML File” on page 140.generate:saveXMLAsFFDictionary service. Using this method XML File Follow this procedure 1 Retrieve the existing information for the flat file dictionary from the Integration Server namespace by invoking the pub. see “Retrieving Namespace Data to Write to an XML File” on page 141. For more information about the pub.flatFile. When you invoke this service: Set the encode input variable to true. see the webMethods Integration Server Built‐In Services Reference. The XML file must conform to the XML schema: IntegrationServer_directory\packages\WmFlatFile\ pub\FFGeneration.flatFile.generate:updateFFDictionaryEntryFromXML service. Delete the existing flat file dictionary from the Integration Server namespace by invoking the pub. Update the data for the flat file dictionary in the XML file.xml:documentToXMLString service. The following describes the basic steps to modify a flat file dictionary either using an XML file or mapping data.xsd 2 3 Retrieve the contents of the XML file as an XML string.flatFile. flatFile.flatFile. Set the documentTypeName input variable to pub.generate:findDependants service. For more information about the pub. Programmatically Creating Flat File Schemas and Dictionaries Using this method Mapping Data Follow this procedure 1 Retrieve the existing information for the flat file dictionary from the Integration Server namespace by invoking the pub. see the webMethods Integration Server Built‐In Services Reference.xml:XMLNodeToDocument services.xml:documentToXMLString service.C.xml:xmlStringToXMLNode service to convert the XML string to an XML node. 5 Delete the existing flat file dictionary from the Integration Server namespace by invoking the pub.xml:xmlStringToXMLNode and pub. see the webMethods Integration Server Built‐In Services Reference.flatFile.generate:FFDictionary IS document type. This creates an IData object that conforms to the pub.flatFile.flatFile. The data is returned as an XML string in the FFXML variable. When you invoke this service: Set the makeArrays input variable to false. When you invoke this service: Set the encode input variable to true.generate:deleteFFDictionary service. For more information about the pub. 3 4 Map data to the IData object to make your changes. Set the documentTypeName input variable to pub. Invoke the pub. Create the flat file dictionary in the Integration Server namespace again by invoking the pub.generate:FFDictionary. Convert the IData object to an XML string by invoking the pub.xml:documentToXMLString service. To convert the XML string in the FFXML variable to an IData object: a b Invoke the pub.1 137 .generate:FFDictionary. 2 6 Flat File Schema Developer’s Guide Version 7.xml:XMLNodeToDocument service to convert the XML node to an IData object.generate:saveXMLAsFFDictionary service.flatFile. generate:getFFSchemaAsXML service and write it to an XML file. Delete the existing flat file schema from the Integration Server namespace by invoking the pub. see “Creating a Service that Retrieves the XML File” on page 140. For more information.xsd 2 3 Retrieve the contents of the XML file as an XML string.C. see “Retrieving Namespace Data to Write to an XML File” on page 141.generate:deleteFFSchema service. Delete the item from the namespace before invoking the appropriate service to write the changes back to the Integration Server namespace.flatFile. The XML file must conform to the XML schema: IntegrationServer_directory\packages\WmFlatFile\ pub\FFGeneration.1 138 .flatFile. Update the data for the flat file schema in the XML file. You make your modifications to the data. 4 5 Flat File Schema Developer’s Guide Version 7. For more information. The following describes the basic steps to modify a flat file schema either using an XML file or mapping data.flatFile. Create the flat file schema in the Integration Server namespace again by invoking the pub. Using this method XML File Follow this procedure 1 Retrieve the existing information for the flat file schema from the Integration Server namespace by invoking the pub. Programmatically Creating Flat File Schemas and Dictionaries Modifying an Existing Flat File Schema To modify an existing flat file dictionary or flat file schema.generate:saveXMLASFFSchema service. you first retrieve from the Integration Server namespace the item that you want to modify. see the webMethods Integration Server Built‐In Services Reference. To convert the XML string in the FFXML variable to an IData object: a b Invoke the pub. Set the documentTypeName input variable to pub. 2 6 Flat File Schema Developer’s Guide Version 7.generate:saveXMLASFFSchema service.flatFile. For more information about the pub.C. Set the documentTypeName input variable to pub.xml:XMLNodeToDocument services.xml:documentToXMLString service. 3 4 Map data to the IData object to make your changes.generate:getFFSchemaAsXML service. This creates an IData object that conforms to the pub.flatFile.generate:FFSchema IS document type.xml:xmlStringToXMLNode service to convert the XML string to an XML node. Invoke the pub.flatFile.xml:xmlStringToXMLNode and pub. Create the flat file schema in the Integration Server namespace again by invoking the pub.generate:FFSchema.flatFile. When you invoke this service: Set the makeArrays input variable to false. When you invoke this service: Set the encode input variable to true. Convert the IData object to an XML string by invoking the pub. For more information about the pub. 5 Delete the existing flat file schema from the Integration Server namespace by invoking the pub.flatFile.xml:XMLNodeToDocument service to convert the XML node to an IData object. Programmatically Creating Flat File Schemas and Dictionaries Using this method Mapping Data Follow this procedure 1 Retrieve the existing information for the flat file schema from the Integration Server namespace by invoking the pub.xml:documentToXMLString service. The data is returned as an XML string in the FFXML variable.generate:FFSchema. see the webMethods Integration Server Built‐In Services Reference.1 139 .generate:deleteFFSchema service.flatFile. file:getFile service to retrieve the XML file from the local file system. see the webMethods Integration Server Built‐In Services Reference. flat file dictionary entry entire flat file dictionary flat file schema Use this service to delete the item from the namespace pub. Sample code for retrieving data from an XML file 1 2 3 Flow Operation 1 Description Invoke the pub...C. Programmatically Creating Flat File Schemas and Dictionaries Deleting Flat File Dictionary Entries.generate:deleteFFDictionaryEntry pub.generate:deleteFFSchema Sample Flow Services for Working with XML Files This section shows sample flow services that show how to retrieve data from an XML file in the local file system and how to retrieve data from the Integration Server namespace that can be written to a file in the local file system. or flat file schema. The XML data must conform to the following XML schema: IntegrationServer_directory\packages\WmFlatFile\pub\ FFGeneration. you invoke the appropriate service.1 140 .xsd For more information about this service.flatFile.flatFile. Flat File Schema Developer’s Guide Version 7.flatFile. and Schemas To delete a flat file dictionary entry. For this item. entire flat file dictionary.generate:deleteFFDictionary pub. Dictionaries. Creating a Service that Retrieves the XML File The following shows a sample flow service for retrieving data from an XML file. flatFile. With the INVOKE saveXMLAsFFSchema flow operation selected. the flow service invokes the pub.string:bytesToString service to convert the file (in bytes format) to a String. or flat file schema. Invoke the appropriate service to make your changes to the Integration Server namespace. In this sample.generate:saveXMLASFFSchema service.1 141 . see the webMethods Integration Server Built‐In Services Reference. In this sample. 3 Retrieving Namespace Data to Write to an XML File The following shows a sample flow service that retrieves data from the Integration Server namespace that can be written to an XML file.generate:saveXMLASFFSchema to save the XML data as a flat file schema in the Integration Server namespace. For more information about this service. Flat File Schema Developer’s Guide Version 7.C. in the pipeline.flatFile. Sample code for retrieving namespace data that can be written to an XML file 1 2 3 Flow Operation 1 Description Invoke the appropriate service to retrieve the Integration Server namespace data for a flat file dictionary entry.string:bytesToString service to the FFXML input of the pub. entire flat file dictionary. Programmatically Creating Flat File Schemas and Dictionaries Flow Operation 2 Description Invoke the pub. the flow service invokes the pub.flatFile.generate:findDependants service to retrieve the data for an entire flat file dictionary. map the output from the pub. For more information about this service. in the pipeline.string:stringToBytes service to convert the namespace data (in String format) to a byte[]. 3 Add code to or invoke a service that you create to write the byte[] to an XML file. With the INVOKE stringToBytes flow operation selected.1 142 . Flat File Schema Developer’s Guide Version 7. Programmatically Creating Flat File Schemas and Dictionaries Flow Operation 2 Description Invoke the pub. map the FFXML output from the pub.C.generate:findDependants service to the input of the stringToBytes service.flatFile. see the webMethods Integration Server Built‐In Services Reference. setting 73 alternate code sets.1 143 . managing dependencies on 72 flat file schemas programmatically 140 fomat services. managing dependencies on 67 delimited field extractors 11 delimited records 11 delimiter record parser defined 36 properties 39 delimiters.Index Index A access permissions. flat file 78 D default records 18 deleteFFDictionary service 99 deleteFFDictionaryEntry service 100 deleteFFSchema service 100 deleting flat file dictionaries entries programmatically 140 flat file dictionaries programmatically 140 flat file dictionaries. field 65 C character position field extractor 11 choosing services to receive flat files 79 code list validator 64 code sets. flat file 78 conventions used in this document 7 converting flat file to IS document (IData) 27 converting IS document (IData) to flat file 31 convertToString service 90 convertToValues service 93 createDocumentType service 98 createFFDictionary service 99 creating flat file dictionaries 69 adding entries programmatically 131 programmatically 132 programmatically creating empty dictionaries 133 when to create 19 creating flat file schemas 36 configuring the structure 48 adding element definitions 49 adding element references 49 record definition properties 55 programmatically 133 setting up flat file schemas 36 specifying properties 41 B byte count validator. specifying 37 Flat File Schema Developer’s Guide Version 7. enabling use of 74 alwaysSortFields variable 74 content type. alternate enabling use of 74 composite defined 10 extractors 61 reusing definitions 18 concepts flat file dictionaries 18 flat file schemas 12 flat files 10 flat files supported 11 overview 10 conditional validators 62 configuration file alwaysSortFields variable 74 customizing 74 enableFormatting variable 66 spacePadJustifies variable 76 useAlternateCodeSets variable 74 useReadableDelimiterReporting variable 75 configuring flat file schema structure 48 adding element definitions 49 adding element references 49 record definition properties 55 constraint types in flat file schemas 12 content handler. cnf configuration file alwaysSortFields variable 74 customizing 74 enableFormatting variable 66 spacePadJustifies variable 76 useAlternateCodeSets variable 74 useReadableDelimiterReporting variable 75 FFDictionary IS document type 107 FFSchema IS document type 109 field defined 10 extractors 61 reusing definitions 18 sorting 74 validators 64 findDependants service 101 findReferences service 101 fixed length record parser defined 36 properties 40 fixed length records 11 flat file dictionaries creating 69 creating empty dictionaries programmatically 133 creating entries programmatically 131 creating programmatically 132 defined 18 deleting entries programmatically 140 deleting programmatically 140 editing 72 Flat File Schema Editor 19 identifying 20 modifying entries programmatically 134 modifying programmatically 136 retrieving data for from XML file 140 setting access permissions 73 flat file dictionary entries. flat file creating empty dictionaries programmatically 133 creating programmatically 132 deleting programmatically 140 managing dependencies on 72 modifying programmatically 136 retrieving data for from XML file 140 dictionary entries.Index delimiters. retrieving data for from XML file 140 Flat File Schema Editor 19 Flat File Defintion tab 20 Flat File Structure tab 20 Properties panel 21 flat file schemas constraints content type 12 structural 12 syntax rule 12 creating 36 creating programmatically 133 defined 12 deleting programmatically 140 editing 72 Flat File Schema Editor 19 identifying 20 identifying records 14 modifying programmatically 138 retrieving data for from XML file 140 Flat File Schema Developer’s Guide Version 7. flat file creating programmatically 131 deleting programmatically 140 modifying programmatically 134 retrieving data for from XML file 140 documentation additional 8 conventions used 7 feedback 8 E EDI record parser 37 editing an existing flat file schema or dictionary 72 elements 10 reusing definitions 18 extractors 61 F ff. using readable and non-readable delimiters 75 diagrams flat file processing 24 inbound conversion and validation 26 outbound conversion 31 dictionaries.1 144 . record 15 identifying flat file schema records 14 identifying flat file schemas and dictionaries 20 inbound flat file processing 25 default records 18 diagram 26 how to 26 large files 30 mapping data 27 parsing 26 undefined data 16 validation error codes 12 validation error contents 12 IS documents (IData objects). 32 diagram 31 how to 31 parsing 31 G getFFDictionaryEntryAsXML service 102 getFFSchemaAsXML service 102 getSupportedEncodings service 98 Flat File Schema Developer’s Guide Version 7.1 145 . inbound parsing 44 examples of. requirements to receive flat files 79 format services 66 creating 66 disabling 66 error messages 66 managing dependencies on 67 processing 25 FormatService service 88 H handling large flat files 30 iterator variable of convertToValues service 94 I identifiers. field 64 listFFDictionaryEntries service 103 M mapping flat file data 27 modifying flat file dictionaries entries programmatically 134 flat file dictionaries programmatically 136 flat file schemas programmatically 138 O outbound flat file processing 31.Index setting access permissions 73 testing 68 validation 12 flat file user interface See Flat File schema Editor flat files creating from IS documents (IData objects) 31 defined 10 mapping 27 processing 24 sending and receiving 78 content handler 78 content type 78 services for receiving 79 via a flow service 79 via a string variable 79 via e-mail 84 via file polling 84 via FTP 81 via HTTP 80 via Trading Networks 78 services 88 types supported 11 floating records behavior of 43 examples of. creating from flat files 26 L large flat file handling 30 iterator variable of convertToValues service 94 length validator. outbound parsing 47 specifying in flat file schema 41 flow services. generate:deleteFFDictionaryEntry service 100 pub.generate:findDependants service 101 pub.flatFile.flatFile.flatFile. 32 diagram 31 how to 31 parsing 31 processing IS documents (IData) 27 program code conventions in this document 7 programmatically create empty flat file dictionaries 133 create flat file dictionaries 132 create flat file dictionary entries 131 create flat file schemas 133 delete flat file dictionaries 140 delete flat file dictionary entries 140 delete flat file schemas 140 modify flat file dictionaries 136 modify flat file dictionary entries 134 modify flat file schemas 138 properties of flat file schemas. defined 36 records.generate:getFFDictionaryEntryAsXML service 102 pub.flatFile.generate:listFFDictionaryEntries service 103 pub.generate:findReferences service 101 pub. specifying 41 pub.flatFile.flatFile:convertToString service 90 pub.generate:FFSchema IS document type 109 pub.flatFile.flatFile.flatFile.Index P parsers.flatFile:FormatService service 88 pub.flatFile.generate:saveXMLAsFFDictionary service 103 pub.generate:FFDictionary IS document type 107 pub.generate:deleteFFDictionary service 99 pub. outbound parsing 47 specifying in flat file schema 41 reusing element definitions 18 Flat File Schema Developer’s Guide Version 7.generate:saveXMLASFFSchema service 104 pub.generate:deleteFFSchema service 100 pub.flatFile.flatFile:getSupportedEncodings service 98 R record default 18 defined 10 identifying 14 reusing definitions 18 record identifiers 15 records with no identifiers 18 record parsers 14.generate:createFFDictionary service 99 pub. floating behavior of 43 examples of. inbound parsing 44 examples of.1 146 .generate:updateFFDictionaryEntryFromXML service 106 pub.flatFile:convertToValues service 93 pub.flatFile.generate:createDocumentType service 98 pub.generate:getFFSchemaAsXML service 102 pub.flatFile.flatFile.flatFile. 36 delimiter defined 36 properties 39 EDI 37 fixed length defined 36 properties 40 general properties 37 specifying delimiters 37 variable length.flatFile. record 14 parsing inbound flat files 26 outbound flat files 31 position field extractors 11 posting a flat file via HTTP 80 processing flat files 24 diagram 24 format services 25 inbound 25 default records 18 diagram 26 how to 26 large files 30 mapping data 27 parsing 26 undefined data 16 validation error codes 120 validation error contents 116 outbound 31. flat file creating programmatically 133 deleting programmatically 140 modifying programmatically 138 retrieving data for from XML file 140 sending and receiving flat files content handler 78 content type 78 overview 78 services for receiving 79 via a flow service 79 via a string variable 79 via e-mail 84 via file polling 84 via FTP 81 via Trading Networks 78 setting access permissions 73 setting up flat file schemas 36 sorting order of fields in composites and records 74 spacePadJustifies variable 76 submitting a flat file via a string variable 79 submitting a flat file via e-mail 84 submitting a flat file via file polling 84 submitting a flat file via FTP 81 submitting a flat file via HTTPsending and receiving flat files via HTTP 80 U undefined data 16 updateFFDictionaryEntryFromXML service 106 updating flat file dictionaries entries programmatically 134 flat file dictionaries programmatically 136 flat file schemas programmatically 138 useAlternateCodeSets variable 74 useReadableDelimiterReporting variable 75 V validation defined 12 error codes 120 error contents 116 validators 62 conditional 62 field 64 byte count 65 code list 64 length 64 variable length record parser. defined 36 variable length records 11 W WmFlatFile package contents 87 flat file services 88 X XML files.flatFile.generateFFSchema:fixedLength service 113 saveXMLAsFFDictionary service 103 saveXMLASFFSchema service 104 schemas. retrieving data from 140 T testing flat file schemas 68 Trading Networks.1 147 .flatFile.generateFFSchema:delimited service 111 sample.Index S sample. sending flat files to 78 troubleshooting information 8 typographical conventions in this document 7 Flat File Schema Developer’s Guide Version 7. Index Flat File Schema Developer’s Guide Version 7.1 148 .
Copyright © 2025 DOKUMEN.SITE Inc.