White Paper. XML-Based Export and Import of Objects Using XSLT. Fabasoft Folio 2017 R1 Update Rollup 1

Similar documents
XSL Elements. xsl:copy-of

XSLT: How Do We Use It?

White Paper. Fabasoft Integration for Eclipse BIRT. Fabasoft Folio 2017 R1

Author: Irena Holubová Lecturer: Martin Svoboda

XSLT is... XML XSLT XSL-FO XPath

XSLT (part I) Mario Alviano A.Y. 2017/2018. University of Calabria, Italy 1 / 22

Computer Science E-259

White Paper. Fabasoft Folio Bulk Jobs. Fabasoft Folio 2017 R1 Update Rollup 1

XSL Transformation (XSLT) XSLT Processors. Example XSLT Stylesheet. Calling XSLT Processor. XSLT Structure

XSL and OU Campus. OmniUpdate User Training Conference OmniUpdate, Inc Flynn Road, Suite 100 Camarillo, CA 93012

XPath and XSLT. Overview. Context. Context The Basics of XPath. XPath and XSLT. Nodes Axes Expressions. Stylesheet templates Transformations

Dynamic Indexing with XSL

Exam : Title : XML 1.1 and Related Technologies. Version : DEMO

Generating Variants Using XSLT Tutorial

COP 4814 Florida International University Kip Irvine XSLT. Updated: 2/9/2016 Based on Goldberg, Chapter 2. Irvine COP 4814

Computer Science E-259

Extensible Markup Stylesheet Transformation (XSLT)

Advanced XSLT. Web Data Management and Distribution. Serge Abiteboul Ioana Manolescu Philippe Rigaux Marie-Christine Rousset Pierre Senellart

XML Wrap-up. CS 431 March 1, 2006 Carl Lagoze Cornell University

Extensions to XSLT 1.0, and XSLT 2.0

White Paper. Fabasoft Integration for Kofax Capture. Fabasoft Folio 2017 R1 Update Rollup 2

Advanced XSLT. Web Data Management and Distribution. Serge Abiteboul Philippe Rigaux Marie-Christine Rousset Pierre Senellart

XML. Objectives. Duration. Audience. Pre-Requisites

Generating Web Pages Using XSLT

Lars Schmidt-Thieme, Information Systems and Machine Learning Lab (ISMLL), University of Hildesheim, Germany, Course on XML and Semantic Web

Web Services Week 3. Fall Emrullah SONUÇ. Department of Computer Engineering Karabuk University

XSL extensible Style Language" DOCUMENTS MULTIMEDIA! Transforming documents using! XSLT" XSLT processor" XSLT stylesheet"

Introduction to XSLT. Version 1.3 March nikos dimitrakas

Advanced XSLT editing: Content query web part (CQWP) Dolev Raz SharePoint top soft Soft.co.il

XSLT. December 16, 2008

Semi-structured Data 11 - XSLT

White Paper. Export of Fabasoft Folio Objects to a Relational Database. Fabasoft Folio 2017 R1 Update Rollup 1

info-h-509 xml technologies Lecture 5: XSLT Stijn Vansummeren February 14, 2017

XPath and XSLT without the pain!

White Paper. Fabasoft Folio Access Definitions. Fabasoft Folio 2017 R1 Update Rollup 1

XML. <subtitle>xslt (cont)</subtitle> <author>prof. Dr. Christian Pape</author>

XML and XSLT. XML and XSLT 10 February

XPath Quick Reference

XSLT Programming Constructs

You need to install this note if you want to enable consolidation in Embedded Model for BPC NW 10.1 in Support Package 08 Patch01.

XML and Semantic Web Technologies. II. XML / 5. XML Stylesheet Language Transformations (XSLT)

The Transformation Language XSL

Functions & Conditional Statements

XSLT. Announcements (October 24) XSLT. CPS 116 Introduction to Database Systems. Homework #3 due next Tuesday Project milestone #2 due November 9

Introduction to XSLT. Version 1.0 July nikos dimitrakas

Appendix H XML Quick Reference

XSL Languages. Adding styles to HTML elements are simple. Telling a browser to display an element in a special font or color, is easy with CSS.

Web Data Management XSLT. Philippe Rigaux CNAM Paris & INRIA Saclay

<xsl:apply-templates select="atom:entry/atom:content"/> <xsl:copy-of xmlns:xsl="

Excel to XML v3. Compatibility Switch 13 update 1 and higher. Windows or Mac OSX.

EXAM XML 1.1 and Related Technologies TYPE: DEMO

Introduction to XSLT

Burrows & Langford Appendix D page 1 Learning Programming Using VISUAL BASIC.NET

6/6/2016 3:23 PM 1 of 15

Style Sheet A. Bellaachia Page: 22

Excel to XML v4. Version adds two Private Data sets

Term selector datatype

XSLT program. XSLT elements. XSLT example. An XSLT program is an XML document containing

Sample Text Point Instruction

White Paper. Creation of Online Help for Fabasoft Folio. Fabasoft Folio 2017 R1 Update Rollup 1

