Copyright © 2005 University of Georgia Research
Foundation, Inc., International
Business Machines Corporation. All rights reserved.
This document is available under the W3C
Document License. See the W3C
Intellectual Rights Notice and Legal Disclaimers for additional
information.
The current WSDL standard operates at the syntactic level and lacks the semantic expressivity needed to represent the requirements and capabilities of Web Services. Semantics can improve software reuse and discovery, significantly facilitate composition of Web services and enable integration of legacy applications as part of business process integration. The Web Service Semantics document defines a mechanism to associate semantic annotations with Web services that are described using Web Service Description Language (WSDL). It is conceptually based on, but a significant refinement in details of, the original WSDL-S proposal [WSDL-S] from the LSDIS laboratory at the University of Georgia. In this proposal, we assume that formal semantic models relevant to the services already exist. In our approach, these models are maintained outside of WSDL documents and are referenced from the WSDL document via WSDL extensibility elements. The type of semantic information that would be useful in describing a Web Service encompass the concepts defined by the semantic Web community in OWL-S [OWL-S] and other efforts [METEOR-S, WSMO]. The semantic information specified in this document includes definitions of the precondition, input, output and effects of Web service operations. This approach offers multiple advantages over OWL-S. First, users can describe, in an upwardly compatible way, both the semantics and operation level details in WSDL- a language that the developer community is familiar with. Second, by externalizing the semantic domain models, we take an agnostic approach to ontology representation languages. This allows Web service developers to annotate their Web services with their choice of ontology language (such as UML or OWL) unlike in OWL-S. This is significant because the ability to reuse existing domain models expressed in modeling languages like UML can greatly alleviate the need to separately model semantics. Finally, it is relatively easy to update the existing tooling around the WSDL specification to accommodate our incremental approach.
This section describes the status of this document at the time of its publication. Other documents may supersede this document.
By publishing this document, W3C acknowledges that IBM and the University of Georgia. have made a formal submission to W3C for discussion. Publication of this document by W3C indicates no endorsement of its content by W3C, nor that W3C has, is, or will be allocating any resources to the issues addressed by it. This document is not the product of a chartered W3C group, but is published as potential input to the W3C Process. Publication of acknowledged Member Submissions at the W3C site is one of the benefits of W3C Membership. Please consult the requirements associated with Member Submissions of section 3.3 of the W3C Patent Policy. Please consult the complete list of acknowledged W3C Member Submissions.
As the set of available Web Services expands, it becomes increasingly important to have automated tools to help identify services that match a requester's requirements. Finding suitable Web services depends on the facilities available for service providers to describe the capabilities of their services and for service requesters to describe their requirements in an unambiguous and ideally, machine-interpretable form. Adding semantics to represent the requirements and capabilities of Web services is essential for achieving this unambiguity and machine-interpretability. Semantics play an important role in the complete lifecycle of Web services. During development, the service provider can explicate the intended semantics by annotating the appropriate parts of the Web service with concepts from a richer semantic model. Since semantic models provide agreement on the meaning and intended use of terms, and may provide formal and informal definitions of the entities, there will be less ambiguity in the intended semantics of the provider. During discovery, the service requestor can describe the service requirements using terms from the semantic model. Reasoning techniques can be used to find the semantic similarity between the service description and the request. During composition, the functional aspect of the annotations can be used to aggregate the functionality of multiple services to create useful service compositions. More importantly, semantics can make it possible to specify mappings between data exchanged through XML-based SOAP [SOAP] messages, which would be difficult to do with syntactic representation offered by the current standards. During invocation, mappings can be used for data transformations. Therefore, once represented, semantics can be leveraged by tools to automate service discovery, mediation, composition and monitoring. Current WS-* standards operate at the syntactic level and lack semantic representation capabilities. This poses an impediment to developing tools to assist humans and/or support semi-automatic process and application integration. In this proposal, we address this problem by applying the work of the semantic Web community to the Web services standards.
The World Wide Web Consortium (W3C) Web services architecture [W3CWSA] defines two aspects of the full description of a Web service. The first is the syntactic functional description as represented by WSDL. The second is described as the semantics of the service and is not covered by a specification. In practice, the semantic description is either missing or informally documented. By examining the WSDL description of a service, we cannot unambiguously determine what the service does. We can see the syntax of its inputs and outputs, but we do not know what these mean or what changes to the environment the service makes. We do not know the meaning of the parameters nor the terms referenced in payload documents. Indeed, two services can have the same syntactic definition but perform significantly different functions. For example, two services that take a parameter of type 'xsd:string' and return an 'xsd:float' can perform completely different functions. One could be a getStockQuote() service that takes the name of the company (string) as input and returns stock price (float) and the other could be an itemAvailabilityCheck() service that takes an XML document as a string consisting of many parameters such as item#, date, quantity etc and return the quantity (float) that is available for the requested date and item#. Similarly, two syntactically dissimilar services can perform the same function. For example, two services both of which provide item availability check interfaces can have syntactically different looking interfaces. Say, one service by the name itemAvailabilityCheck() could take an XML document as a string (second service in the syntactically similar but semantically different example) and return the quantity available as float while another service by the name checkItemAvailability() could expose the individual parameters separately instead of packaging them in an XML document. Syntactically these two services look very different but perform the same function of finding out whether a given item is available or not.
Semantic markup of Web Services has been proposed as an approach to address the above issues. Example proposals include initiatives, projects and languages such as WSMO [WSMO], METEOR-S [METEOR-S], OWL-S [OWL-S] and SWSA/SWSL [SWSA, SWSL]. While the semantic expressivity is rich and flexible in OWL-S, arguably the most visible research approach to date, it defines a new way to describe Web services and suffers from limitations. First, the OWL-S profile model duplicates the descriptions embodied in the rest of WSDL (namely input and outputs). This leads to the inconvenience of creating multiple definitions for describing the same service. Second, it assumes that everyone uses OWL for representing ontologies which may not always be the case. To overcome these limitations, we propose a new approach in this document. The same observations apply to the rest of the proposals identified above.
The approach described in this proposal is an evolutionary and compatible upgrade of the existing Web services standards, and more specifically Web service descriptions. It is a revision of the initial WSDL-S proposal [WSDL-S] from the METEOR-S group at the University of Georgia. In this approach, we augment the expressivity of WSDL with semantics by employing concepts analogous to those in OWL-S while being agnostic to the semantic representation language. In this document, we only refer to the OWL-S profile model (component of OWL-S that describes functionality of Web services). The OWL-S process model (component of OWL-S that describes the interaction protocol of a Web services) compares with WSBPEL and is not discussed here. The advantage of this evolutionary approach to adding semantics to WSDL is multi-fold. First, users can, in an upwardly compatible way, describe both the semantics and operation level details in WSDL- a language that the developer community is familiar with. Second, by externalizing the semantic domain models, we take an agnostic approach to ontology representation languages. This allows Web service developers to annotate their Web services with their choice of modeling language (such as UML or OWL). This is significant since the ability to reuse existing domain models expressed in modeling languages like UML can greatly alleviate the need to separately model semantics. Moreover, this approach realizes the need for the existence of multiples ontologies, either from the same or different domains to annotate a single Web service and provides a mechanism to do so. Finally, it is relatively easy to update the existing tooling around WSDL specification to accommodate our incremental approach. While it is noted that the theoretical underpinnings of OWL-S in description logic makes it a richer language for representing semantics, we believe that extending the industry standards such as WSDL to include semantics is a more practical approach for adoption. Moreover, by externalizing the semantic domain models in our proposal, we still allow for richer representations of domain concepts and relationships in languages such as OWL and UML, thereby bringing together the best of both worlds.
We provide basic definitions for the terminology we use in this document.
The WSDL [WSDL] document forms the anchor point for Web services description. Building on the descriptive capability of WSDL, we provide a mechanism to annotate the capabilities and requirements of Web services with semantic concepts referenced from a semantic model. To do this, we provide mechanisms to annotate the service and its inputs, outputs and operations. Additionally, we provide mechanisms to specify and annotate preconditions and effects of Web Services. These preconditions and effects together with the semantic annotations of inputs and outputs can enable automation of the process of service discovery.
 
