Friday, December 22, 2023

XSLT Overview

XSLT, or eXtensible Stylesheet Language Transformations, is a language used to transform XML documents into different formats. It is a part of the XML family of technologies and is widely used for various purposes such as converting XML data into HTML, plain text, or other XML formats, as well as for data manipulation and extraction.

Key Components of XSLT:

XML Input Document:

XSLT transformations start with an XML document, which serves as the input data that needs to be transformed.

XSLT Stylesheet:

An XSLT stylesheet is a separate XML document that contains transformation rules written in XSLT. The stylesheet defines how the input XML document should be transformed into the desired output format.

Templates:

XSLT transformations are guided by templates. Templates specify how elements and other nodes in the XML document should be transformed. XSLT processors use these templates to match elements in the input XML and apply the specified transformations.

XPath:

XPath is used within XSLT to navigate XML documents and select nodes for processing. It allows for precise targeting of elements, attributes, and other XML nodes within the XSLT templates.

Output Specification:

XSLT allows you to define the structure and format of the output document. This can be HTML, XML, text, or any other format. XSLT provides elements and attributes to specify the structure of the output document.

Basic Structure of an XSLT Stylesheet:

An XSLT stylesheet typically consists of templates, which define how specific elements or patterns in the input XML document should be transformed. Here's the basic structure of an XSLT stylesheet:

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <!-- Template for matching a specific element -->
  <xsl:template match="elementName">
    <!-- Transformation rules for 'elementName' -->
  </xsl: template>
  <!-- More templates can be defined for different elements or patterns -->
</xsl:stylesheet>

Example of an XSLT Transformation:

Consider the following XML input:

<person>
  <name>John Doe</name>
  <age>30</age>
</person>

An XSLT stylesheet to transform this XML into an HTML paragraph might look like this:

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:template match="person">
    <p>
      Name: <xsl:value-of select="name"/><br/>
      Age: <xsl:value-of select="age"/>
    </p>
  </xsl:template>
</xsl:stylesheet>

In this example, the <xsl: template> element matches the <person> element in the input XML. The <xsl:value-of> elements are used to extract the values of <name> and <age> elements, transforming the data into an HTML paragraph.

XSLT is a powerful tool for transforming and manipulating XML data, allowing for the conversion of complex XML structures into various output formats. It is widely used in web development, data integration, and document processing applications. 

The <xsl:stylesheet> element is the root element of every XSLT language document. 

<xsl:stylesheet
id = identifier+
version =number
xmlns:xsl ="http://www.w3.org/1999/XSL/Transform"
extension-element-prefixes=list-of-prefixes
exclude-result-prefixes=list-of-prefixes>top-level-element*
</xsl:stylesheet>

The attributes in the above syntax are:

id: Represents the name to a stylesheet and identify a stylesheet. This attribute also helps in importing a stylesheet into another XSLT document. This attribute is optional.

version: Specifies the version number of the XSLT.

xmlns:xsl: Enables you to identify the XSLT stylesheet. Within a stylesheet element, the default namespace uri http://www.w3.org/1999/XSL/Transform is used.

extension-element-prefixes: This enables you to identify an extension element. You should separate the value of the elements by white spaces.

Example:
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xalan="org.apache.xalan.xslt.extensions.Redirect"
extension-element-prefixes="xalan" version="1.0">

Instead of the <xsl: stylesheet> element, you can also use the <xsl: transform> element to transform the XSLT document. The syntax for the <xsl: transform> element is:

<xsl:transform
    id =identifier
    version="1.0"
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    extension-elements-prefixes=list-of-prefixes
    exclude-result-prefixes=list-of-prefixes >
    top-level-element*
</xsl:transform> 
  • XSLT is a declarative language, which describes the relationship among variables in terms of functions and rules. 

  • XSLT contains several elements that help select data from an XML document, apply a template to the retrieved data, and generate the required output format. 

  • XSLT is a template-based or rule-based language. 

  • In XSLT, you can obtain an output when the pattern is matched with the data in XML documents.

  •  tag <XSL: for-each-group> enables you to group items by values and group in a sequence. 