The Transformation Language XSL

XSLT (part II) Mario Alviano A.Y. 2017/2018. University of Calabria, Italy 1 / 19

Display the XML Files for Disclosure to Public by Using User-defined XSL Zhiping Yan, BeiGene, Beijing, China Huadan Li, BeiGene, Beijing, China

Presentation. Separating Content and Presentation Cascading Style Sheets (CSS) XML and XSLT

Manipulating XML Trees XPath and XSLT. CS 431 February 18, 2008 Carl Lagoze Cornell University

XML and Databases XSLT Stylesheets and Transforms

XSLT. Patryk Czarnik. XML and Applications 2014/2015 Lecture

4. Unit: Transforming XML with XSLT

TEST AND PILOT. Wim Kok SCOBDO

<xsl:variable name="g_ndstemplatedoc" select="document($g_strhtmltemplatename)"/>

XML. COSC Dr. Ramon Lawrence. An attribute is a name-value pair declared inside an element. Comments. Page 3. COSC Dr.

XSLT. Lecture 38. Robb T. Koether. Mon, Apr 21, Hampden-Sydney College. Robb T. Koether (Hampden-Sydney College) XSLT Mon, Apr 21, / 26

White Paper. Fabasoft Integration for CMIS. Fabasoft Folio 2016 Update Rollup 6

For personnal use only

Comp 336/436 - Markup Languages. Fall Semester Week 9. Dr Nick Hayward

INTERNET & WEB APPLICATION DEVELOPMENT SWE 444. Fall Semester (081) Module 4 (III): XSL

Paper for Consideration by the S-100 Working Group. S-100 Portrayal Support for Lua

Introduction to XSLT

IBM Research Report. Using XSLT to Detect Cycles in a Directed Graph

WebSphere DataPower SOA Appliances and XSLT (Part 2 of 2) - Tips and Tricks

White Paper. Fabasoft Integration for CalDAV. Fabasoft Folio 2017 R1 Update Rollup 2

Oracle Application Server 10g Oracle XML Developer s Kit Frequently Asked Questions September, 2005

4. Unit: Transforming XML with XSLT

XML and Databases. Lecture 11 XSLT Stylesheets and Transforms. Sebastian Maneth NICTA and UNSW

Programming issues 5.1 CONTROL STATEMENTS

EXAM IN SEMI-STRUCTURED DATA Study Code Student Id Family Name First Name

6/3/2016 8:44 PM 1 of 35

XSLT Version 2.0 is Turing-Complete: A Purely Transformation Based Proof

Advanced XQuery and XSLT

XML and Databases. Outline XML. XML, typical usage scenario XML. 1. extensible Stylesheet Language X M L. Sebastian Maneth NICTA and UNSW

DHANALAKSHMI COLLEGE OF ENGINEERING, CHENNAI

PASS4TEST. IT Certification Guaranteed, The Easy Way! We offer free update service for one year

XSDs: exemplos soltos

XML. XML Namespaces, XML Schema, XSLT

arxiv: v2 [astro-ph.im] 15 Jun 2009

Sub Templates in Oracle BI Publisher. An Oracle White Paper Aug 2009

SDN Community Contribution

Integrating data: Appendix F, G and H (full) GIMA Thesis. Ing. Huibert-Jan Lekkerkerk B.Sc.

White Paper. Fabasoft Folio Web Client Configuration Possibilities. Fabasoft Folio 2016 Update Rollup 6

Querying transformed XML documents: Determining a sufficient fragment of the original document

Transcription:

White Paper XML-Based Export and Import of Objects Using XSLT Fabasoft Folio 2017 R1 Update Rollup 1

Copyright Fabasoft R&D GmbH, Linz, Austria, 2018. All rights reserved. All hardware and software names used are registered trade names and/or registered trademarks of the respective manufacturers. No rights to our software or our professional services, or results of our professional services, or other protected rights can be based on the handing over and presentation of these documents. XML-Based Export and Import of Objects Using XSLT 2

Contents 1 Introduction 4 2 Software Requirements 4 3 Getting Started 4 4 Available XLST Based Actions 7 4.1 XSLTransformObject 7 4.2 XSLTransformToObject 7 4.3 XSLTransform 8 4.4 Using Parameters 9 5 Working With XSLT 10 6 Export 10 6.1 Simple Export 10 6.2 Data Types 11 7 Import 12 7.1 Simple Import 12 7.2 sys:value 13 7.2.1 Searching for Fabasoft Folio Objects 13 7.2.2 Selecting Fabasoft Folio Objects 14 7.2.3 Setting Values of Object Properties 14 8 XSLT Processing 17 8.1 XSLT Elements 17 8.2 XPath Evaluation 19 8.2.1 Limitations 19 8.2.2 Supported Functions 20 8.2.3 Additional Functions 20 8.2.4 sys:evaluate 21 XML-Based Export and Import of Objects Using XSLT 3