Figure 1. Externalized representation and association of semantics to WSDL elements
Figure 1 shows how semantic annotations are associated with various elements of a WSDL document (including inputs, outputs and functional aspects like operations, preconditions and effects) by referencing the semantic concepts in an external domain semantic model. The domain model can consist of one or more ontologies.
The keywords "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in RFC2119 [keywords].
The XML namespace names [XMLNamespace] URIs [URI] defined by this proposal is as follows:
| Prefix | Namespace name | 
|---|---|
| wssem | http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/WSSemantics.xsd | 
We recommend that certain principles guide any work to define a framework for Web services semantics. Our work is guided by the following principles.
We first present an example WSDL document that is annotated with semantic information to give the reader a preview of what is explained in the rest of the document. The semantic annotations are explained in section 4 with excerpts drawn from this example.
In this sample, we present a simple Web service for an item purchase order. The semantic concepts and their relationships are modeled in an OWL ontology - PurchaseOrder.owl (presented in Appendix C). The inputs, outputs and operations of the ProcessPurchaseOrder service are annotated with semantics. Two new elements namely preconditions and effects are introduced as extensibility elements to the operation construct in WSDL, and an extensibility element called category is added to the interface construct.
PurchaseOrder.wsdl is given below.
<?xml version="1.0" encoding="iso-8859-1"?>
<definitions name="PurchaseOrder"
 targetNamespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns="http://www.w3.org/2004/08/wsdl"
 xmlns:tns="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:xs="http://www.w3.org/2001/XMLSchema"
 xmlns:xsd1="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:wssem="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:POOntology="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl"
 xmlns:Rosetta="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/rosetta.owl">
   <types> 
     <xs:import namespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
       schemaLocation="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/WSSemantics.xsd"/>
     <xs:import namespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
       schemaLocation="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/POBilling.xsd" />
     <xs:import namespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
       schemaLocation="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/POItem.xsd" />
     <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
           targetNamespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
           xmlns="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl">
        <!--Semantic annotations for these complex types are given in their respective type
            definitions -->
        <xs:complexType name="processPurchaseOrderRequest"> 
          <xs:all> 
            <xs:element name="billingInfo" type="xsd1:POBilling"/>
            <xs:element name="orderItem" type="xsd1:POItem"/> 
          </xs:all> 
         </xs:complexType> 
        <!--Semantic annotation is added directly to leaf element -->
        <xs:element name="processPurchaseOrderResponse" type="xs:string"
               wssem:modelReference="POOntology#OrderConfirmation"/>
      </xs:schema> 
    </types>
   <interface name="PurchaseOrder">
           <!--Category is added as an extensible element of an interface-->
           <wssem:category name="Electronics" taxonomyURI="http://www.naics.com/" taxonomyCode="443112" />
           <operation name="processPurchaseOrder" pattern="wsdl:in-out"
                     wssem:modelReference="Rosetta:RequestPurchaseOrder" >
             <input messageLabel ="processPurchaseOrderRequest"
             element="tns:processPurchaseOrderRequest"/> 
             <output messageLabel ="processPurchaseOrderResponse"
             element="processPurchaseOrderResponse"/>
           <!--Precondition and effect are added as extensible elements on an operation-->
           <wssem:precondition name="ExistingAcctPrecond"
           wssem:modelReference="POOntology#AccountExists"/>
           <wssem:effect name="ItemReservedEffect"
           wssem:modelReference="POOntology#ItemReserved"/>
           </operation>
   </interface>
</definitions>
In this WSDL document, the input processPurchaseOrderRequest includes complex child elements. The definition of semantic annotations for these complex types is done at the level of leaf elements in complex types in this example. Annotating complex types at the top level and the leaf level are discussed later in detail. In this document, an alternate way to annotate complex types is also proposed. This approach associates schema mapping functions at the level of complex types. Schema mapping functions represented in XSLT and XQuery are discussed in detail in Appendices A and B respectively. Native support for OWL types (as supported in WSDL 2.0) is also possible within our framework. Details for OWL type support are available in an earlier version of this work [WSDL-S]. The XSD definitions of all the extensions defined in this document are shown in the next section.
WSSemantics.xsd is given below.
<?xml version="1.0" encoding="UTF-8"?>
<schema xmlns="http://www.w3.org/2001/XMLSchema"
 targetNamespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:wssem="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/">
  <attribute name="modelReference" type="anyURI" use="optional"/>
  <attribute name="schemaMapping" type="anyURI" use="optional"/>
  <element name="category" maxOccurs="unbounded">
    <complexType>
      <complexContent>
	<extension base="wsdl:documented">
	  <attribute name="categoryname" type="NCName" use="required"/>
	  <attribute name="taxonomyURI" type="anyURI" use="required"/>
	  <attribute name="taxonomyValue" type="String" use="optional"/>
	  <attribute name="taxonomyCode" type="integer" use="optional"/>
	</extension>
      </complexContent>
    </complexType>
  </element>
  
  <element name="precondition">
    <complexType>
      <complexContent>
	<restriction base="anyType">
	  <attribute name="name" type="string" />
	  <attribute name="modelReference" type="anyURI" />
	  <attribute name="expression" type="string" />
	</restriction>
      </complexContent>
    </complexType>
  </element>
  
  <element name="effect">
    <complexType>
      <complexContent>
	<restriction base="anyType">
	  <attribute name="name" type="string" />
	  <attribute name="modelReference" type="anyURI" />
	  <attribute name="expression" type="string" />
	</restriction>
      </complexContent>
    </complexType>
  </element>
</schema>
This schema is referenced in the definition of the xmlns:wssem namespace definition. The following three XML schema documents define the input and output documents for the service.
POItem.xsd, which defines the properties of an item in a purchase order, is given below.
<?xml version="1.0" encoding="UTF-8"?>
<schema attributeFormDefault="qualified" elementFormDefault="unqualified"
 targetNamespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns="http://www.w3.org/2001/XMLSchema"
 xmlns:xsd1="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:wssem="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:POOntology="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl">
  <import location="WSSemantics.xsd"
	  namespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"/>
  <complexType name="POItem">
    <all>
      <element name="dueDate" nillable="true" type="dateTime"
	       wssem:modelReference="POOntology#DueDate"/>                          
      <element name="qty" type="float" wssem:modelReference="POOntology#Quantity"/>
      <element name="EANCode" nillable="true" type="string"
	       wssem:modelReference="POOntology#ItemCode"/>                                     
      <element name="itemDesc" nillable="true" type="string"
	       wssem:modelReference="POOntology#ItemDesc" />                                                
    </all>
  </complexType>
</schema>
POBilling.xsd, which defines the billing information in a purchase order, is given below. In POBilling.xsd, the elements of POBilling complex type namely shipToAddress and billToAddress are of type POAddress which is a complexType in itself. Therefore, the specification of semantic annotations for these contained complex types are deferred to the corresponding XSDs - in this case POAddress.xsd
<?xml version="1.0" encoding="UTF-8"?>
<schema attributeFormDefault="qualified"
 elementFormDefault="unqualified"
 targetNamespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns="http://www.w3.org/2001/XMLSchema"
 xmlns:xsd1="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:wssem="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:POOntology="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl">
  <include schemaLocation="POAddress.xsd"/>
  <complexType name="POBilling">
    <all>
      <element name="shipToAddress" nillable="true" type="xsd1:POAddress"/>
      <element name="billToAddress" nillable="true" type="xsd1:POAddress"/>
      <element name="accountID" nillable="true" type="xsd1:string"
	       wssem:modelReference="POOntology#AccountID"/>
    </all>
  </complexType>