The Node Tree

the node tree is a bunch of nodes arranged in a tree. Nodes are a general term for the components of an XML document, such as

Element nodes

Attribute nodes

Text nodes

Comment nodes

Processing-instruction node

the nodes that an element contains are called its children and an element node is its children's parent. Similarly, all the children of an element node are siblings. 

At the very top of the node tree is the root node.

 ELEMENT NODE

  • <xsl:element name={QName} namespace={uri} use-attribute-sets = list-of-Qnames> template body </xsl:element>

    The attributes in the syntax are:

    • name: Specifies the name of an element that has to be created in the resultant document. Qname indicates that the name of the element should be a qualified one.

    • namespace: Contains the Uniform Resource Identifier (URI) specific to the prefix in the Qname of name attribute. If there is no prefix for Qname, the value of the namespace will be null.

    • use-attribute-sets: Indicates the list of attribute names to be used by the element.

    Naming Conventions

    Names are used in several places in XML, the most important of which are element names, attribute names, and entity names. In general, the names that you use in XML only have to follow a few rules:

    • Names can contain letters, digits, hyphens (-), periods (.), colons (:), or underscores (_), but they must start with a letter, colon, or underscore.

    • Names cannot start with xml in any case combination (that is, they can't start with XML or Xml either) as these names are reserved for XML standards from the W3C.

    • Names should only use a colon if they use namespaces, which are ways of indicating the markup language that a particular element or attribute comes from. 

    Valid and Invalid XML Names

    Invalid XML Names

    Valid XML Names

    2nd

    second

    XmlDoc

    Doc

    tv:castlist:member

    tv.castlist.member

Attributes in XML
XML attributes are name-value pairs located within an element's start tag.
You can use either single or double quotes for any particular attribute value.

Like element names, attribute names must be valid XML names. However, unlike elements,
some attributes are built in to XML:
  • xml:lang—Indicates the language of the element, its attributes, and its contents

  • xml:space—Controls whether whitespace is retained (preserve) or dealt with by the application (default)

  • xml:base—Provides the base URI for the element, its attributes, and its contents

  • xml:id—Assigns a unique ID to the element, which can then be used for linking to that element

Other Components of XML

There are three other components of XML documents :

  • Comments

  • Processing instructions

  • CDATA sections

Comments

They start with the characters <!-- and end with the characters -->
Comments can go just about anywhere in the document body, but not inside a start tag or an end tag, nor within an empty element tag. You can even spread a comment over several lines if you wish.

Processing Instructions

 Processing instructions start with <?, are immediately followed by a name and then some content, and end with ?>.

Summary

Processing instructions can control the processing of an XML document.

CDATA Sections

CDATA stands for "character data," and a CDATA section indicates that a piece of text only contains characters, so the meaning of the characters is no longer significant. 

CDATA sections begin with the special series of characters <![CDATA[ and end with the sequence ]]>.

CDATA sections are a way of saving you from having to escape characters using entities.

Summary

The <xsl:value-of> instruction gives the result of evaluating the XPath held in its select attribute as some text in the result document.

The <xsl:value-of> element usually takes an attribute called select. 

qualified name or QName for short—a name that is qualified by the namespace to which the element or attribute belongs. 
 If a qualified name contains a colon (:), then the part before the colon indicates a namespace prefix. The part after the colon is known as the local part or local name of the element. 

 So in the case of <xsl:value-of>, the prefix is xsl and the local part is value-of.

Functions : function()

elements : <element>

variables as $variable.

  • type: Indicates the type of link, such as simple, extended, locator, arc, resource, and title.

  • href: Indicates the location of a Uniform Resource Identifier (URI).

The <xsl:stylesheet> element is the root element of every XSLT language document.

  • <xsl:stylesheet id = identifier+ version =number xmlns:xsl ="http://www.w3.org/1999/XSL/Transform" extension-element-prefixes=list-of-prefixes exclude-result-prefixes=list-of-prefixes>top-level-element* </xsl:stylesheet>

  • The attributes in the above syntax are:

    • id: Represents the name to a stylesheet and identify a stylesheet. This attribute also helps in importing a stylesheet into another XSLT document. This attribute is optional.

    • version: Specifies the version number of the XSLT.

    • xmlns:xsl: Enables you to identify the XSLT stylesheet. Within a stylesheet element the default namespace uri http://www.w3.org/1999/XSL/Transform is used.

    • extension-element-prefixes: This enables you to identify an extension element. You should separate the value of the elements by white spaces.


FileAdapter- Operation ListFile

FileAdapter- Operation ListFile

The "List Files" operation in a File Adapter is used to retrieve a list of files from a specified directory. This operation is part of the File Adapter functionality in Oracle SOA Suite or Oracle Service Bus, and it allows integration developers to work with files in file systems as part of their business processes or services.

Here's an overview of how the "List Files" operation works:

Configuration:

Before using the "List Files" operation, you need to configure the File Adapter with the necessary settings, such as the directory path, file name patterns, and other relevant parameters.

Operation:

The "List Files" operation, as the name suggests, is used to list the files present in a specified directory. When you invoke this operation, it queries the file system and returns a list of file names that match the specified criteria.

Input Parameters:

The operation typically takes input parameters such as the directory path, file name patterns (wildcards), and other criteria for listing files. These parameters allow you to filter the list of files based on specific conditions.

Output:

The output of the "List Files" operation is a collection of file names that meet the specified criteria. The list can then be processed further in your integration flow.

Use Cases:

This operation is useful in scenarios where you need to process multiple files in a directory, for example, picking up all files that match a certain naming pattern or files modified after a specific date.

Error Handling:

As with any operation, it's important to implement error handling to deal with potential issues, such as connectivity problems or invalid directory paths.

Here's a simplified example of using the "List Files" operation in BPEL (assuming Oracle SOA Suite):

xml:

<bpel:invoke name="ListFiles" partnerLink="FileAdapterPL" operation="listFiles">

  <bpel:inputVariable name="inputVariable">

    <!-- Specify input parameters for listing files -->

  </bpel:inputVariable>

  <bpel:outputVariable name="outputVariable" />

</bpel:invoke>

In this example, FileAdapterPL is the partner link to the File Adapter, and the listFiles operation is invoked to retrieve a list of files based on the specified criteria. The result is stored in the outputVariable for further processing in the BPEL process.



Saturday, September 23, 2023

XSLT if Condition | xsl:if syntax

 xsl:if

The xsl:if element is used in XSLT (Extensible Stylesheet Language Transformations) to conditionally process nodes in an XML document. It evaluates a specified condition, and if the condition is true, it processes the content within the <xsl:if> element. If the condition is false, the content is skipped.

XSLT contains a set of elements to perform conditional and iterative processing. 

The <xsl:if> element performs conditional processing and is similar to the if statement in other programming languages. 

<xsl:choose>, <xsl:when>, and <xsl:otherwise>, for conditional processing. 

XSLT uses the <xsl:for-each> element for iterative processing. This element is similar to the do-while or for statements in other programming languages. 

The <xsl:copy> and <xsl:copy-of> elements enable you to copy nodes in the source document to the resultant document.

<xsl:if> Element

You can compare conditions in an XSLT stylesheet using the <xsl-if> element. 
The <xsl:if> element returns a Boolean value, which you can use in a template.
 this element conditionally selects a particular node from the source document.

The syntax for the <xsl:if> element is:

<xsl:if test ="expression"> template body </xsl:if>
<xsl:if test="condition"> <!-- Content to be processed if the condition is true --> </xsl:if>
 test: the test attribute compares strings, numeric values, node-sets, and child nodes of the document tree.This attribute specifies the condition to be evaluated. If the condition evaluates to true, the content inside the <xsl:if> element is processed. If it evaluates to false, the content is ignored.
The <xsl:if> element enables you to check the source tree for a particular element before transforming a source document to a resultant document.  This element also checks the attributes of an element in a source tree.
Ex:<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">  <xsl:template match="person">    <xsl:if test="age &lt; 18">      <xsl:text>Child: </xsl:text>      <xsl:value-of select="name"/>    </xsl:if>  </xsl:template></xsl:stylesheet>

In this example, the XSLT stylesheet processes XML data containing <person> elements and checks if the <age> element within each <person> is less than 18. If the condition is true (i.e., the person is a child), it outputs "Child: " followed by the person's name.


xsl-if Example scenario

 The syntax for the <xsl:if> element is:

<xsl:if test="condition"> <!-- Content to be processed if the condition is true --> </xsl:if>
test: This attribute specifies the condition to be evaluated. If the condition evaluates to true, the content inside the <xsl:if> element is processed. If it evaluates to false, the content is ignored.
Ex:<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">  <xsl:template match="person">    <xsl:if test="age &lt; 18">      <xsl:text>Child: </xsl:text>      <xsl:value-of select="name"/>    </xsl:if>  </xsl:template></xsl:stylesheet>
In this example, the XSLT stylesheet processes XML data containing <person> elements and checks if the <age> element within each <person> is less than 18. If the condition is true (i.e., the person is a child), it outputs "Child: " followed by the person's name.

If these fields are optional in the source and target, it is a good practice to insert an xsl:if statement around these mappings to test for the existence of the source node.

Yes, it is a good practice to use xsl:if statements or similar conditional constructs when dealing with optional fields in your source and target XML data during XSLT transformations.This helps ensure that your XSLT stylesheet gracefully handles cases where certain nodes may or may not be present in the source XML.
Here's a simplified example of how you might use xsl:if to handle optional fields in an XSLT transformation:


<xsl:template match="person">  <xsl:if test="address">    <!-- Process the address node -->    <address>      <xsl:value-of select="address"/>    </address>  </xsl:if></xsl:template>

In this example, the <address> element is processed only if the <address> node exists in the source XML. If it doesn't exist, the <address> element is not generated in the output.

Ex:Suppose you have the following source XML:
<person>  <name>John</name>  <!-- Address node is optional and not present --></person>
And you want to transform it into a target XML:
<target>  <person>    <name>John</name>    <!-- Target address node should be optional -->  </person></target>
In this case, if you don't use an xsl:if or similar conditional check, you might end up with undesired empty <address> nodes in the target document:
<target>  <person>    <name>John</name>    <address></address> <!-- Undesired empty node -->  </person></target>
To avoid this, you should use xsl:if to conditionally create the <address> node only when the source <address> node exists:

<xsl:template match="person">  <person>    <name><xsl:value-of select="name" /></name>    <xsl:if test="address">      <address><xsl:value-of select="address" /></address>    </xsl:if>  </person></xsl:template>
With this approach, the <address> node is only created in the target when the source <address> node is present, resulting in the desired output:
<target>  <person>    <name>John</name>  </person></target>

Testing Multiple Conditions

You can test multiple conditions using logical and relational operators with the <xsl-if> element.

Ex: the XML file that stores information about the telephone usage of customers:

TeleInformation.xml File 

?xml version="1.0"?>
<Bill-Information>
<Customer-Info>
<Tel-No>01-456-789-58621</Tel-No>
<CustName>Mr.Micheal</CustName>
<Address>457,Texas,USA.</Address>
<Chargable-Units>450</Chargable-Units>
</Customer-Info>
<Customer-Info>
<Tel-No>01-427-654-57945</Tel-No>
<CustName>Mr.Stewart</CustName>
<Address>789,California,USA</Address>
<Chargable-Units>800</Chargable-Units>
</Customer-Info>
</Bill-Information> 

if the chargeable unit is less than 500, $2.50 is charged for each unit. If the number of units is more than 500, $3.00 per unit is charged. You can use an XSLT stylesheet to calculate the bill amount and display the amount for each customer.

BillAmount.xsl Stylesheet 

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="2.0">
      <xsl:template name="cust-info">
      <xsl:param name="slab1"/>
      <xsl:param name="slab2"/>
      <xsl:for-each select="//Customer-Info">
      <xsl:if test="Chargable-Units &lt;500" >  
      <xsl:variable name="unit" select="Chargable-Units"/>
      <tr><td>PhoneNo: </td><td> <xsl:value-of select="Tel-No"/></td></tr>
      <tr><td>CustomerName: </td><td> <xsl:value-of select="CustName"/></td></tr>
      <tr><td>Address: </td><td><xsl:value-of select="Address"/></td></tr>
      <tr><td>No.of Units: </td><td><xsl:value-of select="$unit"/></td></tr>
      <tr><td>Amount: </td><td><xsl:value-of select="$unit*$slab1"/></td></tr>
      </xsl:if>
      <xsl:if test="Chargable-Units>=500">
      <xsl:variable name="unit" select="Chargable-Units"/>
      <tr><td colspan="2" height="20"></td></tr>
      <tr><td>PhoneNo: </td><td><xsl:value-of select="Tel-No"/></td></tr>
      <tr><td>CustomerName: </td><td><xsl:value-of select="CustName"/></td></tr>
      <tr><td>Address: </td><td><xsl:value-of select="Address"/></td></tr>
      <tr><td>No. of Units: </td><td><xsl:value-of select="$unit"/></td></tr>
      <tr><td>Amount: </td><td><xsl:value-of select="$unit*$slab2"/></td></tr>
      </xsl:if>
      </xsl:for-each>
      </xsl:template>
      <xsl:template match="/">
            <html>
                  <body>
                  <center><table border="1" bgcolor="#ffeedd">
                  <th colspan="2" align="center">Telephone Bill Information</th>
                  <xsl:call-template name="cust-info"> <xsl:with-param name="slab1" select="2.50"/>
                  <xsl:with-param name="slab2" select="3.00"/>
                  </xsl:call-template>
                  </table></center>
                  </body>
            </html>
      </xsl:template>
</xsl:stylesheet>

 Checking the existence of a node

The <xsl:if> element checks for the existence of a node in an XML file.

Ex If the customer node exists, you can display the corresponding node information.
If the customer node does not exist, you can display the message,

CustAcc.xsl stylesheet, which uses the <xsl:if> element to list the account node information and check the existence of the customer node in the CustAcc.xml file:

CustAcc.xml File


<?xml version="1.0"?> <Bank> <Account type="FD"> <AccountNo>FD-1254</AccountNo> <CustName>Mr.Stewart</CustName> <Minimum currency="US$">4500</Minimum> </Account> <Account type="CA"> <AccountNo>CA-1255</AccountNo> <CustName>Mr. John David</CustName> <Minimum currency="US$">8000</Minimum> </Account> <Account type="CA"> <AccountNo >CA-1256</AccountNo> <CustName>Mr. Tom Wilkins</CustName> <Minimum currency="US$">6000</Minimum> </Account> </Bank>
CheckAcc.xsl Stylesheet

xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
version="1.0"> <xsl:output method="xml" indent="yes"/> <xsl:template match="/"> <xsl:if test="//Account"> <xsl:copy-of select="//Account"/> </xsl:if> <xsl:if test="not(//customer)"> <Customer><xsl:text>The customer node does not
Exist</xsl:text></Customer> </xsl:if> </xsl:template> </xsl:stylesheet>







SOA Overview Part-1

  Middleware It provides a mechanism for the process to interact with other processes running on multiple network machines. Advantages...