1 Introduction This document describes on the one hand how to export Fabasoft Folio objects to XML data and on the other hand how to create or update Fabasoft Folio objects based on XML data. To accomplish these goals XSLT based actions are provided. 2 Software Requirements System environment: All information contained in this document implicitly assumes a Microsoft Windows environment or a Linux environment. Supported platforms: For detailed information on supported operating systems and software see the software product information on the Fabasoft distribution media. 3 Getting Started All you need to get your first export and import running is contained in this chapter. Detailed information about the introduced approaches can be found in the following chapters. As prerequisite you need a Fabasoft Folio installation with Fabasoft app.ducx. More information about Fabasoft app.ducx can be found in the white paper An Introduction to Fabasoft app.ducx. Create a new app.ducx project (in this case TRANS@1.506) with a use case and user interface file. Additionally create two XSLT files (export.xsl and import.xsl) and for the import use case an example XML file (import.xml) is required. usecases TRANS@1.506 { import COOSYSTEM@1.1; import FSCVAPP@1.1001; import FSCVENV@1.1001; import FSCVIEW@1.1001; import COOXML@1.1; import GENCONT@1.1; app.ducx Use Case Language // the export should be invoked with a menu command menu usecase Export on selected { variant Object { impl = expression { // cooobj contains the object the user has selected // in a testing environment it is fast and easy to use files // at the end of this chapter an example for working with // objects instead is provided coouser.xsltransformobject(cooobj, "c:/trans/export.xsl", "c:/trans/result.xml"); // the import should be invoked with a menu command menu usecase Import direct { variant Object { impl = expression { coouser.xsltransformtoobject("c:/trans/import.xml", c:/trans/import.xsl"); app.ducx User Interface Language XML-Based Export and Import of Objects Using XSLT 4

userinterface TRANS@1.506 { import COOSYSTEM@1.1; import COOATTREDIT@1.1; import COODESK@1.1; import COOSEARCH@1.1; import FSCVAPP@1.1001; // the menu commands should be available in the Tools menu extend menu COODESK@1.1:MenuTools { entries = { MenuExport, MenuImport <?xml version="1.0" encoding="utf-8"?> <!-- the name of the object is exported --> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/xsl/transform" xmlns:sys="http://www.fabasoft.com/components/coosystem@1.1"> <xsl:output method="xml" version="1.0" encoding="utf-8" indent="yes" omit-xml-declaration="no" /> <xsl:template match="/"> <root> <objname> <xsl:value-of select="*/sys:objname" /> </objname> </root> </xsl:stylesheet> <?xml version="1.0" encoding="utf-8"?> <!-- folders are imported and the name and external key are set --> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/xsl/transform" xmlns:sys="http://www.fabasoft.com/components/coosystem@1.1" xmlns:desk="http://www.fabasoft.com/components/coodesk@1.1"> <xsl:output method="xml" version="1.0" encoding="utf-8" indent="yes" omit-xml-declaration="no" /> <xsl:template match="/"> <xsl:apply-templates select="/root/folder" /> <xsl:template match="folder"> <sys:value search="sys:objexternalkey" searchobjclass="desk:folder" create="desk:folder" match="literal"> <sys:objname select="name" /> <sys:objexternalkey select="externalkey" /> </sys:value> </xsl:stylesheet> export.xsl import.xsl import.xml <?xml version="1.0" encoding="utf-8"?> <!-- two folders should be imported --> <root> <folder> <name>projects</name> <externalkey>projects</externalkey> </folder> <folder> <name>year 2011</name> <externalkey>year2011</externalkey> </folder> </root> If you compile and run this project two menu commands are available at the end of the Tools menu. If you did not provide a multilingual name for the menus they will be called MenuExport XML-Based Export and Import of Objects Using XSLT 5

and MenuImport. Put the example files (export.xsl, import.xsl and import.xml) in the defined path on the server running the Fabasoft Folio Web Services. The import command will create two folder objects that can be searched for in Fabasoft Folio. The export command creates an XML file in the defined path. Working with files is nice for testing but if you do not have access to the file system or you want to set up a productive scenario, here is an extension of the above example: Add an object model file to the app.ducx project and define instances for the XSLT files. Put the two XSLT files (export.xsl and import.xsl) in the resources folder of the app.ducx project. Replace the use case file of the previous example with this one. objmodel TRANS@1.506 { import COOSYSTEM@1.1; import COOXML@1.1; app.ducx Object Model Language // creates a new instance of an XSLT used for export instance XSLTransformation ExportXSLTransformation { content = file("resources/export.xsl"); // creates a new instance of an XSLT used for import instance XSLTransformation ImportXSLTransformation { content = file("resources/import.xsl"); app.ducx Use Case Language usecases TRANS@1.506 { import COOSYSTEM@1.1; import FSCVAPP@1.1001; import FSCVENV@1.1001; import FSCVIEW@1.1001; import COOXML@1.1; import GENCONT@1.1; menu usecase Export on selected { variant Object { impl = expression { // will contain the result XML data content @resultxmlcont; // the fifth parameter is the out parameter // cooobj contains the object the user has selected // #ExportXSLTransformation is used as XSLT for the transformation @resultxmlcont = coouser.xsltransformobject(cooobj, #ExportXSLTransformation)[5]; // create a generic content object that will contain the result XML data GENCONT@1.1:ContentObject @resultxmlobj = #GENCONT@1.1:ContentObject.ObjectCreate()[2]; @resultxmlobj.content.contcontent = @resultxmlcont; @resultxmlobj.content.contextension = "txt"; @resultxmlobj.objname = "Result XML " + coort.getcurrentdatetime(cooobj); menu usecase Import on selected { variant COOSYSTEM@1.1:ContentObject { impl = expression { // it is assumed that the user selects a content object (cooobj) // containingk the source XML data // alternatively, you may provide a dialog for uploading an XML file coouser.xsltransformtoobject(cooobj, #ImportXSLTransformation); XML-Based Export and Import of Objects Using XSLT 6

By now you should have your first working example. Detailed explanations of the depicted approaches can be found in the following chapters. 4 Available XLST Based Actions Fabasoft Folio provides XSLT based actions for import and export. Additionally, an action for standard XSLT processing based on XML input and output is available. 4.1 XSLTransformObject XSLTransformObject is used to export objects to an XML document. COOXML@1.1:XSLTransformObject( any[] value, any[] xsltfile, optional string resultfile, optional dictionary parameter, optional out content resultcontent, optional COOXML@1.1:XMLParser xmlparser) Parameters: value Defines an arbitrary Fabasoft Folio object that should be transformed. : coort.getobject("coo.1.506.1.10126") xsltfile Defines the XSLT document used for the transformation. It can be a file path, a content or a content object. : "C:/trans/ExportXSLTransformation.xsl" (file path) #ExportXSLTransformation.content.contcontent (content) #ExportXSLTransformation (content object) resultfile Defines the file path of the result XML file. Alternatively, the result is stored in resultcontent, if this parameter is omitted. parameter Defines a dictionary that can contain options for the transformation. resultcontent Contains the result XML data, if the resultfile parameter is omitted. xmlparser Defines the XML parser that should be used. Available parsers are: XMLPARSER_DEFAULT, XMLPARSER_MSXML, XMLPARSER_LIBXML. Note: Keep in mind that the defined file paths belong to the server running the Fabasoft Folio Web Services. File paths may be useful in combination with temporary files. In a development and testing environment (when having access to the file system) it may fasten the development process. 4.2 XSLTransformToObject XSLTransformToObject is used to create or update objects from an XML document. XML-Based Export and Import of Objects Using XSLT 7

COOXML@1.1:XSLTransformToObject( any[] xmlfile, any[] xsltfile, optional string metaxmlfile, optional dictionary parameter, optional out content resultcontent, optional COOXML@1.1:XMLParser xmlparser) Parameters: xmlfile Defines the source XML document used for the transformation. It can be a file path, a content or a content object. xsltfile Defines the XSLT document used for the transformation. It can be a file path, a content or a content object. metaxmlfile Defines the file path of the meta XML file. Alternatively, the meta XML data is stored in resultcontent, if this parameter is omitted. The meta XML data is only a by-product of the transformation. Creating or modifying objects in Fabasoft Folio is the main purpose of the XSL transformation and not to transform the source XML to a target document. Thus the target document is called meta because it is technically needed for the XSLT process, but it is not the wanted result. parameter Defines a dictionary that can contain options for the transformation. resultcontent Contains the meta XML data, if the metaxmlfile parameter is omitted. xmlparser Defines the XML parser that should be used. Available parsers are: XMLPARSER_DEFAULT, XMLPARSER_MSXML, XMLPARSER_LIBXML. Note: XSLTransformToObject only provides a limited set of XSLT functionality. Within a property block (e.g. <sys:objname>my Name</sys:objname>) no xsl:if or xsl:when blocks are allowed. Keep in mind that the defined file paths belong to the server running the Fabasoft Folio Web Services. File paths may be useful in combination with temporary files. In a development and testing environment (when having access to the file system) it may fasten the development process. 4.3 XSLTransform XSLTransform is used to perform an XSL transformation using a standard XSLT processor. Input and output are based on XML. This action can also be used to pre-process XML input for XSLTransformToObject or post-process XML output from XSLTransformObject, because these actions only provide a limited set of XSLT functionality. COOXML@1.1:XSLTransform( any[] source, any[] transform, optional out content result, optional dictionary parameters, optional string filename) XML-Based Export and Import of Objects Using XSLT 8

Parameters: source Defines the source XML document used for the transformation. It can be a file path, a content or a content object. transform Defines the XSLT document used for the transformation. It can be a file path, a content or a content object. result Contains the XML data, if the filename parameter is omitted. parameters Defines a dictionary that can contain options for the transformation. filename Defines the file path of the XML file. Alternatively, the XML data is stored in result, if this parameter is omitted. 4.4 Using Parameters Both XSLTransformObject and XSLTransformToObject provide the possibility to use a parameters dictionary. The dictionary is available in the global scope when using the sys:evaluate function (see chapter 8.2.4 sys:evaluate ). Another way to access the dictionary is to define an xsl:param with the same name as the dictionary key. app.ducx Use Case Language menu usecase Export on selected { variant Object { impl = expression { // dictionary that should be available in the XSLT context dictionary @dict; @dict.key1 = "valuekey1"; coouser.xsltransformobject(cooobj, "c:/trans/export.xsl", "c:/trans/result.xml", @dict); export.xsl <?xml version="1.0" encoding="utf-8"?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/xsl/transform" xmlns:sys="http://www.fabasoft.com/components/coosystem@1.1"> <xsl:output method="xml" version="1.0" encoding="utf-8" indent="yes" omit-xml-declaration="no" /> <!-- make the dictionary key available as xsl:param --> <xsl:param name="key1" /> <xsl:template match="/"> <root> <approach1> <!-- use xsl:param --> <xsl:value-of select="$key1" /> </approach1> <approach2> <!-- use sys:evaluate and access the dictionary in the global scope --> <xsl:value-of select="sys:evaluate('::key1')" /> </approach2> </root> </xsl:stylesheet> XML-Based Export and Import of Objects Using XSLT 9

The output looks like this: result.xml <?xml version="1.0" encoding="utf-8" standalone="no"?> <root> <approach1>valuekey1</approach1> <approach2>valuekey1</approach2> </root> Note: In complicated cases it may be easier to transport the objects that have to be exported in the parameters dictionary. In this way you can classify and filter the objects beforehand in the app.ducx project and therefore remove complexity from the XSLT document. 5 Working With XSLT XSLT is used to transform Fabasoft Folio objects to XML data and vice versa. Further on basic knowledge of the XSLT and XPath concept is required. For example, consult http://www.w3schools.com/xsl/ and http://www.w3schools.com/xpath/ for more information about XSLT and XPath. The libxml2 parser used by Fabasoft Folio includes an implementation for the EXSLT module Strings that can be used for easier string manipulation. For more information consult http://www.exslt.org/. 6 Export 6.1 Simple Export The values of an exported Fabasoft Folio object can be accessed via XPath expressions. The following example has already been used in chapter 3 Getting Started to export the name of an object. <?xml version="1.0" encoding="utf-8"?> <!-- the name of the object is exported --> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/xsl/transform" xmlns:sys="http://www.fabasoft.com/components/coosystem@1.1"> <xsl:output method="xml" version="1.0" encoding="utf-8" indent="yes" omit-xml-declaration="no" /> <xsl:template match="/"> <root> <objname> <xsl:value-of select="*/sys:objname" /> </objname> </root> </xsl:stylesheet> export.xsl Explanation: xmlns:sys="http://www.fabasoft.com/components/coosystem@1.1" Defines the sys namespace to make component objects from COOSYSTEM@1.1 accessible with this prefix. XML-Based Export and Import of Objects Using XSLT 10

<xsl:template match="/"> The template matches the root node ( / ) that contains the exported object as child. <xsl:value-of select="*/sys:objname" /> * selects all children of the current node. The current node is the root node (as defined by the match="/" statement). The root node has only one child, the exported object. xsl:value-of prints out the value of COOSYSTEM@1.1:objname of the exported object. The result XML file looks like this: Result <?xml version="1.0" encoding="utf-8" standalone="no"?> <root> <objname>my Object</objname> </root> result.xml 6.2 Data Types How to access the data of properties depends on the data types of the properties. Data Type XSLT Result string <xsl:value-of select="*/sys:objname" /> my string integer <xsl:value-of select="*/sys:objactversnr" /> 13 float <xsl:value-of select="*/term:averagescore" /> 3.49 boolean <xsl:value-of select="*/sys:objversnopurge" /> 0 datetime <xsl:value-of select="*/sys:objactverscreated" /> 2011-08- 10T 12:12:13 object pointer <xsl:value-of select="*/sys:objcreatedby/sys:usersurname"/> Jones enumeration <xsl:value-of select="*/folio:perssex" /> 2 compound <xsl:value-of select="*/sys:objlock/sys:objlocked" /> 0 currency <xsl:value-of select="*/my:sum/sys:currsymbol" /> <xsl:value-of select="*/my:sum/sys:currvalue" /> 4 39000 list data types <xsl:for-each select="*/sys:objchildren"> <xsl:value-of select="sys:objname" /> </xsl:for-each> Pictures Documents Further explanations: If the property has no value an empty string is returned. If a part of the XPath has no value, an empty string is returned for the whole XPath. XML-Based Export and Import of Objects Using XSLT 11

Boolean properties return 0 if false, 1 if true and an empty string if undefined. Properties of objects referenced in object pointers can be accessed via XPath expressions. To each Fabasoft Folio enumeration entry an integer value is assigned. Enumerations return the integer value of the selected enumeration entry. Properties of compound types can be accessed via XPath expressions. Currency consists of two properties. The property currvalue contains the value. The enumeration currsymbol contains the currency symbol. Note: In some cases it might be useful to replace the integer enumeration value with the enumeration reference ( USD instead of 0, or EUR instead of 1 and so on). An example on how to achieve this can be found in chapter 8.2.4 sys:evaluate ). For the data types also corresponding list data types exist. Lists may be looped with xsl:foreach or entries can be accessed by specifying the index: <xsl:value-of select="*/sys:objchildren[1]" /> (returns the first entry in the list) 7 Import 7.1 Simple Import Based on a source XML document objects are created or updated. The following example has already been used in chapter 3 Getting Started to import two folders. <?xml version="1.0" encoding="utf-8"?> <!-- folders are imported and the name and external key are set --> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/xsl/transform" xmlns:sys="http://www.fabasoft.com/components/coosystem@1.1" xmlns:desk="http://www.fabasoft.com/components/coodesk@1.1"> <xsl:output method="xml" version="1.0" encoding="utf-8" indent="yes" omit-xml-declaration="no"/> <xsl:template match="/"> <xsl:apply-templates select="/root/folder"/> <xsl:template match="folder"> <sys:value search="sys:objexternalkey" searchobjclass="desk:folder" create="desk:folder" match="literal" > <sys:objname select="name"/> <sys:objexternalkey select="externalkey"/> </sys:value> </xsl:stylesheet> <?xml version="1.0" encoding="utf-8"?> <!-- two folders should be imported --> <root> <folder> <name>projects</name> <externalkey>projects</externalkey> </folder> <folder> <name>year 2011</name> <externalkey>year2011</externalkey> </folder> </root> import.xsl import.xml Explanation: XML-Based Export and Import of Objects Using XSLT 12

xmlns:xsl="http://www.w3.org/1999/xsl/transform" xmlns:sys="http://www.fabasoft.com/components/coosystem@1.1" xmlns:desk="http://www.fabasoft.com/components/coodesk@1.1" Define the needed namespaces. xsl and sys are mandatory. In this case also the prefix desk is defined because the component object COODESK@1.1:Folder belongs to COODESK@1.1. <xsl:template match="/"> <xsl:apply-templates select="/root/folder"/> Apply templates to all folder nodes in import.xml. <xsl:template match="folder"> <sys:value search="sys:objexternalkey" searchobjclass="desk:folder" create="desk:folder" match="literal" > <sys:objname select="name"/> <sys:objexternalkey select="externalkey"/> </sys:value> For each folder a corresponding object with the same objexternalkey is searched. If no folder is found a new one is created. The properties objname and objexternalkey are set based on data in the import.xml. More information about sys:value can be found in chapter 7.2 sys:value. Note: In most cases it makes sense to work with the property COOSYSTEM@1.1:objexternalkey to identify imported and exported objects. 7.2 sys:value The sys:value block is used as starting point to redirect the output to a Fabasoft Folio object. Instead of writing to the meta XML file, properties of created or found objects are set. 7.2.1 Searching for Fabasoft Folio Objects sys:value is used to search for objects in Fabasoft Folio that match the defined criteria. If no object is found a new one is created. Syntax <sys:value search="[prop1] [prop2] [...]" searchobjclass="[objclass]" create="[objclass]" match="[literal pattern]"> Explanation: search Defines properties to restrict the search. If several properties are defined they are combined with AND. The properties used for search have to be defined within the sys:value block (e.g. <sys:objexternalkey select="externalkey"/>). searchobjclass Defines the object class to be searched for. create Defines the object class that is used to create new objects if no object matches the search criteria. match May have two values: literal and pattern. literal is translated to = in the Fabasoft app.ducx Query Language. pattern is translated to LIKE in the Fabasoft app.ducx Query Language. XML-Based Export and Import of Objects Using XSLT 13

<sys:value search="sys:objexternalkey" searchobjclass="desk:folder" create="desk:folder" match="literal" > <sys:objname select="name"/> <sys:objexternalkey select="externalkey"/> </sys:value> // the resulting query translated in Fabasoft app.ducx Query Language SELECT * FROM COODESK@1.1:Folder WHERE.COOSYSTEM@1.1:objexternalkey = 'projects' <sys:value search="sys:objexternalkey sys:objname" searchobjclass="desk:folder" create="desk:folder" match="pattern" > <sys:objname select="name"/> <sys:objexternalkey select="externalkey"/> </sys:value> // the resulting query translated in Fabasoft app.ducx Query Language SELECT * FROM COODESK@1.1:Folder WHERE.COOSYSTEM@1.1:objexternalkey LIKE 'projects' AND.COOSYSTEM@1.1:objname LIKE 'Projects' 7.2.2 Selecting Fabasoft Folio Objects Beside searching for objects, objects can also be selected using sys:value. Syntax <sys:value select="sys:getobject('[objaddress]')"> Explanation: select Has to return a valid Fabasoft Folio object. <sys:value select="sys:getobject('coo.1.506.1.1127')"> <sys:objname select="name"/> <sys:objexternalkey select="externalkey"/> </sys:value> 7.2.3 Setting Values of Object Properties There are several types of properties and several ways to set a value. Note: Properties that are updated with invalid values are set empty. Properties can be set empty when using empty values in the import XML file (e.g. <done></done>). 7.2.3.1 Ways to Set a Value Static value: The tag consists of the name of the property to be set. <sys:objname>my Name</sys:objname> XML-Based Export and Import of Objects Using XSLT 14

Value from an XML document: The tag consists of the name of the property to be set and a select attribute. In the select attribute the XPath to value in the source XML is defined. <sys:objname select="name"/> Value evaluated with a Fabasoft app.ducx Expression: The value is evaluated with the sys:evaluate function. Make sure to use disable-outputescaping="yes", because the output should be as it is without modification. <sys:objname select="sys:evaluate('"simple evaluated name"')" disableoutput-escaping="yes"/> <sys:objname select="sys:evaluate('::key1')" disable-output-escaping="yes"/> Value evaluated with a Fabasoft app.ducx Expression Using an XML Node: The value is evaluated with the sys:evaluate function with these parameters: sys:evaluate('[arbitrary expression]', [arbitrary xpath],., 'name')" All child nodes of the node defined by the arbitrary XPath are available in the global scope and can be accessed with the node s name. Make sure to use disable-output-escaping="yes", because the output should be as it is without modification. // if the current node is currencysymbol you have access to ::value and ::symbol // in this case it is used to evaluate the corresponding integer value of EUR // because the enumeration can only be set with the integer value <sys:currsymbol select="#currencysymbol.typeenumvalues[typeenumref==::symbol]. typeenumval',./*,.,'name')" disable-output-escaping="yes" /> <currencysymbol> <value>203.56</value> <symbol>eur</symbol> </currencysymbol> import.xml 7.2.3.2 Data Types The following example provides an overview on how to set values depending on the data type of the properties. objmodel TRANS@1.506 { app.ducx Object Model Language XML-Based Export and Import of Objects Using XSLT 15

import COOSYSTEM@1.1; import COOXML@1.1; enum EnumTest { ET_ENTRY1, ET_ENTRY2, ET_ENTRY3 struct CompoundTest { string ctprop1; string ctprop2; // defines a test class with several properties of different data types class Test : BasicObject { string str; integer int; float flo; boolean boo; datetime dt; Object op; EnumTest et; CompoundTest ct; currency curr; currency currsymb; Object[] opl; import.xsl <?xml version="1.0" encoding="utf-8"?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/xsl/transform" xmlns:sys="http://www.fabasoft.com/components/coosystem@1.1" xmlns:t="http://www.fabasoft.com/components/trans@1.506"> <xsl:output method="xml" version="1.0" encoding="utf-8" indent="yes" omit-xml-declaration="no" /> <xsl:template match="/"> <xsl:apply-templates select="/root/object" /> <xsl:template match="object"> <sys:value search="sys:objexternalkey" searchobjclass="t:test" create="t:test" match="literal"> <!-- shows how to set values of properties with different data types --> <sys:objname select="name" /> <sys:objexternalkey select="externalkey" /> <t:str select="string" /> <t:int select="integer" /> <t:flo select="float" /> <t:boo select="boolean" /> <t:dt select="datetime" /> <t:op select="sys:evaluate('coort.getobject(::this)', objectpointer)" /> <t:et select="enumeration" /> <t:ct> <t:ctprop1 select="compound/value1" /> <t:ctprop2 select="compound/value2" /> </t:ct> <t:curr> <sys:currvalue select="currency/value" /> <sys:currsymbol select="currency/symbol" /> </t:curr> <t:currsymb> <sys:currvalue select="currencysymbol/value" /> <sys:currsymbol select="sys:evaluate('#currencysymbol.typeenumvalues [typeenumref==::symbol].typeenumval',./currencysymbol/*,.,'name')" disable-output-escaping="yes" /> </t:currsymb> XML-Based Export and Import of Objects Using XSLT 16

<xsl:for-each select="list/value"> <t:opl select="sys:evaluate('coort.getobject(::this)',.)" /> </xsl:for-each> </sys:value> </xsl:stylesheet> import.xml <?xml version="1.0" encoding="utf-8"?> <root> <object> <name>data Types</name> <externalkey>datatypes5</externalkey> <string>test</string> <integer>79</integer> <float>50.6</float> <boolean>1</boolean> <datetime>2012-08-11t10:12:13</datetime> <objectpointer>coo.1.506.1.1001242</objectpointer> <enumeration>2</enumeration> <compound> <value1>project</value1> <value2>097845</value2> </compound> <currency> <value>500</value> <symbol>1</symbol> </currency> <currencysymbol> <value>203.56</value> <symbol>eur</symbol> </currencysymbol> <list> <value>coo.1.506.1.1001242</value> <value>coo.1.506.1.1001241</value> </list> </object> </root> 8 XSLT Processing The actions COOXML@1.1:XSLTransformObject and COOXML@1.1:XSLTransformToObject operate based on a virtual XML source and target document representing object data in Fabasoft Folio. In order to provide this functionality, Fabasoft Folio implements a subset of XSLT that does not cover all aspects of the standard and shows different behavior in some cases. This chapter provides information on limitations as well as new functionality resulting from this. If more XSLT functionality is required, XML input/output of these actions should be pre-/postprocessed using COOXML@1.1:XSLTransform. 8.1 XSLT Elements For object-based transformations, the following elements and attributes are supported: xsl:stylesheet xsl:include o href xsl:template o match o mode XML-Based Export and Import of Objects Using XSLT 17

o name o priority xsl:value-of o disable-output-escaping o select xsl:apply-templates o mode o select xsl:call-template o mode o name xsl:for-each o select xsl:output o encoding o indent o omit-xml-declaration o standalone o version xsl:param o name o select xsl:if o test xsl:choose xsl:when o test xsl:otherwise xsl:with-param o name o select xsl:sort o datatype o order o select xsl:attribute o name o namespace xsl:element o name o namespace xsl:call-template o mode o name xsl:text o disable-output-escaping XML-Based Export and Import of Objects Using XSLT 18

xsl:number o format o value xsl:variable o name o select 8.2 XPath Evaluation In the context of COOXML@1.1XSLTransformObject and COOXML@1.1:XSLTransformToObject, Fabasoft Folio evaluates XPath expressions based on object data rather than XML data depending on the XSLT context. In case of COOXML@1.1XSLTransformObject, XPath expressions specified in XSLT elements are evaluated based on object data. Object properties can be accessed directly using XPath expressions. <xsl:template match="/"> <name><xsl:value-of select="sys:value/sys:objname" /></name> In case of COOXML@1.1XSLTransformToObject, XPath expressions specified in XSLT elements are evaluated based on XML input data unless elements are generated that represent object data and disable-output-escaping is enabled. <sys:value...> <sys:objsubject select="name" disable-output-escaping="yes" /> </sys:value> 8.2.1 Limitations For object-based transformations, XPath expressions evaluated based on XML input and used with xsl:if or xsl:when must return a list of XML elements rather than a Boolean value. <!-- Test for person elements with degree and no publications --> <xsl:template match="person"> <!-- NOT OK --> <xsl:if test="degree and not(publication)"> </xsl:if> <!-- OK --> <xsl:if test="self::node()[degree and not(publication)]"> </xsl:if> XML-Based Export and Import of Objects Using XSLT 19

8.2.2 Supported Functions If XPath expressions are evaluated in an object context, the following standard XPATH functions are supported: boolean ceiling concat contains count document false floor generate-id id lang last local-name name namespace-uri normalize-space not number position round starts-with string string-length substring substring-after substring-before sum translate true 8.2.3 Additional Functions Fabasoft Folio provides additional XPath functions that can be used in XSLT elements allowing the specification of an XPath expression (e.g. xsl:value-of) in an object context. <xsl:value-of select="sys:getcurrentuser()" /> <sys:objname select="sys:getcurrentuser()" disable-output-escaping="yes" /> The following XPath functions are available: GetObject(string address) XML-Based Export and Import of Objects Using XSLT 20

GetLanguage(string reference) GetSoftwareProduct(string reference) GetSoftwareComponent(string reference) GetObjectClass(string reference) GetTypeDefinition(string reference) GetAttributeDefinition(string reference) GetCurrentDateTime() GetCurrentDomain() GetCurrentUser() GetCurrentUserEnvironment() GetCurrentUserRoot() GetCurrentUserLanguage() GetCurrentUserRoleGroup() GetCurrentUserRolePosition() GetCurrentUserRoleSubstUser() NodeAttributeDefinition(string node) Evaluate(string expression, optional string globalxpath, optional string localxpath) HasClass(string objaddress, string objclassaddress) IsClass(string objaddress, string objclassaddress) GetReference(optional string objaddress) GetName(optional string objaddress) FormatDate(optional date value, optional string formatpattern) FormatTime(optional time value, optional string formatpattern) 8.2.4 sys:evaluate With the Fabasoft Folio XPath function sys:evaluate it is possible to evaluate Fabasoft app.ducx Expressions. Additionally to the mandatory expression parameter two more parameters (globalxpath and localxpath) may be defined. The parameters can contain an XPath and the values are accessible within the expression with ::this and :>this. // a simple expression is executed <xsl:value-of select="sys:evaluate('coort.getversion()')" /> // the optional parameters are used within the expression <xsl:value-of select="sys:evaluate('"name: " + ::this + " Key: " + :>this', */sys:objname, */sys:objexternalkey)" /> // for enums the integer identifier is returned by default // in this way it is possible to print out the enum reference by using globalxpath <xsl:value-of select="sys:evaluate('#currencysymbol.typeenumvalues[typeenumval==::this]. typeenumref', */my:sum/sys:currsymbol)" /> The result may look like this: Result // version 1127 XML-Based Export and Import of Objects Using XSLT 21

// parameters Name: Projects Key: projects // currency USD XML-Based Export and Import of Objects Using XSLT 22