</schema>
POAddress.xsd, which defines an address in a purchase order, is given below.
<?xml version="1.0" encoding="UTF-8"?>
<schema attributeFormDefault="qualified"
 elementFormDefault="unqualified"
 targetNamespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns="http://www.w3.org/2001/XMLSchema"
 xmlns:xsd1="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:wssem="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:POOntology="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl">
  <import location="WSSemantics.xsd" 
	  namespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"/>
  <complexType name="POAddress">
    <all>
      <element name="recipientInstName"  type="string"
	       wssem:modelReference="POOntology#Receiver"/>
      <element name="streetAddr1" type="string"
	       wssem:modelReference="POOntology#StreetAddress"/>
      <element name="streetAdd2" type="string"
	       wssem:modelReference="POOntology#StreetAddress"/> 
      <element name="city" type="string" wssem:modelReference="POOntology#City"/>
      <element name="zipCode" type="string"  
	       wssem:modelReference="POOntology#PostalCode"/>                                    
      <element name="state" type="string" wssem:modelReference="POOntology#State"/>
      <element name="country" type="string"
	       wssem:modelReference="POOntology#Country"/>
    </all>
  </complexType>
</schema>
In this section, we describe how semantic annotations are added to WSDL document elements.
Conceptually, WSDL 2.0 has the following constructs to represent service descriptions: interface, operation, message, binding, service and endpoint [WSDL 2 Diff]. Of these, the first three, namely interface, operation and message constructs deal with the abstract definition of a service while the remaining three given by binding, service and endpoint constructs deal with service implementation. In this proposal, we focus on semantically annotating the abstract definition of a service to enable dynamic discovery, composition and invocation of services (it is important to note that semantic annotations would be of use in service implementations as well. For example, if a message exchange protocol A is compatible with another protocol B, such information could be represented in domain models and made use of during invocation. However, we do not address the annotation of service implementation at this time. Service level annotations are in part addressed by WS-Policy). We provide URI reference mechanisms via extensibility elements to the interface, operation and message constructs to point to the semantic annotations defined in the domain models for services.
A quick summary of the extensibility elements and attributes provided in this proposal are given below:
In this section, we describe how to annotate the operation element of a WSDL document. We propose to annotate the operation element by a concept in a semantic model which provides a high level description of the operation. In the purchase order example, the processPurchaseOrder can be annotated using the RosettaNet [Rosetta] PIP 3A4 (Request Purchase Order). The annotation of the operation using the modelReference attribute is shown below.
<interface name="PurchaseOrder">
  <operation name="processPurchaseOrder"
             pattern="wsdl:in-out"
             wssem:modelReference="rosetta:RequestPurchaseOrder">
       …………………………
  </operation>
</interface>
An OWL ontology created using the RosettaNet PIPs is available at [RosettaOnt]. Although, traditionally inputs, outputs, preconditions and effects provide a logical way of capturing the semantics of an operation, a simple semantic annotation indicating the intended behavior of a given operation as an action concept may be effective at certain times. During service discovery, this verb could provide a quick first cut indication of whether this service is a match for a given request and vice versa.
In this section, we describe how to annotate the input and output elements of a WSDL document. In the purchase order example, the processPurchaseOrder operation had one input and one output. The input is represented by the element processPurchaseOrderRequest which is given by xsd:complexType processPurchaseOrderRequest. The output is represented by the element processPurchaseOrderResponse. A WSDL operation is shown below.
<interface name="PurchaseOrder">
    <operation name="processPurchaseOrder" pattern=wsdl:in-out  
       wssem:modelReference="Rosetta:RequestPurchaseOrder">
        <input messageLabel="processPurchaseOrderRequest"
            element="tns:processPurchaseOrderRequest"/> 
        <output messageLabel="processPurchaseOrderResponse"
           element="processPurchaseOrderResponse"/>
        <!--Precondition and effect are added as extensible elements on an operation -->
        <wssem:precondition name="ExistingAcctPrecond"
           wssem:modelReference="POOntology#AccountExists">
        <wssem:effect name="ItemReservedEffect"
           wssem:modelReference="POOntology#ItemReserved"/>
    </operation>
</interface>
The schema that shows the input and output message definitions is given below.
<types>   
<xsd:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
 targetNamespace=" http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl">
   <!--Semantic annotations for these complex types are given in their respective type
         definitions>
   <xs:complexType name="processPurchaseOrderRequest">    
      <xs:all>
         <xs:element name="billingInfo" type="xs:POBilling"/>     
         <xs:element name="orderItem" type="xs:POItem"/>           
      </xs:all>
   </xs:complexType>
   <!--Semantic annotation is added directly to this leaf element />
   <xs:element name= "processPurchaseOrderResponse" type="xs:string
       wssem:modelReference="POOntology#OrderConfirmation"/>
</xs:schema>
</types>
In this example, the input is a complex type while the output is a simple type. To annotate simple types we use the extensibility of xsd:element. An excerpt from XML Schema for xsd:element is shown below. It indicates that an element can be extended with 'any attributes with non-schema namespace'. We use wssem namespace with modelReference attribute to associate annotations to element.
<element …… id = ID maxOccurs = (nonNegativeInteger | unbounded) : 1 minOccurs = nonNegativeInteger : 1 name = NCName …… type = QName {any attributes with non-schema namespace . . .}> Content: (annotation?, ((simpleType | complexType)?, (unique | key | keyref)*)) </element>
Complex types can be annotated in multiple ways. We propose two alternate schemes for annotating complex types:
In the bottom level annotation, all the leaf elements in a complex type can be annotated. The advantage of this approach is that it is simple. It assumes that there is a corresponding concept in the domain model which maps to each leaf element. In cases where there is no corresponding concept, then its semantic annotation can be left unspecified. The disadvantage of this approach is that it assumes there is one-to-one correspondence between the schema elements and the concepts in the domain model. When the associations are one-to-many or many-to-one specifying associations at each leaf element may not be possible. In top level annotation, complex types themselves are annotated with the semantic concept. The advantage of this approach is that it accommodates the one-to-many and many-to-one type of mappings and allows for the specification of mappings between the elements contained in complex types and the concepts defined in domain models. The disadvantage of this approach is that it tends to be complex. In this proposal, we accommodate both types of annotations. Below, we describe mechanisms for both approaches.
In some cases, the elements of a complex type will correspond in a one-to-one fashion with the concepts in a domain model. To accommodate this case, a simple and direct method is provided. We support this by adding a wssem:modelReference attribute to the relevant schema element or attribute definition. The schema for associating a modelReference attribute is:
<attribute name="modelReference" type="anyURI" use="optional"/>
An example of annotating the leaf nodes of complex type with wssem:modelReference attribute is shown below.
<complexType name="POItem">
        <all>
            <element name="dueDate" type="dateTime"
                wssem:modelReference="POOntology#DueDate"/>
            <element name="quantity" type="float"
                wssem:modelReference="POOntology#Quantity"/>
            <element name="EANCode" type="string"
                wssem:modelReference="POOntology#ItemCode"/>
            <element name="itemDesc" type="string"
                wssem:modelReference="POOntology#ItemDesc"/>
        </all>
</complexType>
A complex type can have a semantic annotation via wssem:modelReference attribute. This attribute can point to the corresponding high level concept in an ontology. This high level semantic annotation on a complex type can be used during discovery to make a preliminary determination on whether two structures that are to be matched are semantically related. For example, a complex type 'chip' in an XSD schema can have a semantic annotation 'Microprocessor Chip' from the ontology. This can provide the required context for a schema element during discovery of services. For instance, a discovery service could mistake a 'chip' to mean a chip in a gambling domain but having a semantic annotation can help clarify the context. The annotation referring to the concept Microprocessor Chip would be part of electronics domain ontology and the related properties such as electrical properties of a microprocessor for example, help set the context for discovery. This wssem:modelReference attribute on a complex type does not specify semantic annotations for any elements within a complex type. Semantic annotations for elements contained within a complex type would have to specified using wssem:schemaMapping attribute (explained below).
The schema for associating a schemaMapping function is:
<attribute name="schemaMapping" type="anyURI" use="optional"/>
An excerpt from XML Schema for a complex type is shown below. It indicates that complex types can be extended with 'any attributes with non-schema namespace'. We use wssem namespace with schemaMapping attribute to associate annotations to complex types.
<complexType abstract = boolean : false block = (#all | List of (extension | restriction)) final = (#all | List of (extension | restriction)) id = ID mixed = boolean : false name = NCName {any attributes with non-schema namespace . . .}> Content: (annotation?, (simpleContent | complexContent | ((group | all | choice | sequence)?, ((attribute | attributeGroup)*, anyAttribute?)))) </complexType>
Just like the way we are agnostic the choice of the domain modeling language, we are also agnostic to the choice of schema mapping language. Our approach provides a mechanism to associate optional schema mapping functions with a complex type without any restriction on the choice of the schema mapping language. The following excerpt from purchase order example shows how XSLT can be used as a schema mapping language to specify associations between XSD elements and OWL concepts. Detailed examples showing mapping using XSLT and XQuery are shown in Appendices A and B respectively.
For mapping XML entities with OWL concepts we suggest the following association:
In POBilling.xsd, the complexType POBilling corresponds directly to the OWL concept Billing (Appendix C). Hence the modelReference attribute is used to associate it (POBilling) to the OWL concept Billing. It is to be noted that this modelReference serves as a semantic annotation to the POBilling complex type itself - no correspondences can be drawn from this to the semantic annotations of the elements contained within a complex type. A schemaMapping attribute is required to specify such element level annotations. This is explained further below.
<?xml version="1.0" encoding="UTF-8"?>
<schema attributeFormDefault="qualified"
 elementFormDefault="unqualified"
 targetNamespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns="http://www.w3.org/2001/XMLSchema"
 xmlns:xsd1="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:wssem="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:POOntology="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl">
  <include schemaLocation="POAddress.xsd"/>
  <complexType name="POBilling" wssem:modelReference="POOntology#Billing">
        <all>
            <element name="shipToAddress" type="xsd1:POAddress" /> 
            <element name="billToAddress" type="xsd1:POAddress"  />                  
            <element name="accountID" type="xsd1:string />"
        </all>
  </complexType>
</schema>
In POAddress.xsd, the complexType POAddress does not map directly to the OWL concept in the ontology. Hence, the schemaMapping attribute is used to point to an XSLT transformation. An XSLT transformation is chosen only for illustration purposes. As mentioned earlier, users are at their liberty to choose their preferred mapping specification language including RDF for this.
<?xml version="1.0" encoding="UTF-8"?>
<schema attributeFormDefault="qualified"
 elementFormDefault="unqualified"
 targetNamespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns="http://www.w3.org/2001/XMLSchema"
 xmlns:xsd1="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:wssem="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:POOntology="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl">
<import location="WSSemantics.xsd"
 namespace=" http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"/>
<complexType name="POAddress"
 wssem:schemaMapping="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/POAddress.xsl"
 wssem:modelReference="POOntology#Address" >
        <all>
               <element name="recipientInstName" type="string" />
               <element name="streetAddr1" type="string" />
               <element name="streetAdd2" type="string" />
               <element name="city" type="string" />
               <element name="state" type="string" />
               <element name="zipCode" type="string" />
               <element name="country" type="string" />
        </all>
</complexType>
</schema>
The schema mapping used by POAddress.xsd, POAddress.xsl is shown below.
<?xml version='1.0' ?>
<xsl:transform version="2.0"
  xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
  xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">
<xsl:template match="/">
  <Address rdf:ID="Address1">
       <has_Receiver rdf:datatype="xs:string">
       <xsl:value-of select="POAddress/recepientInstName"/>
       <has_StreetAddress rdf:datatype="xs:string">
       <xsl:value-of select="concat(POAddress/streetAddr1,POAddress/streetAddr2)"/>
       </has_StreetAddress >
       <has_City rdf:datatype="xs:string">
       <xsl:value-of select="POAddress/city"/>
       </has_City>
       <has_State rdf:datatype="xs:string">
       <xsl:value-of select="POAddress/state"/>
       </has_State> 
       <has_ZipCode rdf:datatype="xs:string">
       <xsl:value-of select="POAddress/zipCode"/>
       </has_ZipCode>
       <has_Country rdf:datatype="xs:string">
       <xsl:value-of select="POAddress/country"/>
       </has_Country>
   </Address>
</xsl:template>
</xsl:transform>
If a schema mapping is given for the same complex type, it overrides the individual modelReferences specified at the leaf elements.
We summarize our approach to annotating complex types below.
We suggest the following rules to resolve any potential conflicts.
A precondition defines a set of assertions that must be met before a Web service operation can be invoked. They can specify requirements that must be met, such as "must have an existing account with this company," or restrictions, such as, "Only US customers can be served". Preconditions are specified as child elements of the operation for which the precondition is defined. The schema for a precondition is shown below.
<xsd:element name="precondition">
  <xsd:complexType>
    <xsd:complexContent>
	<xsd:restriction base="xsd:anyType">
	  <xsd:attribute name="name" type="xsd:string" />
	  <xsd:attribute name="modelReference" type="xsd:anyURI" />
	  <xsd:attribute name="expression" type="xsd:string" />
	</xsd:restriction>
    </xsd:complexContent>
  </xsd:complexType>
</xsd:element>  
The precondition element is defined as follows:
<interface name="PurchaseOrder"> <operation name="processPurchaseOrder" pattern="wsdl:in-out"> <input messageLabel="processPurchaseOrderRequest" element="tns:processPurchaseOrderRequest"/> <output messageLabel ="processPurchaseOrderResponse" element="processPurchaseOrderResponse"/> <!--Precondition and effect are added as extensible elements on an operation> <wssem:precondition name="ExistingAcctPrecond" wssem:modelReference="POOntology#AccountExists"> <wssem:effect name="ItemReservedEffect" wssem:modelReference="POOntology#ItemReserved"/> </operation> </interface>
Preconditions and effects are specified as child elements of the operation element. Each operation may have at most one precondition and one effect. We allow for at most one precondition and effect to keep the specification simple. We believe that complex or conditional preconditions and effects should be expressed in the domain/semantic model. For example, a set of preconditions (effects) may be defined via logical expressions to facilitate operations such as 'and', 'or', 'xor', etc. in evaluating these expressions. In this proposal, we assume that the underlying (semantic) representation language supports capturing such multiple preconditions into a single high-level precondition that can be referenced at the operation element level within a WSDL specification.
Developing markup languages for representing preconditions and effects is an area of active research. Different communities are working on this. For example, the semantic Web community is working on Semantic Web Rule Language (SWRL) [SWRL] and the modeling community is working on Object Constraint Language (OCL) [OCL], etc. While we recognize the importance of preconditions and effects in this document and provides hooks for accommodating them while describing Web Services, we believe that more research and more concrete examples are required to help better understand matching and evaluation of preconditions and effects while (semi) automatically matching Web Services descriptions. We defer such a discussion to a later revision of this document.
The schema for a request-response operation with optional preconditions and effects is shown below.
<group name="request-response-operation">
      <sequence>
         <element ref="wsdl:input"/>
         <element ref="wsdl:output"/>
         <element ref="wsdl:fault" minOccurs="0" maxOccurs="unbounded"/>
         <element ref="wssem:precondition" minOccurs="0" maxOccurs="1""/>
         <element ref="wssem:effect" minOccurs="0" maxOccurs="unbounded"/>
      </sequence>
</group>
The grammar for a request-response operation with optional preconditions and effects is shown below.
<wsdl:operation name="nmtoken" parameterOrder="nmtokens">
    <wsdl:input name="nmtoken"? message="anyURI"/>
    <wsdl:output name="nmtoken"? message="anyURI"/>
    <wssem:precondition name="nmtoken"? [modelReference="anyURI"/> | expression="string"]?
    <wssem:effect name="nmtoken"? [modelReference="anyURI"/> | expression="string"]*
    <wsdl:fault name="nmtoken" message="anyURI" modelReference="anyURI" />*
</wsdl:operation>
An effect defines the result of invoking an operation. It can simply state that the output is returned or it can make statements about what changes in the state are expected to occur upon invocation of the service. For example, "the new account balance will be available" or "the credit card account will be debited."
<xsd:element name="effect">
   <xsd:complexType>
            <xsd:complexContent
                        <xsd:restriction base="xsd:anyType">
                                     <xsd:attribute name="name" type="xsd:string" />
                                     <xsd:attribute name="modelReference" type="xsd:anyURI" />
                                     <xsd:attribute name="expression" type="xsd:string" />
                        </xsd:restriction>
            </xsd:complexContent>
   </xsd:complexType>
</xsd:element>
The effect element is a child of the operation element or the fault element. The effect element is defined as follows:
An effect can be associated with a fault. For example, an effect of 'credit card not processed' might occur when a fault 'InvalidCreditCardError' occurs. The fault effect is attached to the operation's child fault element by adding a child effect element to the fault.
Note: Please see the note in Preconditions (section 4.3) to see how to use the 'annotation' element in operation to capture effects if you are using an older version of WSDL schema where operation does not support extensibility elements.
One purpose for annotating services is to enable dynamic discovery of services. This is possible when services are published, cataloged and annotated with semantics. So far, we have focused on how to annotate services. We now present a mechanism to add categorization information to services which could be used while publishing services in registries such as UDDI. Users can choose any categorization of their choice such as NAICS [NAICS], UNSPSC [UNSPSC] and GICS [GICS]. This aids in service discovery by narrowing the range of candidate services. The categorization can be used as input when the service is published in a UDDI registry or it can constitute the effective categorization when the service is made available via Web Services Inspection Language [WSIL] or some other solution-specific means. Service categorization is also aimed at supporting specialized taxonomies of middleware or utility services such as mediators. Our objective is to ensure that there is basic and high-level categorization information about a service and leave the details of actual categorization system and maintenance of taxonomies, classifications, etc., to the underlying service registries. As has been noted earlier, this concept of associating service categorization information is borrowed from OWL-S but here it is adapted to work within the parameters of WSDL specification.
We model a service category using the extensibility elements on a WSDL interface element. This assumes that all operations in the interface of a given WSDL document belong to the same category. The schema for the service categorization element is given below.
<element name="category" maxOccurs="unbounded">
  <complexType>
   <complexContent>
     <extension base="wsdl:interface">
      <attribute name="categoyname" type="NCName" use="required"/>
      <attribute name="taxonomyURI" type="anyURI" use="required"/>
      <attribute name="taxonomyValue" type="String" use="optional"/>
      <attribute name="taxonomyCode" type="integer" use="optional"/>
     </extension>
    </complexContent>
  </complexType>
</element>
Multiple category elements can be used to specify that the service falls into multiple categories. A category element specifies one categorization. For example, the following categorization references the NAICS taxonomy and specifies that the services falls into the 443112 - Electronics category.
<wssem:category name= "Electronics" taxonomyURI="http://www.naics.com/" taxonomyCode="443112" />
This section is non-prescriptive and is provided to describe how this proposal relates to Web services publication and discovery.
Finding suitable Web Services depends on the quality of the search facilities available for service requesters. Web services registries can play an important role in describing the available services and providing these search facilities for finding suitable services. As an industry-backed registry for Web Services, UDDI plays a central role in helping requesters find suitable services. Unfortunately, the current search functions in UDDI are limited in their support for making automatic service selection decisions. Its keyword and category based search facilities are insufficient for selecting suitable services for a given requirement. As of version 3.0, UDDI does not capture the relationships between entities in its directory and therefore is not capable of making use of the semantic information to infer relationships during search. Moreover, UDDI currently does not facilitate matching at the service capability level. Ways to address these limitations are being discussed in the context of upcoming versions of UDDI specifications.
One topic under discussion is the use of OWL ontologies to represent UDDI taxonomies, thereby enabling semantic matching at the category level. The semantic annotations defined in this document both complement and extend such an approach. The semantic annotations enhance the functional description so that while the classification can effectively narrow the set of possible matches, the WSDL annotations can allow specific functional matching and enable the discovery of composite services.
UDDI already specifies how to publish WSDL files to the registry. Semantically annotated WSDL files can be published in similar fashion. A specific approach to performing such semantic matching in UDDI is presented in [Semantic Matching in UDDI; SVSM03].
OWL-S prescribes a notion of conditional outputs and conditional effects. We are currently assessing methods for representing these concepts. Another important aspect is the support of Quality of Service (QoS) assertions for Web services. We are investigating how to represent QoS assertions using ontologies and rules by extending the WS-Policy framework [VAG05]. However, it is to be noted that our intent in this document is to stay close to the WSDL specification and yet accommodate the much needed semantics for Web Service descriptions. By describing semantics for other areas such as Web Service quality of service or multi service orchestration we may tread the unintended path of moving away from the WSDL specification. This is not to say that describing the semantics for QoS and service orchestration are unimportant, but that each is an important topic in its own right and deserves a deeper investigation.
The mechanism for semantic annotation described in this specification can also be applied to WSDL 1.1 conformant Web services descriptions. All the XML attributes and elements defined in this specification apply without modification to the WSDL 1.1 descriptions. However, in some cases they are applied to different elements in the WSDL document structure.
Input and Output
Schema mapping of XML Schema types can be accomplished using the approach described for annotating these elements in WSDL 2.0. In addition, a schemaMapping or modelReference attribute may be added to a part element (under a message element) to specify an input or output annotation that applies to the entire message part. These elements are part of the portType structure in WSDL1.1 which generally corresponds to the WSDL2.0 interface structure.
Preconditions and Effects
The precondition and effect attributes are child attributes of the operation element in a portType. Operation is an extensible element in schema http://schemas.xmlsoap.org/wsdl/. However, if you are using an older version of XML schema for WSDL, then an operation of a portType is not extensible. Therefore, we recommend using the documentation element on an operation to capture the semantics of preconditions and effects. That is shown below.
<portType name="PurchaseOrder">
<operation name="processPurchaseOrder" parameterOrder="billingInfo orderItem">
   <documentation>
      <wssem:precondition name="PreExistingAcctPrecond"
        wssem:modelReference="POOntology#AccountExists">
    <wssem:effect name="ItemReservedEffect"
       wssem:modelReference="POOntology#ItemReserved"/>
  </documentation>
  <input message="tns:processPurchaseOrderRequest"
      name="processPurchaseOrderRequest"/>
  <output message="tns:processPurchaseOrderResponse"
      name="processPurchaseOrderResponse"/>
</operation>
</portType>
Faults
In WSDL 1.1, faults are specified as messages that are generated when a particular condition arises. Annotations for fault messages are done just as annotations are done for any other output message.
This specification singled out UML as an alternative modeling language because of the extensive use of UML to create domain and enterprise models. The availability of these models, even where some may need to be extended to capture the needed semantics, provides an important initial set of useful ontologies for semantic annotation. WSDL-S supports UML class models for annotation through references to model constructs serialized in XMI files. Alternatively, a UML class model can be converted to OWL using the mapping rules defined by the Ontology Definition Metamodel [ODM] developed by the Object Management Group.
Preconditions and effects may also be added to WSDL interfaces using the same extensibility features that were used for WSDL operation. This can help capture global constraints that apply to all operations in a given interface. However, service developers should be careful about this construct as this may lead to contradicting behavioral descriptions at the interface and the contained operations thereby causing semantic misrepresentation of the operation.
Another important aspect that WSDL-S does not currently consider is the behavioral aspect of a Web service, which among other things specifies the order in which the services operations should be invoked. This has been referred to as (choreography - WSMO, interaction protocol - METEOR-S, abstract process -BPEL, conversation language - WSCL). Currently, the ordering of constraints can be captured using preconditions by specifying the operations that are to be invoked before invoking an operation. In the future, we will consider a more direct approach for specifying the behavior of a Web Service. Additional resources, updates, supporting material and tools can be found on the WSDL-S resource page [WSDL-S Resource].
We would like to thank the following people for reviewing this document and providing valuable feedback and helping improve this work.
In this section, we show how XSLT can be used to represent the schema mapping between XSD and OWL elements.
POAddress.xsd is given below.
<?xml version="1.0" encoding="UTF-8"?>
<schema attributeFormDefault="qualified"
 elementFormDefault="unqualified"
 targetNamespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl
 xmlns="http://www.w3.org/2001/XMLSchema"
 xmlns:xsd1="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:wssem="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:POOntology="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl">
<import location="WSSemantics.xsd" namespace=" http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl" />
  <complexType name="POAddress"
    wssem:schemaMapping="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/POAddress.xsl"
    wssem:modelReference="POOntology#Address">
    <all>
      <element name="recipientInstName" type="string" />
      <element name="streetAddr1" type="string" />
      <element name="streetAdd2" type="string" />
      <element name="city" type="string" />
      <element name="state" type="string" />
      <element name="zipCode" type="string" />
      <element name="country" type="string" />
    </all>
  </complexType>
</schema>
The schema mapping used by POAddress.xsd, POAddress.xsl is shown below
<?xml version='1.0' ?>
<xsl:transform version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
 xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
 xmlns:Address="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/POAddress.xsl"
 xmlns:POOntology="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl">
   <xsl:template match="/">
     <POOntology:Address rdf:ID="Address1">
      <POOntology:has_Receiver rdf:datatype="xs:string">
       <xsl:value-of select="POAddress/recepientInstName"/>
       </POOntology:has_Receiver>
       <POOntology:has_StreetAddress rdf:datatype="xs:string">
       <xsl:value-of select="concat(POAddress/streetAddr1,POAddress/streetAddr2)"/>
       </POOntology:has_StreetAddress >
       <POOntology:has_City rdf:datatype="xs:string">
       <xsl:value-of select="POAddress/city"/></POOntology:has_City>
       <POOntology:has_State rdf:datatype="xs:string">
       <xsl:value-of select="POAddress/state"/>
       </POOntology:has_State>
       <POOntology:has_Country rdf:datatype="xs:string">
       <xsl:value-of select="POAddress/country"/>
       </POOntology:has_Country>
       <POOntology:has_ZipCode rdf:datatype="xs:string">
       <xsl:value-of select="POAddress/zipCode"/>
       </POOntology:has_ZipCode>
</POOntology:Address>
</xsl:template>
</xsl:transform>
POItem.xsd is given below
<?xml version="1.0" encoding="UTF-8"?>
<schema attributeFormDefault="qualified"
 elementFormDefault="unqualified"
 targetNamespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns="http://www.w3.org/2001/XMLSchema"
 xmlns:xsd1="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:wssem="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:POOntology="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl">
  <import location="WSSemantics.xsd"
           namespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
  <complexType name="POItem"
      wssem:schemaMapping="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/POItem.xsl"
      wssem:modelReference="POOntology#Item" >
      <all>
        <element name="dueDate" type="dateTime" />
        <element name="quantity" type="float" />
        <element name="EANCode" type="string" />
        <element name="itemDesc" type="string" />
      </all>
  </complexType>
</schema>
The POItem schema is also updated to include semantic references. The schema mapping used by POItem.xsd, POItem.xsl is shown below.
POItem.xsl
<?xml version='1.0' ?>
<xsl:transform version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
 xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
 xmlns:Item="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/POItem.xsl"
 xmlns:POOntology="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl">
  <xsl:template match="/">
    <POOntology:Item rdf:ID="Item1">
      <POOntology:has_dueDate rdf:datatype="xs:dateTime">
	<xsl:value-of select="POItem/dueDate"/>
      </POOntology:has_dueDate >
      <POOntology:has_quantity rdf:datatype="xs:float">
	<xsl:value-of select="POItem/quantity"/>
      </POOntology:has_quantity>                             
      <POOntology:has_EANCode rdf:datatype="xs:string">
	<xsl:value-of select="POItem/EANCode"/>
      </POOntology:has_EANCode >
      <POOntology:has_itemDesc rdf:datatype="xs:string">
	<xsl:value-of select="POItem/itemDesc"/>
      </POOntology:has_itemDesc>
    </POOntology:Item>
  </xsl:template>
</xsl:transform>
This appendix shows examples of how mappings between XSD schema elements and concepts in domain model can be specified using XQuery. The mappings written as XQuery functions are organized as modules to enable reusability. Once specified, we show how these mappings can be invoked using an XQuery.
We show the mapping for POAddress.xsd in this section.
POAddress.xsd is given below.
<?xml version="1.0" encoding="UTF-8"?>
<schema attributeFormDefault="qualified"
 elementFormDefault="unqualified"
 targetNamespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns="http://www.w3.org/2001/XMLSchema"
 xmlns:xsd1="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:wssem="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl">
  <import location="WSSemantics.xsd"
	  namespace=" http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"/>
  <complexType name="POAddress"
      wssem:schemaMapping="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/POAddress.xq"
      wssem:modelReference="POOntology#Address">
    <all>
      <element name="streetAddr1" type="string" />
      <element name="streetAdd2" type="string" />
      <element name="poBox" type="string" />
      <element name="city" type="string" />   
      <element name="zipCode" type="string" />                                                   
      <element name="state" type="string" />                                        
      <element name="country" type="string" />
      <element name="recipientInstName" type="string" />
    </all>
  </complexType>
</schema>
POAddress.xsd defines an address in a purchase order. It contains a wssem:schemaMapping attribute that points to a schema mapping that shows how the elements of the POAddress complex type are defined by concepts in a semantic model. This mapping defines the meaning of the information carried in the XML element.
The schema mapping used by POAddress.xsd, POAddress.xq is shown below.
POAddress.xq
xquery version "1.0";
declare namespace Address = "http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/POAddress.xq";
declare namespace xs = "http://www.w3.org/2001/XMLSchema" ;
declare namespace POOntology="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl" ;
declare namespace owl="http://www.w3.org/2002/07/owl#";
declare namespace rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#";
for $a in doc("POAddress.xml")/POAddress
return
  <POOntology:Address rdf:ID="Address1">        
    <POOntology:has_StreetAddress rdf:datatype="xs:string">
       { fn:concat($a/streetAddr1 , " ", $a/streetAddr2 ) }
    </POOntology:has_StreetAddress>
    <POOntology:has_City rdf:datatype="xs:string">
       { fn:string($a/city) }
    </POOntology:has_City>
    <POOntology:has_State rdf:datatype="xs:string">
       { fn:string($a/state) }
    </POOntology:has_State>
    <POOntology:has_Country rdf:datatype="xs:string">
       { fn:string($a/country) }
    </POOntology:has_Country>
    <POOntology:has_POBox rdf:datatype="xs:string">
       { fn:string($a/poBox) }
    </POOntology:has_POBox>
    <POOntology:has_ZipCode rdf:datatype="xs:string">
       { fn:string($a/zipCode) }
    </POOntology:has_ZipCode>
    <POOntology:has_Receiver rdf:datatype="xs:string">
       { fn:string($a/recipientInstName) }
    </POOntology:has_Receiver>
  </POOntology:Address>
Result of the mapping
<POOntology:Address rdf:ID="Address1"> <POOntology:has_StreetAddress rdf:datatype="xs:string"> 224 Boyd </POOntology:has_StreetAddress> <POOntology:has_City rdf:datatype="xs:string"> Athens </POOntology:has_City> <POOntology:has_State rdf:datatype="xs:string"> Georgia </POOntology:has_State> <POOntology:has_Country rdf:datatype="xs:string"> US </POOntology:has_Country> <POOntology:has_POBox rdf:datatype="xs:string"> 897656 </POOntology:has_POBox> <POOntology:has_ZipCode rdf:datatype="xs:string"> 30602 </POOntology:has_ZipCode> <POOntology:has_Receiver rdf:datatype="xs:string"> XYZ </POOntology:has_Receiver> </POOntology:Address>
POItem.xsd is given below
<?xml version="1.0" encoding="UTF-8"?>
<schema attributeFormDefault="qualified"
 elementFormDefault="unqualified"
 targetNamespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns="http://www.w3.org/2001/XMLSchema"
 xmlns:xsd1="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"
 xmlns:wssem="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl">
 <import location="WSSemantics.xsd"
    namespace="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/purchaseOrder.wsdl"/>
 <complexType name="POItem"
  wssem:schemaMapping="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/POItem.xq"
  wssem:modelReference="POOntology#Item">
  <all>
    <element name="dueDate" type="dateTime" />                                  
    <element name="quantity" type="float" />                                                       
    <element name="EANCode" type="string" />                                                   
    <element name="itemDesc" type="string" />                                                   
  </all>
 </complexType>
</schema>
The POItem schema is also updated to include semantic references. The schema mapping used by POItem.xsd, POItem.xq is shown below.
xquery version "1.0";
declare namespace Item = "http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/examples/POItem.xq";
declare namespace xs = "http://www.w3.org/2001/XMLSchema" ;
declare namespace POOntology="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl" ;
declare namespace owl="http://www.w3.org/2002/07/owl#";
declare namespace rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#";
for $a in doc("POItem.xml")/POItem
return
  <POOntology:Item rdf:ID="Item1">
  <POOntology:has_quantity rdf:datatype="xs:float">
     { fn:string($a/quantity) }
  </POOntology:has_quantity>
  <POOntology:has_dueDate rdf:datatype="xs:dateTime">
     { fn:string($a/dueDate) }
  </POOntology:has_dueDate>            
  <POOntology:has_EANCode rdf:datatype="xs:string">
     { fn:string($a/EANCode) }
  </POOntology:has_EANCode>
  <POOntology:has_itemDesc rdf:datatype="xs:string">
     { fn:string($a/itemDesc) }
  </POOntology:has_itemDesc>
  </POOntology:Item>
Result of the mapping
<POOntology:Item rdf:ID="Item1"> <POOntology:has_quantity rdf:datatype="xs:float"> 5.0 </POOntology:has_quantity> <POOntology:has_dueDate rdf:datatype="xs:dateTime"> 2001-11-19T00:00:00.00000 </POOntology:has_dueDate> <POOntology:has_EANCode rdf:datatype="xs:string"> A6253SAW </POOntology:has_EANCode> <POOntology:has_itemDesc rdf:datatype="xs:string"> Belkin Wireless Router </POOntology:has_itemDesc> </POOntology:Item>
<?xml version="1.0"?>
<rdf:RDF
    xmlns="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl#"
    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
    xmlns:rdfs="http://www.w3.org/2000/01/rdf-schema#"
    xmlns:owl="http://www.w3.org/2002/07/owl#"
    xml:base="http://lsdis.cs.uga.edu/projects/meteor-s/wsdl-s/ontologies/PurchaseOrder.owl">
  <owl:Ontology rdf:about=""/>
  <owl:Class rdf:ID="ItemDesc"/>
  <owl:Class rdf:ID="Item"/>
  <owl:Class rdf:ID="DueDate"/>
  <owl:Class rdf:ID="PreCondition"/>
  <owl:Class rdf:ID="PostalCode"/>
  <owl:Class rdf:ID="City"/>
  <owl:Class rdf:ID="Billing"/>
  <owl:Class rdf:ID="AccountExists">
    <rdfs:subClassOf rdf:resource="#PreCondition"/>
  </owl:Class>
  <owl:Class rdf:ID="Country"/>
  <owl:Class rdf:ID="Account"/>
  <owl:Class rdf:ID="Quantity"/>
  <owl:Class rdf:ID="Address"/>
  <owl:Class rdf:ID="Effect"/>
  <owl:Class rdf:ID="OrderConfirmation"/>
  <owl:Class rdf:ID="StreetAddress"/>
  <owl:Class rdf:ID="State"/>
  <owl:Class rdf:ID="ItemReserved">
    <rdfs:subClassOf rdf:resource="#Effect"/>
  </owl:Class>
  <owl:Class rdf:ID="Receiver"/>
  <owl:Class rdf:ID="ItemCode"/>
  <owl:Class rdf:ID="ZipCode">
    <rdfs:subClassOf rdf:resource="http://www.w3.org/2002/07/owl#Thing"/>
    <rdfs:subClassOf rdf:resource="#PostalCode"/>
  </owl:Class>
  <owl:Class rdf:ID="EanCode">
    <rdfs:subClassOf rdf:resource="#ItemCode"/>
    <rdfs:subClassOf rdf:resource="http://www.w3.org/2002/07/owl#Thing"/>
  </owl:Class>
  <owl:ObjectProperty rdf:ID="has_billingAddress">
    <rdfs:range rdf:resource="#Billing"/>
    <rdfs:domain rdf:resource="#Billing"/>
  </owl:ObjectProperty>
  <owl:ObjectProperty rdf:ID="has_account">
    <rdfs:domain rdf:resource="#Billing"/>
    <rdfs:range rdf:resource="#Account"/>
  </owl:ObjectProperty>
  <owl:ObjectProperty rdf:ID="has_shippingAddress">
    <rdfs:range rdf:resource="#Address"/>
    <rdf:type rdf:resource="http://www.w3.org/2002/07/owl#FunctionalProperty"/>
    <rdfs:domain rdf:resource="#Billing"/>
  </owl:ObjectProperty>
  <owl:DatatypeProperty rdf:ID="has_StreetAddress">
    <rdfs:domain rdf:resource="#Address"/>
    <rdfs:range rdf:resource="http://www.w3.org/2001/XMLSchema#string"/>
  </owl:DatatypeProperty>
  <owl:DatatypeProperty rdf:ID="has_City">
    <rdfs:domain rdf:resource="#Address"/>
    <rdf:type rdf:resource="http://www.w3.org/2002/07/owl#FunctionalProperty"/>
    <rdfs:range rdf:resource="http://www.w3.org/2001/XMLSchema#string"/>
  </owl:DatatypeProperty>
  <owl:DatatypeProperty rdf:ID="has_AccountID">
    <rdfs:range rdf:resource="http://www.w3.org/2001/XMLSchema#string"/>
    <rdf:type rdf:resource="http://www.w3.org/2002/07/owl#FunctionalProperty"/>
    <rdfs:domain rdf:resource="#Account"/>
  </owl:DatatypeProperty>
  <owl:DatatypeProperty rdf:ID="has_State">
    <rdf:type rdf:resource="http://www.w3.org/2002/07/owl#FunctionalProperty"/>
    <rdfs:range rdf:resource="http://www.w3.org/2001/XMLSchema#string"/>
    <rdfs:domain rdf:resource="#Address"/>
  </owl:DatatypeProperty>
  <owl:DatatypeProperty rdf:ID="has_itemDesc">
    <rdfs:range rdf:resource="http://www.w3.org/2001/XMLSchema#string"/>
    <rdfs:domain rdf:resource="#Item"/>
  </owl:DatatypeProperty>
  <owl:DatatypeProperty rdf:ID="has_Quantity">
    <rdfs:range rdf:resource="http://www.w3.org/2001/XMLSchema#float"/>
    <rdf:type rdf:resource="http://www.w3.org/2002/07/owl#FunctionalProperty"/>
    <rdfs:domain rdf:resource="#Item"/>
  </owl:DatatypeProperty>
  <owl:DatatypeProperty rdf:ID="has_POBox">
    <rdf:type rdf:resource="http://www.w3.org/2002/07/owl#FunctionalProperty"/>
    <rdfs:range rdf:resource="http://www.w3.org/2001/XMLSchema#string"/>
  </owl:DatatypeProperty>
  <owl:FunctionalProperty rdf:ID="has_ZipCode">
    <rdfs:domain rdf:resource="#Address"/>
    <rdfs:range rdf:resource="http://www.w3.org/2001/XMLSchema#string"/>
    <rdf:type rdf:resource="http://www.w3.org/2002/07/owl#DatatypeProperty"/>
  </owl:FunctionalProperty>
  <owl:FunctionalProperty rdf:ID="has_Country">
    <rdfs:domain rdf:resource="#Address"/>
    <rdf:type rdf:resource="http://www.w3.org/2002/07/owl#DatatypeProperty"/>
    <rdfs:range rdf:resource="http://www.w3.org/2001/XMLSchema#string"/>
  </owl:FunctionalProperty>
  <owl:FunctionalProperty rdf:ID="has_Receiver">
    <rdfs:range rdf:resource="http://www.w3.org/2001/XMLSchema#string"/>
    <rdf:type rdf:resource="http://www.w3.org/2002/07/owl#DatatypeProperty"/>
    <rdfs:domain rdf:resource="#Address"/>
  </owl:FunctionalProperty>
  <owl:FunctionalProperty rdf:ID="has_DueDate">
    <rdfs:domain rdf:resource="#Item"/>
    <rdf:type rdf:resource="http://www.w3.org/2002/07/owl#DatatypeProperty"/>
    <rdfs:range rdf:resource="http://www.w3.org/2001/XMLSchema#dateTime"/>
  </owl:FunctionalProperty>
  <owl:FunctionalProperty rdf:ID="has_EANCode">
    <rdfs:domain rdf:resource="#Item"/>
    <rdfs:range rdf:resource="http://www.w3.org/2001/XMLSchema#string"/>
    <rdf:type rdf:resource="http://www.w3.org/2002/07/owl#DatatypeProperty"/>
  </owl:FunctionalProperty>
</rdf:RDF>
The focus of research in Semantic Web services has been on using ontologies for Web service discovery and composition [SVSM03, WSMO, OWL-S]. It is useful to use ontologies, as they provide semantic normalization between service requests and advertisements, for higher level tasks like finding an appropriate service (discovery) or composing services to aggregate their functionalities. However, during execution of such compositions, just semantic annotations are not enough to automatically map the data (inputs and outputs) of these services. For a valid interaction, the mappings must also be specified as annotations.
There has been significant work in the database area during 1980s and early 1990s on recognizing the need for data interoperability. There have been numerous efforts in schema mapping/merging/transformations, semantic heterogeneity, and use of ontology and description logics for schematic and semantic integration (e.g., see the discussion in [S04]). This was followed by substantial work on schema matching and mapping as part of the Model Management initiative [BM]. There is ongoing work in the above areas especially in the context of the new Web Service technologies and Semantic Web languages (XML, RDF/RDFS, OWL) [POSV04, KS03, SM01, DMDH02, N04, FB02, HG05].
Conceptually, data interoperability can be divided into two parts - schema matching and schema/data mapping. The words matching and mapping have often been used interchangeably in the literature. The rest of this appendix follows the definition given below for schema matching and mapping. Schema matching is the process of finding semantic correspondences between elements of two schemas and mapping deals with the physical representation of the matches established by schema matching and rules for transforming elements of one schema to that of other. In the next two sections, we seek to briefly describe the major advances in this field, as well as to point out where the approach suggested in this specification stands in this space.
Mapping is the process of representing the matches found as mapping expressions, required to make the mappings operational. Some of the past approaches to representing mappings have been:
This specification does not specify a single mapping language to use. However, as domain models like UML, OWL and XSD are represented in XML, the examples in the document represent mappings either as transformations using XSLT or queries using XQuery. Using these mappings from xml schema elements to concepts in a domain model, it is possible to map instances of Web service schemas from one representation to another. We also recognize that the process of capturing mappings can be complicated by heterogeneities at various levels and that XQuery / XSLT might not be suited for all cases. Also, our approach supports the use of languages such as RDF/S and OWL for specifying mappings since it is agnostic to the mapping language used for specifying the mappings.
Table1 illustrates the schema/data conflicts that most mapping representation languages are capable of handling and how instances of one schema can be mapped to instances of another using a common ontology.

Table 1: Possible schematic / data conflicts between xml input/output messages
* Although the mapping function is well defined in one direction, from the WSDL element to the Ontology concept, it is not well defined in the reverse direction. Although converting a 5 digit StudentID to a 9 digit StudentID is conceivable through use of a look up table, the transformation is not a well defined function in itself.
Legend: We use WS1, WS2 to denote Web Services 1 and 2 and f1 and f2 to denote mapping functions from the WSDL elements to the ontology.
In addition to mapping representation languages, another area of focus has been the task of automating the process of generating mappings. Generating mapping expressions are essential in enabling semantic integration applications like query processing, data integration or exchange of xml messages between Web services. Semi-automating the process of elaborating matches has been discussed in [MHHYHFP01, MBR01, DR02].
Although the loosely coupled nature of Web services has reduced a lot of heterogeneity between interoperating systems at the syntax level, issues of semantic and model/representational heterogeneity are even more complex than before and remain to be addressed adequately. Semantically annotating WSDL elements partly addresses this issue by dissolving the ambiguities in their schemas, structures and syntax, to aid in service discovery and composition. That however, does not suffice to achieve complete interoperability that is critical for service invocation or process execution. It is for these reasons that we recognize the value add that schema/data mapping brings to the Web service descriptions. This appendix has therefore been an attempt to point the reader to existing work in the areas of schema matching and schema/data mapping, recognize issues that need to be addressed in the context of Web services, and briefly characterize the space of solutions to this matching and mapping challenge. We chose to use the point in this space that seemed most practical to us at this time.