Skip to main content

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [List Home]
[eclipselink-dev] fix for bug 242452

The following fix has been checked in:

Bug 242452 - Expand XMLLogin representation in sessions XML & deployment XML
https://bugs.eclipse.org/bugs/show_bug.cgi?id=242452

 Patch file included in the bug report, fix reviewed by Matt MacIvor.

--
Oracle
Rick Barkhouse | Software Developer, TopLink | 613.288.4613
Oracle Development
45 O'Connor Street, Suite 400 | Ottawa, Ontario K1P 1A4
Index: foundation/org.eclipse.persistence.core/resource/xsd/eclipselink_persistence_map_1.1.xsd
===================================================================
--- foundation/org.eclipse.persistence.core/resource/xsd/eclipselink_persistence_map_1.1.xsd	(revision 0)
+++ foundation/org.eclipse.persistence.core/resource/xsd/eclipselink_persistence_map_1.1.xsd	(revision 0)
@@ -0,0 +1,4159 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!--
+*******************************************************************************
+ Copyright (c) 1998, 2007 Oracle. All rights reserved.
+ This program and the accompanying materials are made available under the
+ terms of the Eclipse Public License v1.0, which accompanies this distribution
+ and is available at http://www.eclipse.org/legal/epl-v10.html.
+
+ Contributors:
+     Oracle - initial API and implementation from Oracle TopLink
+*****************************************************************************/
+-->
+<!-- Eclipse Persistence Service Project :: Map Schema file for ORM/OXM/EIS -->
+<xsd:schema
+  targetNamespace="http://www.eclipse.org/eclipselink/xsds/persistence";
+  xmlns:xsd="http://www.w3.org/2001/XMLSchema";
+  xmlns="http://www.eclipse.org/eclipselink/xsds/persistence";
+  elementFormDefault="qualified"
+  attributeFormDefault="unqualified"
+  version="1.1"
+  >
+  <xsd:element name="object-persistence" type="object-persistence" />
+  <xsd:complexType name="object-persistence">
+    <xsd:annotation>
+      <xsd:documentation>An object-persistence mapping module, a set of class-mapping-descriptors.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="name" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>A name for the model being mapped.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="class-mapping-descriptors">
+        <xsd:annotation>
+          <xsd:documentation>The list of class mapping descriptors.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element minOccurs="0" maxOccurs="unbounded" name="class-mapping-descriptor" type="class-mapping-descriptor">
+              <xsd:annotation>
+                <xsd:documentation>Information of how a class is persisted to its data-store.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="login" type="datasource-login">
+        <xsd:annotation>
+          <xsd:documentation>The datasource connection and configuration information.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="default-temporal-mutable" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Defines the default for how Date and Calendar types are used with change tracking.</xsd:documentation>
+          <xsd:documentation>By default they are assumed not to be changed directly (only replaced).</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+    <xsd:attribute default="Eclipse Persistence Services - 1.1 (Build YYMMDD)" name="version" type="xsd:string" />
+  </xsd:complexType>
+  <xsd:complexType name="datasource-login">
+    <xsd:annotation>
+      <xsd:documentation>The datasource connection and configuration information.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="platform-class" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The fully qualified name of the platform class.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="user-name" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The datasource user-name.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="password" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The datasource password, this is stored in encrypted form.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="external-connection-pooling" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Defines if the connections are managed by the datasource driver, and a new connection should be acquire per call.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="external-transaction-controller" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Defines if the transaction are managed by a transaction manager, and should not be managed by TopLink.</xsd:documentation>
+          <xsd:documentation>This can also be used if the datasource does not support transactions.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="sequencing">
+        <xsd:annotation>
+          <xsd:documentation>Sequencing information.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element minOccurs="0" name="default-sequence" type="sequence">
+              <xsd:annotation>
+                <xsd:documentation>Default sequence. The name is optional. If no name provided an empty string will be used as a name.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+            <xsd:element minOccurs="0" name="sequences">
+              <xsd:annotation>
+                <xsd:documentation>Non default sequences. Make sure each sequence has unique name.</xsd:documentation>
+              </xsd:annotation>
+              <xsd:complexType>
+                <xsd:sequence>
+                  <xsd:element minOccurs="0" maxOccurs="unbounded" name="sequence" type="sequence" />
+                </xsd:sequence>
+              </xsd:complexType>
+            </xsd:element>
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="database-login">
+    <xsd:annotation>
+      <xsd:documentation>The JDBC driver and database connection and configuration information.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="datasource-login">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="driver-class" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The fully qualified name of the JDBC driver class.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="connection-url" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The full JDBC driver connection URL.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="true" name="bind-all-parameters" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Configure if parameter binding should be used.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="cache-all-statements" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Configure if statement caching should be used.  This should be used with parameter binding, this cannot be used with external connection pooling.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="true" name="byte-array-binding" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Configure if byte array data-types should use binding.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="string-binding" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Configure if string data-types should use binding.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="256" name="string-binding-size" type="xsd:integer">
+            <xsd:annotation>
+              <xsd:documentation>Configure the threshold string size for usage of string binding.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="streams-for-binding" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Configure if large byte array and string data-types should be bound as streams.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="force-field-names-to-upper-case" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Configure to force all field names to upper-case.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="true" name="optimize-data-conversion" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Configure data optimization.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="true" name="trim-strings" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Configure if string trailing blanks should be trimmed.  This is normally required for CHAR data-types.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="batch-writing" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Configure if batch writing should be used.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="true" name="jdbc-batch-writing" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>If using batch writing, configure if the JDBC drivers batch writing should be used.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="eis-login">
+    <xsd:annotation>
+      <xsd:documentation>The JCA driver and EIS connection and configuration information.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="datasource-login">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="connection-spec-class" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The fully qualified name of the TopLink platform specific connection spec class.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="connection-factory-url" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The JNDI url for the managed JCA adapter's connection factory.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-login">
+    <xsd:annotation>
+      <xsd:documentation>The connection and configuration information.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="datasource-login">
+        <xsd:sequence>
+        	<xsd:element minOccurs="0" default="true"
+        		name="equal-namespace-resolvers" type="xsd:boolean" />
+        	<xsd:element name="document-preservation-policy"
+        		type="document-preservation-policy" maxOccurs="1"
+        		minOccurs="0">
+        	</xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="class-mapping-descriptor">
+    <xsd:annotation>
+      <xsd:documentation>Information of how a class is persisted to its data-store.</xsd:documentation>
+      <xsd:documentation>This is an abstract definition to allow flexibility in the types of classes and datastores persisted, i.e. interfaces, abstract classes, aggregates, non-relational persistence.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element name="class" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The name of the implementation class being persisted.  The class name must be full qualified with its package.</xsd:documentation>
+          <xsd:documentation>Example: <class xmlns="http://www.eclipse.org/eclipselink/xsds/persistence";>example.employee.implementation.Employee</class></xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="alias" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Optionally an alias name can be given for the class.  The alias is a string that can be used to refer to the class in place of its implementation name, such as in querying.</xsd:documentation>
+          <xsd:documentation>Example: <alias xmlns="http://www.eclipse.org/eclipselink/xsds/persistence";>Employee</alias></xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="primary-key">
+        <xsd:annotation>
+          <xsd:documentation>The list of fields/columns that make up the primary key or unique identifier of the class.</xsd:documentation>
+          <xsd:documentation>This is used for caching, relationships, and for database operations.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element maxOccurs="unbounded" name="field" type="field">
+              <xsd:annotation>
+                <xsd:documentation>The primary key field.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="read-only" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Defines if the class is read-only.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="properties">
+        <xsd:annotation>
+          <xsd:documentation>Allow for user defined properties to be defined.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element minOccurs="0" maxOccurs="unbounded" name="property" type="property">
+              <xsd:annotation>
+                <xsd:documentation>A user defined property.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="inheritance" type="inheritance-policy">
+        <xsd:annotation>
+          <xsd:documentation>Defines how the class is related in inheritance and how this inheritance is persisted.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="events" type="event-policy">
+        <xsd:annotation>
+          <xsd:documentation>Defines the persistent events for this class.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="querying" type="query-policy">
+        <xsd:annotation>
+          <xsd:documentation>The list of defined queries for the class.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="attribute-mappings">
+        <xsd:annotation>
+          <xsd:documentation>The list of mappings that define how the class' attributes are persisted.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element minOccurs="0" maxOccurs="unbounded" name="attribute-mapping" type="attribute-mapping">
+              <xsd:annotation>
+                <xsd:documentation>Defines how a attribute is persisted. The attribute mapping definition is extendable to allow for different types of mappings.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="descriptor-type" type="class-descriptor-type">
+        <xsd:annotation>
+          <xsd:documentation>Defines the descriptor type, such as aggregate or independent.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="interfaces" type="interface-policy">
+        <xsd:annotation>
+          <xsd:documentation>Defines the interfaces that this class implements..</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="locking" type="locking-policy">
+        <xsd:annotation>
+          <xsd:documentation>Defines the locking behavior for the class.  Such as an optimistic locking policy based on version, timestamp or change set of columns.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="sequencing" type="sequencing-policy">
+        <xsd:annotation>
+          <xsd:documentation>Defines how a generated unique id should be assigned to the class.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="caching" type="caching-policy">
+        <xsd:annotation>
+          <xsd:documentation>Defines how the class' instances should be cached.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="remote-caching" type="caching-policy">
+        <xsd:annotation>
+          <xsd:documentation>Defines how the class' instances should be cached on remote clients.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="history-policy" type="history-policy">
+        <xsd:annotation>
+          <xsd:documentation>Defines how past versions of objects are persisted to the data-store.  By default there will be no history policy.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="returning-policy" type="returning-policy">
+        <xsd:annotation>
+          <xsd:documentation>Defines retuning policy.  By default there will be no returning policy.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="amendment" type="amendment">
+        <xsd:annotation>
+          <xsd:documentation>Allow for the descriptor to be amended or customized through a class API after loading.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="instantiation" type="instantiation-policy">
+        <xsd:annotation>
+          <xsd:documentation>Allow the object instantiation behavoir to be customized</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="copying" type="copy-policy">
+        <xsd:annotation>
+          <xsd:documentation>Allow the object cloning/copying behavoir to be customized.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="query-keys">
+        <xsd:annotation>
+          <xsd:documentation>A list of query keys or aliases for database information.  These can be used in queries instead of the database column names.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element minOccurs="0" maxOccurs="unbounded" name="query-key" type="query-key">
+              <xsd:annotation>
+                <xsd:documentation>Defines an alias for querying database information.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="cmp-policy" type="cmp-policy">
+        <xsd:annotation>
+          <xsd:documentation>Place holder of CMP information specific.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="fetch-groups" type="fetch-groups">
+        <xsd:annotation>
+          <xsd:documentation>Contains all pre-defined fetch groups at the descriptor level</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" maxOccurs="1" name="change-policy" type="change-policy">
+        <xsd:annotation>
+          <xsd:documentation>Contains the Change Policy for this descriptor</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+    <xsd:attribute fixed="10" name="schema-major-version" type="xsd:integer" />
+    <xsd:attribute fixed="0" name="schema-minor-version" type="xsd:integer" />
+  </xsd:complexType>
+  <xsd:simpleType name="class-descriptor-type">
+    <xsd:annotation>
+      <xsd:documentation>Defines the class descriptor type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="independent" />
+      <xsd:enumeration value="aggregate" />
+      <xsd:enumeration value="aggregate-collection" />
+      <xsd:enumeration value="composite" />
+      <xsd:enumeration value="composite" />
+      <xsd:enumeration value="interface" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:complexType name="interface-policy">
+    <xsd:annotation>
+      <xsd:documentation>Specify the interfaces that a class descriptor implements, or the implemention class for an interface descriptor.</xsd:documentation>
+      <xsd:documentation>Optionally a set of public interfaces for the class can be specified.  This allows the interface to be used to refer to the implementation class.</xsd:documentation>
+      <xsd:documentation>If two classes implement the same interface, an interface descriptor should be defined for the interface.</xsd:documentation>
+      <xsd:documentation>This can also be used to define inheritance between interface descriptors.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" maxOccurs="unbounded" name="interface" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The fully qualified interface class name.</xsd:documentation>
+          <xsd:documentation>Example: <class xmlns="http://www.eclipse.org/eclipselink/xsds/persistence";>example.employee.api.Employee</class></xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" maxOccurs="unbounded" name="implementor-descriptor" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The fully qualified class name of the implementation class for which this interface is the public interface.</xsd:documentation>
+          <xsd:documentation>This can be used if the interface has only a single implementor.</xsd:documentation>
+          <xsd:documentation>Example: <class xmlns="http://www.eclipse.org/eclipselink/xsds/persistence";>example.employee.impl.Employee</class></xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="copy-policy">
+    <xsd:annotation>
+      <xsd:documentation>Allow the object cloning/copying behavoir to be customized.</xsd:documentation>
+    </xsd:annotation>
+  </xsd:complexType>
+  <xsd:complexType name="instantiation-copy-policy">
+    <xsd:annotation>
+      <xsd:documentation>Creates a copying through creating a new instance to copy into.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="copy-policy" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="clone-copy-policy">
+    <xsd:annotation>
+      <xsd:documentation>Allow the object cloning/copying behavoir to be customized through a clone method.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="copy-policy">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="method" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name of the clone method on the object, i.e. 'clone'</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="instantiation-policy">
+    <xsd:annotation>
+      <xsd:documentation>Allow the object instantiation behavoir to be customized.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The name of the method on the factory to instantiate the object instance.'</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="factory-class" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The fully qualified factory class name.'</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="factory-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The name of the method to instantiate the factory class.'</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="amendment">
+    <xsd:annotation>
+      <xsd:documentation>Specifies a class and static method to be called to allow for the descriptor to be amended or customized through a class API after loading.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element name="amendment-class" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation> The fully qualified name of the amendment class.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element name="amendment-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The name of the static amendment method on the class.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="relational-class-mapping-descriptor">
+    <xsd:annotation>
+      <xsd:documentation>Defines a class mapping to a relational database table(s).</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="class-mapping-descriptor">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="tables">
+            <xsd:annotation>
+              <xsd:documentation>The list of the tables the class is persisted to.  Typically a class is persisted to a single table, but multiple tables can be defined.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element maxOccurs="unbounded" name="table" type="table">
+                  <xsd:annotation>
+                    <xsd:documentation>The list of tables that the class is persisted to.  This is typically a single table but can be multiple, or empty for inheritance or aggregated classes.</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="foreign-keys-for-multiple-table" type="foreign-key">
+            <xsd:annotation>
+              <xsd:documentation>Allow the foreign key field references to be define for multiple table descriptors.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="multiple-table-join-criteria" type="criteria">
+            <xsd:annotation>
+              <xsd:documentation>For complex multiple table join conditions an expression may be provided instead of the table foreign key information.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="locking-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines an optimistic locking policy.</xsd:documentation>
+    </xsd:annotation>
+  </xsd:complexType>
+  <xsd:complexType name="version-locking-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines an optimistic locking policy based on a numeric version field/column that tracks changes and the version to an object.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="locking-policy">
+        <xsd:sequence>
+          <xsd:element name="version-field" type="field">
+            <xsd:annotation>
+              <xsd:documentation>The name and optionally the table of the column that the attribute is stored into.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="true" name="store-version-in-cache" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify if the version value should be stored in the cache, or if it will be stored in the object.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="timestamp-locking-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines an optimistic locking policy based on timestamp version column that tracks changes and the version to an object.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="version-locking-policy">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" default="false" name="server-time" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify if the timestamp should be obtained locally or from the database server.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="all-fields-locking-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines an optimistic locking policy based on comparing the original read values of all fields of the object with the current state of the values in the database.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="locking-policy" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="changed-fields-locking-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines an optimistic locking policy based on comparing the original read values of only the changed fields of the object with the current state of the values in the database.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="locking-policy" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="selected-fields-locking-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines an optimistic locking policy based on comparing the original read values of a specified set of fields of the object with the current state of the values in the database.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="locking-policy">
+        <xsd:sequence>
+          <xsd:element name="fields">
+            <xsd:annotation>
+              <xsd:documentation>Specify the set of fields to compare on update and delete.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element maxOccurs="unbounded" name="field" type="field" />
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="sequencing-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines how a database generated unique id should be assigned to the class.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element name="sequence-name" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Specify the name of the sequence generator.  This could be the name of a sequence object, or a row value in a sequence table.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element name="sequence-field" type="field">
+        <xsd:annotation>
+          <xsd:documentation>Specify the field/column that the generated sequence id is assigned to.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:simpleType name="cache-type">
+    <xsd:annotation>
+      <xsd:documentation>Defines the set of valid caching types.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="none" />
+      <xsd:enumeration value="full" />
+      <xsd:enumeration value="cache" />
+      <xsd:enumeration value="weak-reference" />
+      <xsd:enumeration value="soft-reference" />
+      <xsd:enumeration value="soft-cache-weak-reference" />
+      <xsd:enumeration value="hard-cache-weak-reference" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:complexType name="caching-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines how the class' instances should be cached and how object identity should be maintained.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" default="soft-cache-weak-reference" name="cache-type" type="cache-type">
+        <xsd:annotation>
+          <xsd:documentation>Specify the type of caching, such as LRU, weak reference or none.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="100" name="cache-size" type="xsd:integer">
+        <xsd:annotation>
+          <xsd:documentation>Specify the initial or maximum size of the cache.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="always-refresh" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Specify to always refresh cached objects on queries.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="only-refresh-cache-if-newer-version" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Specify to refresh if the cached object is an older version.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="disable-cache-hits" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Disable obtaining cache hits on primary key queries.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="always-conform" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Specify to always conform queries within a transaction.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="isolated" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Specify if objects of this type should be isolated from the shared cache.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="isolate-new-data-after-transaction" name="unitofwork-isolation-level" type="unitofwork-isolation-level">
+        <xsd:annotation>
+          <xsd:documentation>Specify how the unit of work should be isolated to the session cache.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="cache-invalidation-policy" type="cache-invalidation">
+        <xsd:annotation>
+          <xsd:documentation>Defines the cache invalidation policy.  By default there will be no cache invalidation policy.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="change-set" name="cache-sync-type" type="cache-sync-type">
+        <xsd:annotation>
+          <xsd:documentation>The type of cache synchronization to be used with this descripor.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="cache-invalidation" abstract="true">
+    <xsd:annotation>
+      <xsd:documentation>Abstract superclass for cache invalidation policies.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" default="false" name="update-read-time-on-update" type="xsd:boolean" />
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="no-expiry-cache-invalidation-policy">
+    <xsd:annotation>
+      <xsd:documentation>Cache invalidation policy where objects in the cache do not expire.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="cache-invalidation" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="time-to-live-cache-invalidation-policy">
+    <xsd:annotation>
+      <xsd:documentation>Cache invalidation policy where objects live a specific number of milliseconds after they are read.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="cache-invalidation">
+        <xsd:sequence>
+          <xsd:element name="time-to-live" type="xsd:long" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="daily-cache-invalidation-policy">
+    <xsd:annotation>
+      <xsd:documentation>Cache invalidation Policy where objects expire at a specific time every day</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="cache-invalidation">
+        <xsd:sequence>
+          <xsd:element name="expiry-time" type="xsd:dateTime" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="history-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines how past versions of objects are to be persisted to the data-store.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" default="true" name="handle-writes" type="xsd:boolean" />
+      <xsd:element minOccurs="0" default="false" name="use-database-time" type="xsd:boolean" />
+      <xsd:element minOccurs="0" name="history-tables">
+        <xsd:annotation>
+          <xsd:documentation>Defines the names of the mirroring historical tables.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element maxOccurs="unbounded" name="history-table" type="history-table" />
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="start-fields">
+        <xsd:annotation>
+          <xsd:documentation>Defines the start fields for each historical table.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element maxOccurs="unbounded" name="start-field" type="field" />
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="end-fields">
+        <xsd:annotation>
+          <xsd:documentation>Defines the end fields for each historical table.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element maxOccurs="unbounded" name="end-field" type="field" />
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="history-table">
+    <xsd:annotation>
+      <xsd:documentation>Each entry is a source (descriptor) to history table name association.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" default="" name="source" type="xsd:string" />
+      <xsd:element minOccurs="1" name="history" type="xsd:string" />
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="returning-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines retuning policy.  By default there will be no returning policy.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="1" name="returning-field-infos">
+        <xsd:annotation>
+          <xsd:documentation>Lists the fields to be returned together with the flags defining returning options</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element maxOccurs="unbounded" name="returning-field-info" type="returning-field-info" />
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="returning-field-info">
+    <xsd:annotation>
+      <xsd:documentation>Field to be returned together with type and the flags defining returning options. At least one of insert, update should be true.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="reference-class" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The fully qualified name of the target referenced class.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element name="field" type="field">
+        <xsd:annotation>
+          <xsd:documentation>The field to be returned.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="insert" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Indicates whether the field should be retuned after Insert.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="insert-mode-return-only" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>If insert==true, indicates whether the field should not be inserted (true). If insert==false - ignored.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="update" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Indicates whether the field should be retuned after Insert.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="inheritance-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines how the class is related in inheritance and how this inheritance is persisted.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="parent-class" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The name of the parent/superclass of the class being persisted.  The class name must be full qualified   with its package.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="true" name="read-subclasses-on-queries" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Define if subclasses of the class should be returned on queries, or only the exact class.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="all-subclasses-view" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Optionally specify the name of a view that joins all of the subclass' tables.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="use-class-name-as-indicator" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Specifies if the fully qualified class name should be used as the class type indicator.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="class-extraction-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The name of a method on the class that takes the class' row as argument a computed that class type to be used to instantiate from the row.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="class-indicator-field" type="field">
+        <xsd:annotation>
+          <xsd:documentation>The name of the type field/column that the class type is stored into.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="class-indicator-mappings" type="class-indicator-mappings">
+        <xsd:annotation>
+          <xsd:documentation>The set of class indicator values and the subclasses they map to.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="class-extractor" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The name of a class that implements a class extractor interface.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="only-instances-criteria" type="criteria">
+        <xsd:annotation>
+          <xsd:documentation>The criteria that filters out all sibling and subclass instances on queries.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="all-subclasses-criteria" type="criteria">
+        <xsd:annotation>
+          <xsd:documentation>The criteria that filters out sibling instances on queries.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="outer-join-subclasses" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>For inheritance queries specify if all subclasses should be outer joined, instead of a query per subclass.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="qname-inheritance-policy">
+    <xsd:annotation>
+      <xsd:documentation>Extends inheritance policy. Allows for prefixed names to be resolved at runtime to find the approriate class</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="inheritance-policy" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="class-indicator-mappings">
+    <xsd:annotation>
+      <xsd:documentation>The set of class indicator values and the subclasses they map to.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" maxOccurs="unbounded" name="class-indicator-mapping">
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element name="class" type="xsd:string">
+              <xsd:annotation>
+                <xsd:documentation>The fully qualified name of the class the type maps to.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="class-indicator" type="xsd:anySimpleType">
+              <xsd:annotation>
+                <xsd:documentation>The field value used to define the class type.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="event-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines the persistent events for this class.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="event-listeners">
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element minOccurs="0" maxOccurs="unbounded" name="event-listener" type="xsd:string">
+              <xsd:annotation>
+                <xsd:documentation>The fully qualified name of an event listener class that implements the descriptor event listener interface.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="post-build-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed after building the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="pre-write-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed before writing the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="post-write-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed after writing the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="pre-insert-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed before inserting the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="post-insert-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed after inserting the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="pre-update-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed before updating the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="post-update-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed after updating the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="pre-delete-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed before deleting the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="post-delete-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed after deleting the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="about-to-insert-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed before inserting the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="about-to-update-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed before updating the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="post-clone-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed after cloning the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="post-merge-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed after merging the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="post-refresh-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Method executed after refreshing the object.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="query-policy">
+    <xsd:annotation>
+      <xsd:documentation>The list of defined queries and query properties for the class.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="queries">
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element minOccurs="0" maxOccurs="unbounded" name="query" type="query">
+              <xsd:annotation>
+                <xsd:documentation>A query definition for the class' instances.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="timeout" type="xsd:integer">
+        <xsd:annotation>
+          <xsd:documentation>Specifies a timeout to apply to all queries.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="check-cache" name="existence" type="existence-policy">
+        <xsd:annotation>
+          <xsd:documentation>Allow the behavoir used to determine if an insert or update should occur for an object to be customized.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="insert-query" type="insert-object-query">
+        <xsd:annotation>
+          <xsd:documentation>Custom insert query.  This overide the default insert behavoir for usage with stored procedures or custom calls.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="update-query" type="update-object-query">
+        <xsd:annotation>
+          <xsd:documentation>Custom update query.  This overide the default update behavoir for usage with stored procedures or custom calls.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="delete-query" type="delete-object-query">
+        <xsd:annotation>
+          <xsd:documentation>Custom delete query.  This overide the default delete behavoir for usage with stored procedures or custom calls.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="does-exist-query" type="does-exist-query">
+        <xsd:annotation>
+          <xsd:documentation>Custom does exist query.  This overide the default delete behavoir for usage with stored procedures or custom calls.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="read-object-query" type="read-object-query">
+        <xsd:annotation>
+          <xsd:documentation>Custom read object query.  This overide the default read behavoir for usage with stored procedures or custom calls.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="read-all-query" type="read-all-query">
+        <xsd:annotation>
+          <xsd:documentation>Custom read all query.  This overide the default read all behavoir for usage with stored procedures or custom calls.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:simpleType name="existence-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines the set of valid existence policies for determining if an insert or update should occur for an object.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="check-cache" />
+      <xsd:enumeration value="check-database" />
+      <xsd:enumeration value="assume-existence" />
+      <xsd:enumeration value="assume-non-existence" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:complexType name="query-key">
+    <xsd:annotation>
+      <xsd:documentation>Defines an alias for querying database information.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:attribute name="name" type="xsd:string">
+      <xsd:annotation>
+        <xsd:documentation>The query-key alias name.</xsd:documentation>
+      </xsd:annotation>
+    </xsd:attribute>
+  </xsd:complexType>
+  <xsd:simpleType name="cache-sync-type">
+    <xsd:annotation>
+      <xsd:documentation>The type of cache synchronization to use with a descriptor.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="invalidation" />
+      <xsd:enumeration value="no-changes" />
+      <xsd:enumeration value="change-set-with-new-objects" />
+      <xsd:enumeration value="change-set" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:simpleType name="unitofwork-isolation-level">
+    <xsd:annotation>
+      <xsd:documentation>Specify how the unit of work isolated from the session cache.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="use-session-cache-after-transaction" />
+      <xsd:enumeration value="isolate-new-data-after-transaction" />
+      <xsd:enumeration value="isolate-cache-after-transaction" />
+      <xsd:enumeration value="isolate-cache-always" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:complexType name="direct-query-key">
+    <xsd:annotation>
+      <xsd:documentation>Defines an alias for a database column.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="query-key">
+        <xsd:sequence>
+          <xsd:element name="field" type="field">
+            <xsd:annotation>
+              <xsd:documentation>The field/column being aliased.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="relationship-query-key" abstract="true">
+    <xsd:annotation>
+      <xsd:documentation>Defines an alias for a join to another class' table.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="query-key">
+        <xsd:sequence>
+          <xsd:element name="reference-class" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The fully qualified name of the target referenced class.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:choice>
+            <xsd:element name="foreign-key" type="foreign-key">
+              <xsd:annotation>
+                <xsd:documentation>The foreign key join condition between the source and target class' tables.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="criteria" type="criteria">
+              <xsd:annotation>
+                <xsd:documentation>The join criteria between the source and target class' tables.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+          </xsd:choice>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="one-to-one-query-key">
+    <xsd:annotation>
+      <xsd:documentation>Defines an alias for a 1-1 join to another class' table.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="relationship-query-key" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="one-to-many-query-key">
+    <xsd:annotation>
+      <xsd:documentation>Defines an alias for a 1-m join from another class' table.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent>
+      <xsd:extension base="relationship-query-key" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="abstract-direct-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a mapping from an attirbute to a simple field datatype, i.e. String, Number, Date.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent>
+      <xsd:extension base="attribute-mapping">
+        <xsd:sequence>
+          <xsd:element name="field" type="field">
+            <xsd:annotation>
+              <xsd:documentation>The name and optionally the table of the field/column that the attribute is stored into.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element name="null-value" type="xsd:anySimpleType" minOccurs="0">
+            <xsd:annotation>
+              <xsd:documentation>Optionally specify a value that null data values should be converted to.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element name="converter" type="value-converter" minOccurs="0">
+            <xsd:annotation>
+              <xsd:documentation>Optionally specify how the data value should be converted to the object value.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element name="attribute-classification" type="xsd:string" minOccurs="0"/>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="attribute-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines how a attribute is persisted. The attribute mapping definition is extendable to allow for different types of mappings.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="attribute-name" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The name of the attribute.  This is the implementation class attribute name.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="false" name="read-only" type="xsd:boolean">
+        <xsd:annotation>
+          <xsd:documentation>Specify if the attribute is read-only.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="get-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The name of the get method for the attribute.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="set-method" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The name of the set method for the attribute.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="properties">
+        <xsd:annotation>
+          <xsd:documentation>Allow for user defined properties to be defined.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element minOccurs="0" maxOccurs="unbounded" name="property" type="property">
+              <xsd:annotation>
+                <xsd:documentation>A user defined property.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="direct-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines how a simple attribute is persisted.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent>
+      <xsd:extension base="abstract-direct-mapping">
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-direct-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a mapping from an attirbute to a simple field datatype, i.e. String, Number, Date.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent>
+      <xsd:extension base="abstract-direct-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="is-cdata" type="xsd:boolean" />
+          <xsd:element minOccurs="0" name="null-policy" type="abstract-null-policy" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="eis-direct-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a mapping from an attirbute to a simple field datatype, i.e. String, Number, Date.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-direct-mapping" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="field-transformation" abstract="true">
+    <xsd:annotation>
+      <xsd:documentation>Defines a field transformation for a transformation mapping</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element name="field" type="field" />
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="method-based-field-transformation">
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="field-transformation">
+        <xsd:sequence>
+          <xsd:element name="method" type="xsd:string" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="transformer-based-field-transformation">
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="field-transformation">
+        <xsd:sequence>
+          <xsd:element name="transformer-class" type="xsd:string" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="abstract-transformation-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a transformation mapping that uses Java code to transform between the data and object values.</xsd:documentation>
+      <xsd:documentation>This can be used if a single attribute maps to multiple fields, or field only mappings or attribute only mappings.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="attribute-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="attribute-method" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name of the attribute transformation defined in the domain class.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="attribute-transformer" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The class name of the attribute transformer. Used in place of attribute-transformation.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="true" name="mutable" type="xsd:boolean" />
+          <xsd:element minOccurs="0" name="indirection" type="indirection-policy" />
+          <xsd:element minOccurs="0" name="field-transformations">
+            <xsd:annotation>
+              <xsd:documentation>The field transformations.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="field-transformation" type="field-transformation" />
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="transformation-mapping">
+    <xsd:annotation>
+      <xsd:documentation>This can be used if a single attribute maps to multiple fields, or field only mappings or attribute only mappings.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-transformation-mapping" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-transformation-mapping">
+    <xsd:annotation>
+      <xsd:documentation>This can be used if a single attribute maps to multiple fields, or field only mappings or attribute only mappings.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-transformation-mapping" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="eis-transformation-mapping">
+    <xsd:annotation>
+      <xsd:documentation>This can be used if a single attribute maps to multiple fields, or field only mappings or attribute only mappings.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-transformation-mapping" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="aggregate-object-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a relationship where the target object is strictly privately owned by the source object and stores within the source objects row</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="attribute-mapping">
+        <xsd:sequence>
+          <xsd:element name="reference-class" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The fully qualified class name of the target class of the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="true" name="allow-null" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify if a row of all nulls should be interpreted as null.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="field-translations">
+            <xsd:annotation>
+              <xsd:documentation>Allow for the mapping to use different field names than the descriptor.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="field-translation">
+                  <xsd:complexType>
+                    <xsd:sequence>
+                      <xsd:element name="source-field" type="field">
+                        <xsd:annotation>
+                          <xsd:documentation>The field in the source descriptor's table.</xsd:documentation>
+                        </xsd:annotation>
+                      </xsd:element>
+                      <xsd:element name="target-field" type="field">
+                        <xsd:annotation>
+                          <xsd:documentation>The field in the aggregate descriptor.</xsd:documentation>
+                        </xsd:annotation>
+                      </xsd:element>
+                    </xsd:sequence>
+                  </xsd:complexType>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="relationship-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines how a relationship between two classes is persisted.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="attribute-mapping">
+        <xsd:sequence>
+          <xsd:element name="reference-class" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The fully qualified class name of the target class of the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="private-owned" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify if the target objects are privately owned dependent objects.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="cascade-persist" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify if the create operation should be cascaded to the referenced object.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="cascade-merge" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify if the create operation should be cascaded to the referenced object.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="cascade-refresh" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify if the refresh operation should be cascaded to the referenced object.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="cascade-remove" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify if the remove operation should be cascaded to the referenced object.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="one-to-one-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a 1-1 relationship from the source instance to the target instance.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="relationship-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="foreign-key" type="foreign-key">
+            <xsd:annotation>
+              <xsd:documentation>The foreign key in the source class' table that defines the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="foreign-key-fields">
+            <xsd:annotation>
+              <xsd:documentation>The set of foreign key fields populated by this relationship in the source class' table.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="field" type="field">
+                  <xsd:annotation>
+                    <xsd:documentation>The set of foreign key fields populated by this relationship in the source class' table.</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="bidirectional-target-attribute" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>For bi-directional relationships the target inverse relationship can be defined.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="batch-reading" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify to optimize reads for the class by batching the reads to this relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="indirection" type="indirection-policy">
+            <xsd:annotation>
+              <xsd:documentation>The indirection policy to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="selection-query" type="read-object-query">
+            <xsd:annotation>
+              <xsd:documentation>Specify the query to use to select the target objects.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="none" name="join-fetch" type="join-fetch-type">
+            <xsd:annotation>
+              <xsd:documentation>Specify to always join the related objects.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="eis-one-to-one-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a 1-1 relationship from the source instance to the target instance.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="one-to-one-mapping" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="one-to-many-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a 1-m relationship from the source instance to the target instances.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="relationship-mapping">
+        <xsd:sequence>
+          <xsd:element name="target-foreign-key" type="foreign-key">
+            <xsd:annotation>
+              <xsd:documentation>The foreign key in the target class' table that defines the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="bidirectional-target-attribute" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>For bi-directional relationships the target inverse relationship can be defined.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="batch-reading" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify to optimize reads for the class by batching the reads to this relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="container" type="container-policy">
+            <xsd:annotation>
+              <xsd:documentation>Defines the collection type to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="indirection" type="indirection-policy">
+            <xsd:annotation>
+              <xsd:documentation>The indirection policy to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="selection-query" type="read-all-query">
+            <xsd:annotation>
+              <xsd:documentation>Specify the query to use to select the target objects.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="delete-all-query" type="delete-all-query">
+            <xsd:annotation>
+              <xsd:documentation>A query to delete all of the related objects can be specified.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="none" name="join-fetch" type="join-fetch-type">
+            <xsd:annotation>
+              <xsd:documentation>Specify to always join the related objects.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="eis-one-to-many-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a 1-m relationship from the source instance to the target instances.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="relationship-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="source-foreign-key-fields">
+            <xsd:annotation>
+              <xsd:documentation>The set of foreign key fields populated by this relationship in the source class' table.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="field" type="field">
+                  <xsd:annotation>
+                    <xsd:documentation>The set of foreign key fields populated by this relationship in the source class' table.</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="target-foreign-key-fields">
+            <xsd:annotation>
+              <xsd:documentation>The set of foreign key fields populated by this relationship in the source class' table.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="field" type="field">
+                  <xsd:annotation>
+                    <xsd:documentation>The set of foreign key fields populated by this relationship in the source class' table.</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="foreign-key-grouping-element" type="field" />
+          <xsd:element minOccurs="0" name="bidirectional-target-attribute" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>For bi-directional relationships the target inverse relationship can be defined.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="container" type="container-policy">
+            <xsd:annotation>
+              <xsd:documentation>Defines the collection type to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="indirection" type="indirection-policy">
+            <xsd:annotation>
+              <xsd:documentation>The indirection policy to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="selection-query" type="read-all-query">
+            <xsd:annotation>
+              <xsd:documentation>Specify the query to use to select the target objects.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="delete-all-query" type="delete-all-query">
+            <xsd:annotation>
+              <xsd:documentation>A query to delete all of the related objects can be specified.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="direct-collection-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a collection of simple types relationship from the source instance to a set of simple data values.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="attribute-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" default="false" name="batch-reading" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify to optimize reads for the class by batching the reads to this relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="container" type="container-policy">
+            <xsd:annotation>
+              <xsd:documentation>Defines the collection type to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="indirection" type="indirection-policy">
+            <xsd:annotation>
+              <xsd:documentation>The indirection policy to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="selection-query" type="data-read-query">
+            <xsd:annotation>
+              <xsd:documentation>Specify the query to use to select the target data values.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element name="reference-table" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name of the reference table that stores the source primary key and the data values.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element name="direct-field" type="field">
+            <xsd:annotation>
+              <xsd:documentation>The field/column in the reference table that stores the data values.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element name="reference-foreign-key" type="foreign-key">
+            <xsd:annotation>
+              <xsd:documentation>The foreign key in the reference table that defines the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="value-converter" type="value-converter">
+            <xsd:annotation>
+              <xsd:documentation>Optionally specify how the data value should be converted to the object value.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="insert-query" type="data-modify-query">
+            <xsd:annotation>
+              <xsd:documentation>A query to insert a row into the reference table can be specified.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="delete-query" type="data-modify-query">
+            <xsd:annotation>
+              <xsd:documentation>A query to delete a row from the reference table can be specified.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="delete-all-query" type="data-modify-query">
+            <xsd:annotation>
+              <xsd:documentation>A query to delete all of the rows from the reference table can be specified.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="session-name" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name session that defines the reference table.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="history-policy" type="history-policy">
+            <xsd:annotation>
+              <xsd:documentation>Defines how past versions of this attribute are persisted to the data-store.  By default there will be no history policy.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="none" name="join-fetch" type="join-fetch-type">
+            <xsd:annotation>
+              <xsd:documentation>Specify to always join the related objects.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="direct-map-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a map relationship from the source instance to a set of key values pairs of simple data values.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="direct-collection-mapping">
+        <xsd:sequence>
+          <xsd:element name="direct-key-field" type="field">
+            <xsd:annotation>
+              <xsd:documentation>The field/column in the reference table that sores the map key data value.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="key-converter" type="value-converter">
+            <xsd:annotation>
+              <xsd:documentation>Optionally specify how the key data value should be converted to the object value.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="aggregate-collection-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a 1-m relationship from the source instance to the target instances where the target instances are strictly privately owned by the source object.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="relationship-mapping">
+        <xsd:sequence>
+          <xsd:element name="target-foreign-key" type="foreign-key">
+            <xsd:annotation>
+              <xsd:documentation>The foreign key in the target class' table that defines the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="bidirectional-target-attribute" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>For bi-directional relationships the target inverse relationship can be defined.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="batch-reading" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify to optimize reads for the class by batching the reads to this relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="container" type="container-policy">
+            <xsd:annotation>
+              <xsd:documentation>Defines the collection type to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="indirection" type="indirection-policy">
+            <xsd:annotation>
+              <xsd:documentation>The indirection policy to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="selection-query" type="read-all-query">
+            <xsd:annotation>
+              <xsd:documentation>Specify the query to use to select the target objects.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="delete-all-query" type="delete-all-query">
+            <xsd:annotation>
+              <xsd:documentation>A query to delete all of the related objects can be specified.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="none" name="join-fetch" type="join-fetch-type">
+            <xsd:annotation>
+              <xsd:documentation>Specify to always join the related objects.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="many-to-many-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a m-m relationship from the source instance to the target instances.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="relationship-mapping">
+        <xsd:sequence>
+          <xsd:element name="relation-table" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name of the relation table that stores the source/target primary keys.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element name="source-relation-foreign-key" type="foreign-key">
+            <xsd:annotation>
+              <xsd:documentation>The foreign key from the relational table to the source class' table.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element name="target-relation-foreign-key" type="foreign-key">
+            <xsd:annotation>
+              <xsd:documentation>The foreign key from the relational table to the target class' table.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="bidirectional-target-attribute" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>For bi-directional relationships the target inverse relationship can be defined.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="batch-reading" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify to optimize reads for the class by batching the reads to this relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="container" type="container-policy">
+            <xsd:annotation>
+              <xsd:documentation>Defines the collection type to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="indirection" type="indirection-policy">
+            <xsd:annotation>
+              <xsd:documentation>The indirection policy to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="selection-query" type="read-all-query">
+            <xsd:annotation>
+              <xsd:documentation>Specify the query to use to select the target objects.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="insert-query" type="data-modify-query">
+            <xsd:annotation>
+              <xsd:documentation>A query to insert a row into the relation table can be specified.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="delete-query" type="data-modify-query">
+            <xsd:annotation>
+              <xsd:documentation>A query to delete a row from the relation table can be specified.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="delete-all-query" type="data-modify-query">
+            <xsd:annotation>
+              <xsd:documentation>A query to delete all of the rows from the relation table can be specified.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="history-policy" type="history-policy">
+            <xsd:annotation>
+              <xsd:documentation>Defines how past versions of this attribute are persisted to the data-store.  By default there will be no history policy.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="none" name="join-fetch" type="join-fetch-type">
+            <xsd:annotation>
+              <xsd:documentation>Specify to always join the related objects.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="variable-one-to-one-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a 1-1 relationship from the source instance to the target instance that may be of several types related through an interface.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="relationship-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="bidirectional-target-attribute" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>For bi-directional relationships the target inverse relationship can be defined.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="batch-reading" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify to optimize reads for the class by batching the reads to this relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="indirection" type="indirection-policy">
+            <xsd:annotation>
+              <xsd:documentation>The indirection policy to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="selection-query" type="read-object-query">
+            <xsd:annotation>
+              <xsd:documentation>Specify the query to use to select the target objects.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="type-field" type="field">
+            <xsd:annotation>
+              <xsd:documentation>Specify the column to store the class type of the related object into.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="foreign-key-fields">
+            <xsd:annotation>
+              <xsd:documentation>The set of foreign key fields populated by this relationship in the source class' table.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="field" type="field">
+                  <xsd:annotation>
+                    <xsd:documentation>The set of foreign key fields populated by this relationship in the source class' table.</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element name="foreign-key-to-query-key">
+            <xsd:annotation>
+              <xsd:documentation>The list of source/target column/query key references relating a foreign key in one table to the query keys defining a primary or unique key value in the other interface descriptor.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element maxOccurs="unbounded" name="query-key-reference">
+                  <xsd:annotation>
+                    <xsd:documentation>The reference of a source table foreign key and a target interface descriptor query key.</xsd:documentation>
+                  </xsd:annotation>
+                  <xsd:complexType>
+                    <xsd:sequence>
+                      <xsd:element name="source-field" type="field">
+                        <xsd:annotation>
+                          <xsd:documentation>The foreign key field/column name in the source table.</xsd:documentation>
+                        </xsd:annotation>
+                      </xsd:element>
+                      <xsd:element name="target-query-key" type="xsd:string">
+                        <xsd:annotation>
+                          <xsd:documentation>The query key name of the target interface descriptor.</xsd:documentation>
+                        </xsd:annotation>
+                      </xsd:element>
+                    </xsd:sequence>
+                  </xsd:complexType>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="class-indicator-mappings" type="class-indicator-mappings">
+            <xsd:annotation>
+              <xsd:documentation>The set of class indicator values and the subclasses they map to.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="container-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines a container/collection type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="collection-type" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Specifies the fully qualified class name of the collection implementation class.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="sorted-collection-container-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines a sorted collection type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="container-policy">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="comparator-class" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specifies the fully qualified class name of the comparitor, used to compare objects in sorting the collection.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="list-container-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines a list collection type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="container-policy" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="map-container-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines a map container type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="container-policy">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="map-key-method" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specifies the method to call on the target objects to get the key value for the map.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="direct-map-container-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines a direct map container type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="container-policy" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="scrollable-cursor-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines a scrollable cursor container type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="container-policy" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="cursored-stream-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines a cursored stream container type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="container-policy" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="indirection-policy" abstract="true">
+    <xsd:annotation>
+      <xsd:documentation>Defines a deferred read indirection mechanism.</xsd:documentation>
+    </xsd:annotation>
+  </xsd:complexType>
+  <xsd:complexType name="value-holder-indirection-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines usage of value holders to implement indirection.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="indirection-policy" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="proxy-indirection-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines usage of proxies to implement indirection.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="indirection-policy" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="transparent-collection-indirection-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines usage of transparent collections to implement indirection.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="indirection-policy">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="collection-type" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specifies the fully qualified class name of the collection interface to use, i.e. List, Set, Map.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="map-key-method" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specifies the method to call on the target objects to get the key value for the map.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="container-indirection-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines usage of a user defined container to implement indirection.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="indirection-policy">
+        <xsd:sequence>
+          <xsd:element name="container-type" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specifies the fully qualified class name of the container implementer to use.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="typesafe-enumeration-converter">
+    <xsd:annotation>
+      <xsd:documentation>Typesafe Enumeration conversion</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="value-converter" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="type-conversion-converter">
+    <xsd:annotation>
+      <xsd:documentation>Specifies the data type and an object type of the attribute to convert between.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="value-converter">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="object-class" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specifies the fully qualified class name of the attribute type.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="data-class" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specifies the fully qualified class name of the attributes storage data type.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="serialized-object-converter">
+    <xsd:annotation>
+      <xsd:documentation>Uses object serialization to convert between the object and data type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="value-converter">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="data-type" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specifies the fully qualified class name of the attributes storage data type.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="object-type-converter">
+    <xsd:annotation>
+      <xsd:documentation>Specifies a mapping of values from database values used in the field and object values used in the attribute.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="value-converter">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="default-value" type="xsd:anySimpleType">
+            <xsd:annotation>
+              <xsd:documentation>An optional default value can be specified.  This value is used if a database type is not found in the type mapping.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element name="type-mappings">
+            <xsd:annotation>
+              <xsd:documentation>Specifies the mapping of values.  Both the object and database values must be unique.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element maxOccurs="unbounded" name="type-mapping" type="type-mapping">
+                  <xsd:annotation>
+                    <xsd:documentation>Defines the object and data value mapping.</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="attribute-only-type-mappings">
+            <xsd:annotation>
+              <xsd:documentation>Specifies a mapping of additional values that map non-unique data values to a unique attribute value.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element maxOccurs="unbounded" name="type-mapping" type="type-mapping">
+                  <xsd:annotation>
+                    <xsd:documentation>Defines the object and data value mapping.</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="type-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Define an object and data value mapping.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element name="object-value" type="xsd:anySimpleType">
+        <xsd:annotation>
+          <xsd:documentation>Specifies the value to use in the object's attribute.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element name="data-value" type="xsd:anySimpleType">
+        <xsd:annotation>
+          <xsd:documentation>Specifies the value to use in the database field.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="database-query" abstract="true">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query/interaction against a database.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="query">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" default="true" name="maintain-cache" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specifies if the query should bypass the cache completely.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="bind-all-parameters" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specifies if the query should use paramater binding for arguments, or print the arguments in-line.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="cache-statement" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specifies if the queries statement should be cached, this must be used with parameter binding.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="timeout" type="xsd:integer">
+            <xsd:annotation>
+              <xsd:documentation>Specifies a timeout to cancel the query in if the request takes too long to complete.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="true" name="prepare" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specifies if the query should prepare and cache its generated SQL, or regenerate the SQL on each execution.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="call" type="criteria">
+            <xsd:annotation>
+              <xsd:documentation>For static calls the SQL or Stored Procedure call definition can be specified.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:simpleType name="join-fetch-type">
+    <xsd:annotation>
+      <xsd:documentation>Defines the set of valid join fetch options.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="none" />
+      <xsd:enumeration value="inner-join" />
+      <xsd:enumeration value="outer-join" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:simpleType name="cascade-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines the set of valid cascade policies.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="none" />
+      <xsd:enumeration value="private" />
+      <xsd:enumeration value="all" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:complexType name="value-read-query">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for reading a single value.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="direct-read-query" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="direct-read-query">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for reading a collection of values.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="data-read-query" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="data-read-query">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for reading raw data.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="read-query">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="container" type="container-policy">
+            <xsd:annotation>
+              <xsd:documentation>Defines the collection type to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="read-query" abstract="true">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for reading.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="database-query">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" default="false" name="cache-query-results" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specifies if the query should cache the query results to avoid future executions.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="max-rows" type="xsd:integer">
+            <xsd:annotation>
+              <xsd:documentation>Specifies the maximum number of rows to fetch, results will be trunctate on the database to this size.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="first-result" type="xsd:integer">
+            <xsd:annotation>
+              <xsd:documentation>Specifies where to start the cursor in a result set returned from the database. Results prior to this number will not be built into objects</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="fetch-size" type="xsd:integer">
+            <xsd:annotation>
+              <xsd:documentation>Specifiess the number of rows to fetch from the database on each result set next operation.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="query-result-cache-policy" type="query-result-cache-policy">
+            <xsd:annotation>
+              <xsd:documentation>Specify how the query results should be cached.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="query-result-cache-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines how a query's results should be cached.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="invalidation-policy" type="cache-invalidation">
+        <xsd:annotation>
+          <xsd:documentation>Defines the cache invalidation policy. By default there will be no cache invalidation policy.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="100" name="maximum-cached-results" type="xsd:integer">
+        <xsd:annotation>
+          <xsd:documentation>This defines the number of query result sets that will be cached. The LRU query results will be discarded when the max size is reached.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="data-modify-query">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for manipulating data.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="database-query" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="object-modify-query" abstract="true">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for modifying an object.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="database-query" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="update-object-query">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for updating an object.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="object-modify-query" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="insert-object-query">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for inserting an object.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="object-modify-query" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="delete-object-query">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for deleting an object.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="object-modify-query" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="does-exist-query">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for determining if an object exists.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="database-query">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="existence-check" type="existence-check">
+            <xsd:annotation>
+              <xsd:documentation>The existence check option.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:simpleType name="existence-check">
+    <xsd:annotation>
+      <xsd:documentation>Defines the set of valid existence check options.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="check-cache" />
+      <xsd:enumeration value="check-database" />
+      <xsd:enumeration value="assume-existence" />
+      <xsd:enumeration value="assume-non-existence" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:complexType name="delete-all-query">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for deleting a criteria of objects.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="database-query" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="object-level-read-query" abstract="true">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for objects (as apposed to data).</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="read-query">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="reference-class" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The full qualified name of the class of objects being queried.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="refresh" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify if the query should refresh any cached objects from the database.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="remote-refresh" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify if the query should refresh any remotely cached objects from the server.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="none" name="cascade-policy" type="cascade-policy">
+            <xsd:annotation>
+              <xsd:documentation>Specifies if the queries settings (such as refresh, maintain-cache) should apply to the object's relationship queries.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="primary-key" name="cache-usage" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specify how the query should interact with the cache.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="none" name="lock-mode" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specify if the query should lock the resulting rows on the database.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="none" name="distinct-state" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specify if the query should filter distinct results.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="in-memory-querying">
+            <xsd:annotation>
+              <xsd:documentation>The in memory querying policy.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element default="ignore-exceptions-return-conformed" name="policy" type="xsd:string">
+                  <xsd:annotation>
+                    <xsd:documentation>Specify how indirection or unconformable expressions should be treating with in-memory querying and conforming.</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="true" name="use-default-fetch-group" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify if the default fetch group should be used for the query.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="fetch-group" type="fetch-group">
+            <xsd:annotation>
+              <xsd:documentation>Allow the query to partially fetch the object.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="fetch-group-name" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specify a pre-defined named fetch group to allow the query to partially fetch the object.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="use-exclusive-connection" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify if the exclusive connection (VPD) should be used for the query.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="joined-attribute-expressions">
+            <xsd:annotation>
+              <xsd:documentation>Specifies the attributes being joined.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="expression" type="expression">
+                  <xsd:annotation>
+                    <xsd:documentation>Represents an expression for joining</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="read-only" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Specify if objects resulting from the query are read-only, and will not be registered in the unit of work.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="false" name="outer-join-subclasses" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>For inheritance queries specify if all subclasses should be outer joined, instead of a query per subclass.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="read-all-query">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for a set of objects.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="object-level-read-query">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="container" type="container-policy">
+            <xsd:annotation>
+              <xsd:documentation>Defines the collection type to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="batch-read-attribute-expressions">
+            <xsd:annotation>
+              <xsd:documentation>Specifies all attributes for batch reading.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="expression" type="expression">
+                  <xsd:annotation>
+                    <xsd:documentation>Represents an expression for batch reading</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="order-by-expressions">
+            <xsd:annotation>
+              <xsd:documentation>Sets the order expressions for the query.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="expression" type="expression">
+                  <xsd:annotation>
+                    <xsd:documentation>Represents an expression for ordering</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="read-object-query">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query for a single object.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="object-level-read-query" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="report-query">
+    <xsd:annotation>
+      <xsd:documentation>Query for information about a set of objects instead of the objects themselves.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="read-all-query">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="return-choice" type="return-choice">
+            <xsd:annotation>
+              <xsd:documentation>Simplifies the result by only returning the first result, first value, or all attribute values.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="retrieve-primary-keys" type="retrieve-primary-keys">
+            <xsd:annotation>
+              <xsd:documentation>Indicates wether the primary key values should also be retrieved for the reference class.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="report-items">
+            <xsd:annotation>
+              <xsd:documentation>Items to be selected, these could be attributes or aggregate functions.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="item" type="report-item">
+                  <xsd:annotation>
+                    <xsd:documentation>Represents an item requested</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="group-by-expressions">
+            <xsd:annotation>
+              <xsd:documentation>Sets GROUP BY expressions for the query.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="expression" type="expression">
+                  <xsd:annotation>
+                    <xsd:documentation>Represents an expression for grouping</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:simpleType name="return-choice">
+    <xsd:annotation>
+      <xsd:documentation>Simplifies the result by only returning the first result, first value, or all attribute values.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="return-single-result" />
+      <xsd:enumeration value="return-single-value" />
+      <xsd:enumeration value="return-single-attribute" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:simpleType name="retrieve-primary-keys">
+    <xsd:annotation>
+      <xsd:documentation>Indicates wether the primary key values should also be retrieved for the reference class.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="full-primary-key" />
+      <xsd:enumeration value="first-primary-key" />
+      <xsd:enumeration value="no-primary-key" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:complexType name="report-item">
+    <xsd:annotation>
+      <xsd:documentation>Represents an item requested in ReportQuery.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element name="name" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Name given for item, can be used to retieve value from result.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element name="attribute-expression" type="expression">
+        <xsd:annotation>
+          <xsd:documentation>Expression (partial) that describes the attribute wanted.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="expression" abstract="true">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query filter expression tree.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="criteria" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="relation-expression">
+    <xsd:annotation>
+      <xsd:documentation>Defines a relation expression that compares to expressions through operators such as equal, lessThan, etc..</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="expression">
+        <xsd:sequence>
+          <xsd:element name="left" type="expression" />
+          <xsd:element name="right" type="expression" />
+        </xsd:sequence>
+        <xsd:attribute name="operator" type="operator" />
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="logic-expression">
+    <xsd:annotation>
+      <xsd:documentation>Defines a expression composed of two sub-expressions joined through an operator such as AND, OR.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="expression">
+        <xsd:sequence>
+          <xsd:element name="left" type="expression" />
+          <xsd:element name="right" type="expression" />
+        </xsd:sequence>
+        <xsd:attribute name="operator" type="operator" />
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="function-expression">
+    <xsd:annotation>
+      <xsd:documentation>Defines a expression composed of a function applied to a list of sub-expressions.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="expression">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="arguments">
+            <xsd:annotation>
+              <xsd:documentation>The list of function arguments.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="argument" type="expression">
+                  <xsd:annotation>
+                    <xsd:documentation>Defines an argument expression.</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+        <xsd:attribute name="function" type="operator" />
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="constant-expression">
+    <xsd:annotation>
+      <xsd:documentation>Defines an expression value.  If the value is null the value tag can is absent.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="expression">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="value" type="xsd:anySimpleType" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="query-key-expression">
+    <xsd:annotation>
+      <xsd:documentation>Defines an expression query-key.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="expression">
+        <xsd:sequence>
+          <xsd:element name="base" type="expression" />
+        </xsd:sequence>
+        <xsd:attribute name="name" type="xsd:string" />
+        <xsd:attribute name="any-of" type="xsd:boolean" />
+        <xsd:attribute name="outer-join" type="xsd:boolean" />
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="field-expression">
+    <xsd:annotation>
+      <xsd:documentation>Defines an expression field.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="expression">
+        <xsd:sequence>
+          <xsd:element name="field" type="field" />
+          <xsd:element name="base" type="expression" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="parameter-expression">
+    <xsd:annotation>
+      <xsd:documentation>Defines an expression parameter.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="expression">
+        <xsd:sequence>
+          <xsd:element name="parameter" type="field" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="base-expression">
+    <xsd:annotation>
+      <xsd:documentation>Defines an expression builder/base.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="expression" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:simpleType name="operator">
+    <xsd:annotation>
+      <xsd:documentation>Defines the set of valid operators.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:restriction base="xsd:string" />
+  </xsd:simpleType>
+  <xsd:complexType name="sql-call">
+    <xsd:annotation>
+      <xsd:documentation>Defines an SQL query language string.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="criteria">
+        <xsd:sequence>
+          <xsd:element name="sql" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The full SQL query string.  Arguments can be specified through #arg-name tokens in the string.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="ejbql-call">
+    <xsd:annotation>
+      <xsd:documentation>Defines an EJB-QL query language string.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="criteria">
+        <xsd:sequence>
+          <xsd:element name="ejbql" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The EJB-QL query string.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="stored-procedure-call">
+    <xsd:annotation>
+      <xsd:documentation>Defines a stored procedure invocation definition.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="criteria">
+        <xsd:sequence>
+          <xsd:element name="procedure-name" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name of the stored procedure.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="cursor-output-procedure" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Define the call to use a cursor output parameter to define the result set.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="arguments">
+            <xsd:annotation>
+              <xsd:documentation>The list of input and output arguments.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="argument" type="procedure-argument">
+                  <xsd:annotation>
+                    <xsd:documentation>Defines an argument to the procedure. The order of the arguments must match the procedure arguments if not named.</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="stored-function-call">
+    <xsd:annotation>
+      <xsd:documentation>Defines a stored function invocation definition.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="stored-procedure-call">
+        <xsd:sequence>
+          <xsd:element minOccurs="1" name="stored-function-result" type="procedure-output-argument">
+            <xsd:annotation>
+              <xsd:documentation>The return value of the stored-function.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="procedure-argument">
+    <xsd:annotation>
+      <xsd:documentation>Defines a stored procedure call argument.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="procedure-argument-name" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The stored procedure name of the argument. For indexed argument the name is not required.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="argument-name" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The query name of the argument. This is the name of the argument as define in the query.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="procedure-argument-type" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The fully qualified name of the argument class type.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="procedure-argument-sqltype" type="xsd:int">
+        <xsd:annotation>
+          <xsd:documentation>The JDBC int type of the argument, as defined in java.jdbc.Types</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="procedure-argument-sqltype-name" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The name of the type if procedure-argument-sqltype is STRUCT or ARRAY</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="argument-value" type="xsd:anySimpleType">
+        <xsd:annotation>
+          <xsd:documentation>The procedure argument value maybe be specified if not using a query argument.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="procedure-output-argument">
+    <xsd:annotation>
+      <xsd:documentation>Defines a stored procedure call output argument.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="procedure-argument" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="procedure-inoutput-argument">
+    <xsd:annotation>
+      <xsd:documentation>Defines a stored procedure call output argument.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="procedure-argument">
+        <xsd:sequence>
+          <xsd:element name="output-argument-name" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The query name of the argument. This is the name of the argument as define in the query.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="plsql-stored-procedure-call">
+    <xsd:annotation>
+      <xsd:documentation>Defines a stored procedure invocation definition whose arguments contain at least one Oracle PL/SQL type that has no JDBC representation (e.g. BOOLEAN, PLS_INTEGER, PL/SQL record).</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="criteria">
+        <xsd:sequence>
+          <xsd:element name="procedure-name" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name of the stored procedure.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="arguments">
+            <xsd:annotation>
+              <xsd:documentation>The list of input and output arguments.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="argument" type="plsql-procedure-argument-type">
+                  <xsd:annotation>
+                    <xsd:documentation>Defines an argument to the procedure.</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="plsql-procedure-argument-type" abstract="true">
+    <xsd:sequence>
+      <xsd:element name="name" type="xsd:string" />
+      <xsd:element minOccurs="0" name="index" type="xsd:string" />
+      <xsd:element minOccurs="0" name="direction" type="xsd:string" />
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="jdbc-type">
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="plsql-procedure-argument-type">
+        <xsd:sequence>
+          <xsd:choice>
+            <xsd:element minOccurs="0" name="length" type="xsd:string" />
+            <xsd:sequence>
+              <xsd:element name="precision" type="xsd:string" />
+              <xsd:element name="scale" type="xsd:string" />
+            </xsd:sequence>
+          </xsd:choice>
+        </xsd:sequence>
+        <xsd:attribute name="type-name" type="xsd:string" />
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="plsql-type">
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="plsql-procedure-argument-type">
+        <xsd:attribute name="type-name" type="xsd:string" />
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="plsql-record">
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="plsql-procedure-argument-type">
+        <xsd:sequence>
+          <xsd:element name="record-name" type="xsd:string" />
+          <xsd:element name="type-name" type="xsd:string" />
+          <xsd:element minOccurs="0" name="compatible-type" type="xsd:string" />
+          <xsd:element minOccurs="0" name="fields">
+            <xsd:annotation>
+              <xsd:documentation>The list of fields.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="field" type="plsql-procedure-argument-type">
+                  <xsd:annotation>
+                    <xsd:documentation>Defines an argument to the procedure.</xsd:documentation>
+                  </xsd:annotation>
+                </xsd:element>
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="eis-class-mapping-descriptor">
+    <xsd:annotation>
+      <xsd:documentation>Defines a class mapping to an EIS record data structure.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="class-mapping-descriptor">
+        <xsd:sequence>
+          <xsd:element name="datatype" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name of the record structure name the descriptor maps to.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="namespace-resolver" type="namespace-resolver">
+            <xsd:annotation>
+              <xsd:documentation>The namespace resolver for the descriptor.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="mapped-interaction">
+    <xsd:annotation>
+      <xsd:documentation>Defines an EIS interaction utilizing MappedRecord.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="criteria">
+        <xsd:sequence>
+          <xsd:element name="function-name" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name of the function.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="input-result-path" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Optional root key if the input result is not at the record root.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="output-result-path" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Optional root key if the output result is not at the record root.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="input-arguments">
+            <xsd:annotation>
+              <xsd:documentation>The list of input arguments.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="argument" type="interaction-argument" />
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="output-arguments">
+            <xsd:annotation>
+              <xsd:documentation>The list of output arguments.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="argument" type="interaction-argument" />
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-interaction">
+    <xsd:annotation>
+      <xsd:documentation>Defines an EIS interaction utilizing XML records.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="criteria">
+        <xsd:sequence>
+          <xsd:element name="function-name" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name of the function.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="input-record-name" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name to use for the input record, if required by the adapter.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="input-root-element-name" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Optional root key if the output result is not at the record root.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="input-result-path" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Optional root key if the input result is not at the record root.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="output-result-path" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Optional root key if the output result is not at the record root.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="input-arguments">
+            <xsd:annotation>
+              <xsd:documentation>The list of input arguments.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="argument" type="interaction-argument" />
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="output-arguments">
+            <xsd:annotation>
+              <xsd:documentation>The list of output arguments.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="argument" type="interaction-argument" />
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="indexed-interaction">
+    <xsd:annotation>
+      <xsd:documentation>Defines an EIS interaction utilizing Indexed records.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="criteria">
+        <xsd:sequence>
+          <xsd:element name="function-name" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name of the function.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="input-arguments">
+            <xsd:annotation>
+              <xsd:documentation>The list of input arguments.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="argument" type="interaction-argument" />
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="output-arguments">
+            <xsd:annotation>
+              <xsd:documentation>The list of output arguments.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="argument" type="interaction-argument" />
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="interaction-argument">
+    <xsd:annotation>
+      <xsd:documentation>Defines an interaction argument.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="argument-value" type="xsd:anySimpleType">
+        <xsd:annotation>
+          <xsd:documentation>The procedure argument value maybe be specified if not using a query argument.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+    <xsd:attribute name="name" type="xsd:string">
+      <xsd:annotation>
+        <xsd:documentation>The interaction name of the argument. For indexed arguments the name is not required.</xsd:documentation>
+      </xsd:annotation>
+    </xsd:attribute>
+    <xsd:attribute name="argument-name" type="xsd:string">
+      <xsd:annotation>
+        <xsd:documentation>The query name of the argumen. This is the name of the argument as define in the query, or the descriptor field name.</xsd:documentation>
+      </xsd:annotation>
+    </xsd:attribute>
+  </xsd:complexType>
+  <xsd:complexType name="object-relational-class-mapping-descriptor">
+    <xsd:annotation>
+      <xsd:documentation>Defines a class mapping to a Structure type in an object-relational database.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="relational-class-mapping-descriptor">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="structure" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name of the object structure type.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="field-order">
+            <xsd:annotation>
+              <xsd:documentation>The ordered list of the field defined in the structure.</xsd:documentation>
+            </xsd:annotation>
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element maxOccurs="unbounded" name="field" type="field" />
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="nested-table-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a 1-m/m-m relationship that makes use of the object-relational nested-table type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="relationship-mapping">
+        <xsd:sequence>
+          <xsd:element name="field" type="field">
+            <xsd:annotation>
+              <xsd:documentation>The field/column in the source table that stores the nested-table.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element name="structure" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specify the object-relational type name of the nested-table type.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="array-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a collection of primitive/simple type values using the object-relational array type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-composite-direct-collection-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="structure" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specify the object-relational type name of the structure type.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="object-array-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a collection of object-types using the object-relational array type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-composite-collection-mapping">
+        <xsd:sequence>
+          <xsd:element name="structure" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Specify the object-relational type name of the structure type.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="structure-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a structure of object-types using the object-relational structure type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-composite-object-mapping" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="reference-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a reference to another object-type using the object-relational reference type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="relationship-mapping">
+        <xsd:sequence>
+          <xsd:element name="field" type="field">
+            <xsd:annotation>
+              <xsd:documentation>The field in the source type that stores the reference.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="object-relational-field">
+    <xsd:annotation>
+      <xsd:documentation>Defines an ObjectRelationalDatabaseField</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="field">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="nested-type-field" type="field" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="direct-xml-type-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a direct mapping to an Oracle XDB XML Type.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="direct-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="read-whole-document" type="xsd:boolean" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="abstract-composite-direct-collection-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a direct collection mapping for an XML list of elements.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="attribute-mapping">
+        <xsd:sequence>
+          <xsd:element name="field" type="field" />
+          <xsd:element minOccurs="0" name="value-converter" type="value-converter">
+            <xsd:annotation>
+              <xsd:documentation>Optionally specify how the data value should be converted to the object value.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="value-converter-class" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Optionally specify a user defined converter class.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="container" type="container-policy">
+            <xsd:annotation>
+              <xsd:documentation>Defines the collection type to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-collection-reference-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a 1-M relationship from the source XML element to the target XML element based on a key.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="xml-object-reference-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="containerpolicy" type="container-policy">
+            <xsd:annotation>
+              <xsd:documentation>Defines the collection type to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element name="uses-single-node" type="xsd:boolean" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-object-reference-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a 1-1 relationship from the source XML element to the target XML element based on one or more keys.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="aggregate-object-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="source-to-target-key-field-association" type="foreign-key" />
+          <xsd:element minOccurs="0" name="source-to-target-key-fields">
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element minOccurs="0" maxOccurs="unbounded" name="field" type="field" />
+              </xsd:sequence>
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-composite-direct-collection-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a direct collection mapping for an XML list of elements.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-composite-direct-collection-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="is-cdata" type="xsd:boolean" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="eis-composite-direct-collection-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a direct collection mapping for an XML list of elements.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-composite-direct-collection-mapping" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="abstract-composite-collection-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a composite collection mapping for an XML list of nested elements.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="attribute-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="reference-class" type="xsd:string" />
+          <xsd:element name="field" type="field" />
+          <xsd:element minOccurs="0" name="container" type="container-policy">
+            <xsd:annotation>
+              <xsd:documentation>Defines the collection type to use for the relationship.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-composite-collection-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a composite collection mapping for an XML list of nested elements.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-composite-collection-mapping" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="eis-composite-collection-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a composite collection mapping for an XML list of nested elements.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-composite-collection-mapping" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="abstract-composite-object-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a composite object mapping for an XML nested element.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="attribute-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="reference-class" type="xsd:string" />
+          <xsd:element name="field" type="field" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-composite-object-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a composite object mapping for an XML nested element.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-composite-object-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="null-policy" type="abstract-null-policy" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="eis-composite-object-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a composite object mapping for an XML nested element.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-composite-object-mapping" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-class-mapping-descriptor">
+    <xsd:annotation>
+      <xsd:documentation>Defines a class mapping to an XML element.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="class-mapping-descriptor">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" maxOccurs="unbounded" name="default-root-element" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The name of the element the descriptor maps to.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="default-root-element-field" type="node">
+            <xsd:annotation>
+              <xsd:documentation>The XMLField representing the default root element of the descriptor.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="should-preserve-document" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Indicates if nodes should be cached to preserve unmapped data</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="namespace-resolver" type="namespace-resolver">
+            <xsd:annotation>
+              <xsd:documentation>The namespace resolver for the descriptor.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="schema" type="schema-reference">
+            <xsd:annotation>
+              <xsd:documentation>The location of the XML Schema.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-any-collection-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a mapping of a collection to an xs:any declaration or xs:anyType element</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="attribute-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="field" type="field" />
+          <xsd:element minOccurs="0" name="container" type="container-policy" />
+          <xsd:element minOccurs="0" default="false" name="use-xml-root" type="xsd:boolean" />
+          <xsd:element minOccurs="0" name="keep-as-element-policy" type="xsd:string" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-any-attribute-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a mapping of a collection to an xs:any declaration or xs:anyType element</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="attribute-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="field" type="field" />
+          <xsd:element minOccurs="0" name="container" type="container-policy" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-any-object-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a mapping of a single object to an xs:any declaration</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="attribute-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="field" type="field" />
+          <xsd:element minOccurs="0" default="false" name="use-xml-root" type="xsd:boolean" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-fragment-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a mapping of a single Node to a fragment of an XML document</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="xml-direct-mapping" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-fragment-collection-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a mapping of a collection of Nodes to a fragment of an XML document</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-composite-collection-mapping" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-binary-data-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a mapping of a binary object to base64 binary</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="xml-direct-mapping">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="is-swa-ref" type="xsd:boolean" />
+          <xsd:element minOccurs="0" name="mime-type" type="xsd:string" />
+          <xsd:element minOccurs="0" name="should-inline-data" type="xsd:boolean" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-choice-collection-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a mapping of a collection to a choice structure in an xml document</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="attribute-mapping">
+        <xsd:sequence>
+          <xsd:element name="container-policy" type="container-policy" />
+          <xsd:element maxOccurs="unbounded" name="field-to-class-association" type="xml-choice-field-to-class-association" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-choice-object-mapping">
+    <xsd:annotation>
+      <xsd:documentation>Defines a mapping of a collection to a choice structure in an xml document</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="attribute-mapping">
+        <xsd:sequence>
+          <xsd:element maxOccurs="unbounded" name="field-to-class-association" type="xml-choice-field-to-class-association" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-choice-field-to-class-association">
+    <xsd:sequence>
+      <xsd:element name="xml-field" type="node" />
+      <xsd:element name="class-name" type="xsd:string" />
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="xml-conversion-pair">
+    <xsd:sequence>
+      <xsd:element name="qname" type="xsd:string" />
+      <xsd:element name="class-name" type="xsd:string" />
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="node">
+    <xsd:annotation>
+      <xsd:documentation>Defines an XPath expression to an element or attribute in an XML document.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="field">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="position" type="xsd:integer">
+            <xsd:annotation>
+              <xsd:documentation>The position of the node in the parent type.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="typed-text-field" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>If this is a typed text field.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="single-node" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Indicates if each item in the collection is in the same node instead of having one node per item in the collection</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" maxOccurs="unbounded" name="schema-type" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The schema type of the element.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" maxOccurs="unbounded" name="xml-to-java-conversion-pair" type="xml-conversion-pair" />
+          <xsd:element minOccurs="0" maxOccurs="unbounded" name="java-to-xml-conversion-pair" type="xml-conversion-pair" />
+          <xsd:element minOccurs="0" name="leaf-element-type" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Indicates the elements type.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="union-node">
+    <xsd:annotation>
+      <xsd:documentation>Use to represent nodes which are mapped to unions</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="field">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="typed-text-field" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>If this is a typed text field.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" name="single-node" type="xsd:boolean">
+            <xsd:annotation>
+              <xsd:documentation>Indicates if each item in the collection is in the same node instead of having one node per item in the collection</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" maxOccurs="unbounded" name="schema-type" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>The schema type of the element.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" maxOccurs="unbounded" name="xml-to-java-conversion-pair" type="xml-conversion-pair" />
+          <xsd:element minOccurs="0" maxOccurs="unbounded" name="java-to-xml-conversion-pair" type="xml-conversion-pair" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="namespace-resolver">
+    <xsd:sequence>
+      <xsd:element minOccurs="0" maxOccurs="1" name="namespaces">
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element minOccurs="0" maxOccurs="unbounded" name="namespace" type="namespace" />
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+      <xsd:element minOccurs="0" maxOccurs="1" name="default-namespace-uri" type="xsd:string" />
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="namespace">
+    <xsd:sequence>
+      <xsd:element name="prefix" type="xsd:string" />
+      <xsd:element name="namespace-uri" type="xsd:string" />
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="schema-reference">
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="resource" type="xsd:string" />
+      <xsd:element name="schema-context" type="xsd:string" />
+      <xsd:element name="node-type" type="xsd:string" />
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="schema-class-path-reference">
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="schema-reference" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="schema-file-reference">
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="schema-reference" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="schema-url-reference">
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="schema-reference" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:simpleType name="java-character">
+    <xsd:restriction base="xsd:string" />
+  </xsd:simpleType>
+  <xsd:simpleType name="java-timestamp">
+    <xsd:restriction base="xsd:dateTime" />
+  </xsd:simpleType>
+  <xsd:simpleType name="java-util-date">
+    <xsd:restriction base="xsd:dateTime" />
+  </xsd:simpleType>
+  <xsd:complexType name="cmp-policy">
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="pessimistic-locking" type="pessimistic-locking">
+        <xsd:annotation>
+          <xsd:documentation>Defines the cmp bean-level pessimistic locking policy.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="defer-until-commit" type="defer-until-commit">
+        <xsd:annotation>
+          <xsd:documentation>Defines modification deferral level for non-deferred writes.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="non-deferred-create-time" type="non-deferred-create-time">
+        <xsd:annotation>
+          <xsd:documentation>Defines point at which insert will be issued to Database.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="pessimistic-locking">
+    <xsd:sequence>
+      <xsd:element minOccurs="0" default="wait" name="locking-mode" type="locking-mode" />
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:simpleType name="defer-until-commit">
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="all-modifications" />
+      <xsd:enumeration value="update-modifications" />
+      <xsd:enumeration value="none" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:simpleType name="non-deferred-create-time">
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="after-ejbcreate" />
+      <xsd:enumeration value="after-ejbpostcreate" />
+      <xsd:enumeration value="undefined" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:simpleType name="locking-mode">
+    <xsd:annotation>
+      <xsd:documentation>Holds the pessimistic locking mode.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="wait" />
+      <xsd:enumeration value="no-wait" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:complexType name="sequence">
+    <xsd:annotation>
+      <xsd:documentation>Sequence object.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" default="" name="name" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>Sequence name.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" default="50" name="preallocation-size" type="xsd:integer">
+        <xsd:annotation>
+          <xsd:documentation>Sequence preallocation size.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="default-sequence">
+    <xsd:annotation>
+      <xsd:documentation>References default sequence object, overriding its name and (optionally) preallocation size.</xsd:documentation>
+      <xsd:documentation>To use preallocation size of default sequence object, set preallocation size to 0</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="sequence" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="native-sequence">
+    <xsd:annotation>
+      <xsd:documentation>Database sequence mechanism used.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="sequence" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="table-sequence">
+    <xsd:annotation>
+      <xsd:documentation>Table sequence</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="sequence">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" default="SEQUENCE" name="table" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Define the name of the sequence table.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="SEQ_NAME" name="name-field" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Define the name of the sequence name field in the sequence table.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="SEQ_COUNT" name="counter-field" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Define the name of the sequence counter field in the sequence table.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="unary-table-sequence">
+    <xsd:annotation>
+      <xsd:documentation>Unary table sequence - sequence name is a table name, table has a single field and a single row</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="sequence">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" default="SEQUENCE" name="counter-field" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Define the name of the sequence counter field in the sequence table.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xmlfile-sequence">
+    <xsd:annotation>
+      <xsd:documentation>Xmlfile sequence.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="sequence" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="xml-sequence">
+    <xsd:annotation>
+      <xsd:documentation>Xml sequence</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="sequence">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" default="SEQUENCE" name="root-element" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Define the name of the sequence table.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="SEQ_NAME" name="name-element" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Define the name of the sequence name field in the sequence table.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+          <xsd:element minOccurs="0" default="SEQ_COUNT" name="counter-element" type="xsd:string">
+            <xsd:annotation>
+              <xsd:documentation>Define the name of the sequence counter field in the sequence table.</xsd:documentation>
+            </xsd:annotation>
+          </xsd:element>
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="fetch-groups">
+    <xsd:annotation>
+      <xsd:documentation>Contains all pre-defined fetch groups.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="default-fetch-group" type="fetch-group" />
+      <xsd:element minOccurs="0" maxOccurs="unbounded" name="fetch-group" type="fetch-group" />
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="fetch-group">
+    <xsd:annotation>
+      <xsd:documentation>Contains the fetch group attributes info.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="name" type="xsd:string" />
+      <xsd:element name="fetch-group-attributes">
+        <xsd:complexType>
+          <xsd:annotation>
+            <xsd:documentation>Contains a fetch group's attribute list.</xsd:documentation>
+          </xsd:annotation>
+          <xsd:sequence>
+            <xsd:element minOccurs="0" maxOccurs="unbounded" name="fetch-group-attribute" type="xsd:string" />
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="change-policy">
+    <xsd:annotation>
+      <xsd:documentation>Describes the change tracking policy for this descriptor.</xsd:documentation>
+    </xsd:annotation>
+  </xsd:complexType>
+  <xsd:complexType name="deferred-detection-change-policy">
+    <xsd:annotation>
+      <xsd:documentation>Uses backup clone to detect changes.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="change-policy" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="object-level-change-policy">
+    <xsd:annotation>
+      <xsd:documentation>Uses "mark dirty" to detect changes.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="change-policy" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="attribute-level-change-policy">
+    <xsd:annotation>
+      <xsd:documentation>Uses a ChangeTracker firing PropertyChangeEvent's to detect changes.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="change-policy" />
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="abstract-null-policy">
+    <xsd:annotation>
+      <xsd:documentation>Defines the Null Policy in use for this relationship currently a choice of [NullPolicy and IsSetNullPolicy].</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" default="false" name="xsi-nil-represents-null" type="xsd:boolean" />
+      <xsd:element minOccurs="0" default="false" name="empty-node-represents-null" type="xsd:boolean" />
+      <xsd:element minOccurs="0" name="null-representation-for-xml" type="marshal-null-representation" />
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="null-policy">
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-null-policy">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" default="true" name="is-set-performed-for-absent-node" type="xsd:boolean" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="is-set-null-policy">
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="abstract-null-policy">
+        <xsd:sequence>
+          <xsd:element minOccurs="0" name="is-set-method-name" type="xsd:string" />
+          <xsd:element minOccurs="0" maxOccurs="unbounded" name="is-set-parameter-type" type="xsd:string" />
+          <xsd:element minOccurs="0" maxOccurs="unbounded" name="is-set-parameter" type="xsd:string" />
+        </xsd:sequence>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:simpleType name="marshal-null-representation">
+    <xsd:annotation>
+      <xsd:documentation>Write null, no tag(default) or an empty tag.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:restriction base="xsd:string">
+      <xsd:enumeration value="XSI_NIL" />
+      <xsd:enumeration value="ABSENT_NODE" />
+      <xsd:enumeration value="EMPTY_NODE" />
+    </xsd:restriction>
+  </xsd:simpleType>
+  <xsd:complexType name="field">
+    <xsd:annotation>
+      <xsd:documentation>Defines a generic field concept, such as a database column.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:attribute name="name" type="xsd:string">
+      <xsd:annotation>
+        <xsd:documentation>The name of the field.</xsd:documentation>
+      </xsd:annotation>
+    </xsd:attribute>
+  </xsd:complexType>
+  <xsd:complexType name="column">
+    <xsd:annotation>
+      <xsd:documentation>Defines a column in a relational database table.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:complexContent mixed="false">
+      <xsd:extension base="field">
+        <xsd:attribute name="table" type="xsd:string">
+          <xsd:annotation>
+            <xsd:documentation>The name of the column's table. This table must be listed in the class' tables. If not specified the first table of the class will be used.</xsd:documentation>
+          </xsd:annotation>
+        </xsd:attribute>
+      </xsd:extension>
+    </xsd:complexContent>
+  </xsd:complexType>
+  <xsd:complexType name="foreign-key">
+    <xsd:annotation>
+      <xsd:documentation>The list of source/target field/column references relating a foreign key in one table to the primary or unique key in another table.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element maxOccurs="unbounded" name="field-reference">
+        <xsd:annotation>
+          <xsd:documentation>The reference of a source table foreign key and a target table primary key.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element name="source-field" type="field">
+              <xsd:annotation>
+                <xsd:documentation>The foreign key field/column name in the source table.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="target-field" type="field">
+              <xsd:annotation>
+                <xsd:documentation>The primary or unique key field/column name in the target table.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+    </xsd:sequence>
+  </xsd:complexType>
+  <xsd:complexType name="query">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query specification for querying instances of the class.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="criteria" type="criteria">
+        <xsd:annotation>
+          <xsd:documentation>The selection criteria of the query.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="arguments">
+        <xsd:annotation>
+          <xsd:documentation>The list of query arguments. The order of the argument must match the order of the argument value passed to the query.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+          <xsd:sequence>
+            <xsd:element minOccurs="0" maxOccurs="unbounded" name="argument" type="query-argument">
+              <xsd:annotation>
+                <xsd:documentation>The query argument.</xsd:documentation>
+              </xsd:annotation>
+            </xsd:element>
+          </xsd:sequence>
+        </xsd:complexType>
+      </xsd:element>
+    </xsd:sequence>
+    <xsd:attribute name="name" type="xsd:string">
+      <xsd:annotation>
+        <xsd:documentation>The name of the query.  This name can be used to reference and execute the query.</xsd:documentation>
+      </xsd:annotation>
+    </xsd:attribute>
+  </xsd:complexType>
+  <xsd:complexType name="criteria">
+    <xsd:annotation>
+      <xsd:documentation>Defines the filtering clause of a query.</xsd:documentation>
+    </xsd:annotation>
+  </xsd:complexType>
+  <xsd:complexType name="query-argument">
+    <xsd:annotation>
+      <xsd:documentation>Defines a query argument.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element minOccurs="0" name="type" type="xsd:string">
+        <xsd:annotation>
+          <xsd:documentation>The fully qualified class type name of the argument may be provided.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+      <xsd:element minOccurs="0" name="value" type="xsd:anySimpleType">
+        <xsd:annotation>
+          <xsd:documentation>Optional constant value for the argument.</xsd:documentation>
+        </xsd:annotation>
+      </xsd:element>
+    </xsd:sequence>
+    <xsd:attribute name="name" type="xsd:string">
+      <xsd:annotation>
+        <xsd:documentation>The name of the query argument.</xsd:documentation>
+      </xsd:annotation>
+    </xsd:attribute>
+  </xsd:complexType>
+  <xsd:complexType name="property">
+    <xsd:annotation>
+      <xsd:documentation>A user defined property.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:sequence>
+      <xsd:element name="value" type="xsd:anyType" />
+    </xsd:sequence>
+    <xsd:attribute name="name" type="xsd:string" />
+  </xsd:complexType>
+  <xsd:complexType name="table">
+    <xsd:annotation>
+      <xsd:documentation>The list of tables that the class is persisted to.  This is typically a single table but can be multiple, or empty for inheritance or aggregated classes.</xsd:documentation>
+    </xsd:annotation>
+    <xsd:attribute name="name" type="xsd:string">
+      <xsd:annotation>
+        <xsd:documentation>The name of the table.  The name can be fully qualified with the schema, tablespace or link.</xsd:documentation>
+      </xsd:annotation>
+    </xsd:attribute>
+  </xsd:complexType>
+  <xsd:complexType name="value-converter">
+    <xsd:annotation>
+      <xsd:documentation>
+        Specifies how the data value should be converted to the
+        object value.
+      </xsd:documentation>
+    </xsd:annotation>
+  </xsd:complexType>
+
+  <xsd:complexType name="document-preservation-policy">
+  	<xsd:sequence>
+  		<xsd:element name="node-ordering-policy"
+  			type="node-ordering-policy" maxOccurs="1" minOccurs="0">
+  		</xsd:element>
+  	</xsd:sequence>
+  </xsd:complexType>
+
+    <xsd:complexType name="node-ordering-policy"></xsd:complexType>
+
+
+    <xsd:complexType
+    	name="descriptor-level-document-preservation-policy">
+    	<xsd:complexContent>
+    		<xsd:extension base="document-preservation-policy"></xsd:extension>
+    	</xsd:complexContent>
+    </xsd:complexType>
+
+    <xsd:complexType name="no-document-preservation-policy">
+    	<xsd:complexContent>
+    		<xsd:extension base="document-preservation-policy"></xsd:extension>
+    	</xsd:complexContent>
+    </xsd:complexType>
+
+    <xsd:complexType name="xml-binder-policy">
+    	<xsd:complexContent>
+    		<xsd:extension base="document-preservation-policy"></xsd:extension>
+    	</xsd:complexContent>
+    </xsd:complexType>
+
+    <xsd:complexType name="append-new-elements-ordering-policy">
+    	<xsd:complexContent>
+    		<xsd:extension base="node-ordering-policy"></xsd:extension>
+    	</xsd:complexContent>
+    </xsd:complexType>
+
+    <xsd:complexType name="ignore-new-elements-ordering-policy">
+    	<xsd:complexContent>
+    		<xsd:extension base="node-ordering-policy"></xsd:extension>
+    	</xsd:complexContent>
+    </xsd:complexType>
+
+    <xsd:complexType name="relative-position-ordering-policy">
+    	<xsd:complexContent>
+    		<xsd:extension base="node-ordering-policy"></xsd:extension>
+    	</xsd:complexContent>
+    </xsd:complexType>
+</xsd:schema>
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/resource/xsd/eclipselink_sessions_1.1.xsd
===================================================================
--- foundation/org.eclipse.persistence.core/resource/xsd/eclipselink_sessions_1.1.xsd	(revision 0)
+++ foundation/org.eclipse.persistence.core/resource/xsd/eclipselink_sessions_1.1.xsd	(revision 0)
@@ -0,0 +1,1575 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+*******************************************************************************
+ Copyright (c) 1998, 2007 Oracle. All rights reserved.
+ This program and the accompanying materials are made available under the
+ terms of the Eclipse Public License v1.0, which accompanies this distribution
+ and is available at http://www.eclipse.org/legal/epl-v10.html.
+
+ Contributors:
+     Oracle - initial API and implementation from Oracle TopLink
+*****************************************************************************/  
+-->
+<!-- 
+
+XML Schema definition for the Eclipse Persistence Services Project Session Configuration file. Instances
+of this file are typically located as: 'META-INF/sessions.xml'
+
+ -->
+
+<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema";
+    elementFormDefault="qualified" version="1.1">
+    <xsd:element name="sessions">
+        <xsd:annotation>
+            <xsd:documentation>
+                This is the root element and exists only for XML
+                structure
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexType>
+            <xsd:sequence>
+                <xsd:element name="session" type="session" minOccurs="0"
+                    maxOccurs="unbounded" />
+            </xsd:sequence>
+            <xsd:attribute name="version" type="xsd:string"
+                use="required" />
+        </xsd:complexType>
+    </xsd:element>
+    <xsd:complexType name="session">
+        <xsd:annotation>
+            <xsd:documentation>
+                This is the node element that describes a particular session
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:sequence>
+            <xsd:element name="name" type="xsd:string">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Generic element used to describe a string that
+                        represents the name of an item
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="server-platform" type="server-platform"
+                minOccurs="0" />
+            <xsd:choice minOccurs="0">
+                <xsd:element name="remote-command">
+                    <xsd:annotation>
+                        <xsd:documentation>
+                            This element is an optional element of
+                            session element that define the Remote
+                            Command Module that can also be used for
+                            cache synchronization
+                        </xsd:documentation>
+                    </xsd:annotation>
+                    <xsd:complexType>
+                        <xsd:sequence>
+                            <xsd:element name="channel"
+                                type="xsd:string" default="EclipseLinkCommandChannel"
+                                minOccurs="0">
+                                <xsd:annotation>
+                                    <xsd:documentation>
+                                        This element is an optional
+                                        element of remote-command
+                                        element."
+                                    </xsd:documentation>
+                                </xsd:annotation>
+                            </xsd:element>
+                            <xsd:element name="commands"
+                                minOccurs="0">
+                                <xsd:annotation>
+                                    <xsd:documentation>
+                                        This element is an optional
+                                        element of remote-command
+                                        element. It determine what
+                                        command features, the RCM
+                                        supports
+                                    </xsd:documentation>
+                                </xsd:annotation>
+                                <xsd:complexType>
+                                    <xsd:sequence>
+                                        <xsd:element name="cache-sync"
+                                            type="xsd:boolean" default="false" minOccurs="0">
+                                            <xsd:annotation>
+                                                <xsd:documentation>
+                                                    This element is an
+                                                    optional element of
+                                                    command element. It
+                                                    turns on cache
+                                                    synchronization to
+                                                    allow sending and
+                                                    receiving cache sync
+                                                    commands
+                                                </xsd:documentation>
+                                            </xsd:annotation>
+                                        </xsd:element>
+                                    </xsd:sequence>
+                                </xsd:complexType>
+                            </xsd:element>
+                            <xsd:element name="transport"
+                                type="transport-manager" minOccurs="0">
+                                <xsd:annotation>
+                                    <xsd:documentation>
+                                        This element is an optional
+                                        element of remote-command
+                                        element. It defines the
+                                        transport mechanism of the RCM.
+                                        The default transport mechanism
+                                        is RMI
+                                    </xsd:documentation>
+                                </xsd:annotation>
+                            </xsd:element>
+                        </xsd:sequence>
+                    </xsd:complexType>
+                </xsd:element>
+            </xsd:choice>
+            <xsd:element name="event-listener-classes" minOccurs="0">
+                <xsd:complexType>
+                    <xsd:group ref="event-listener-classes" />
+                </xsd:complexType>
+            </xsd:element>
+            <xsd:element name="profiler" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This element represents if the profiler will be
+                        used by the session
+                    </xsd:documentation>
+                </xsd:annotation>
+                <xsd:simpleType>
+                    <xsd:restriction base="xsd:string">
+                        <xsd:enumeration value="dms" />
+                        <xsd:enumeration value="eclipselink" />
+                    </xsd:restriction>
+                </xsd:simpleType>
+            </xsd:element>
+            <xsd:element name="exception-handler-class"
+                type="xsd:string" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This is the class that the session will use to
+                        handle exceptions generated from within the
+                        session
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="logging" type="log" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This element used to specify the logging options
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="session-customizer-class"
+                type="xsd:string" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This element specifies the session customizer
+                        class to run on a loaded session.
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+        </xsd:sequence>
+    </xsd:complexType>
+    <xsd:complexType name="server-platform">
+        <xsd:annotation>
+            <xsd:documentation>
+                This is the node element that describes which server
+                platform to use, JTA settings and runtime services
+                settings
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:sequence>
+            <xsd:element name="enable-runtime-services"
+                type="xsd:boolean" default="true" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This element is an optional element. This
+                        specifies whether or not the JMX MBean for
+                        providing runtime services is deployed.
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="enable-jta" type="xsd:boolean"
+                default="true" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This element is an optional element. This
+                        specifies whether or not this session will
+                        integrate with the JTA (i.e. whether the session
+                        will be populated with a transaction controller
+                        class. The choice of server-class will
+                        automatically be chosen based on the transaction
+                        controller
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+        </xsd:sequence>
+    </xsd:complexType>
+    <xsd:complexType name="custom-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform">
+                <xsd:sequence>
+                    <xsd:element name="server-class" type="xsd:string"
+                        default="org.eclipse.persistence.platform.server.CustomServerPlatform"
+                        minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                This is the subclass of
+                                org.eclipse.persistence.platform.server.PlatformBase
+                                to specify which server platform to use
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element
+                        name="external-transaction-controller-class" type="xsd:string"
+                        minOccurs="0" />
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="oc4j-903-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="oc4j-904-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="oc4j-1012-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="oc4j-1013-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="oc4j-1111-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform"/>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="weblogic-61-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="weblogic-70-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="weblogic-81-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="websphere-40-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="websphere-50-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="websphere-51-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="websphere-60-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="websphere-61-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="jboss-platform">
+        <xsd:complexContent>
+            <xsd:extension base="server-platform" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="session-broker">
+        <xsd:annotation>
+            <xsd:documentation>
+                Provides a single view to a session that
+                transparently accesses multple databases.
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="session">
+                <xsd:sequence>
+                    <xsd:element name="session-name" type="xsd:string"
+                        maxOccurs="unbounded">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                This is the element that represents the
+                                session name
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:simpleType name="project">
+        <xsd:restriction base="xsd:string" />
+    </xsd:simpleType>
+    <xsd:simpleType name="xml">
+        <xsd:restriction base="project" />
+    </xsd:simpleType>
+    <xsd:simpleType name="class">
+        <xsd:restriction base="project" />
+    </xsd:simpleType>
+    <xsd:complexType name="database-session">
+        <xsd:annotation>
+            <xsd:documentation>
+                The session is the primary interface into EclipseLink, the
+                application should do all of its reading and writing of
+                objects through the session. The session also manages
+                transactions and units of work. The database session is
+                intended for usage in two-tier client-server
+                applications. Although it could be used in a server
+                situation, it is limitted to only having a single
+                database connection and only allows a single open
+                database transaction.
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="session">
+                <xsd:sequence>
+                    <xsd:element name="primary-project" type="project"
+                        minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                This project (class or xml) will be
+                                loaded as the primary project for the
+                                session.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="additional-project"
+                        type="project" minOccurs="0" maxOccurs="unbounded">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Additional projects will have their
+                                descriptors appended to the primary
+                                project.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="login" type="login"
+                        minOccurs="0" />
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="server-session">
+        <xsd:annotation>
+            <xsd:documentation>
+                Is an extension of a DatabaseSession
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="database-session">
+                <xsd:sequence>
+                    <xsd:element name="connection-pools"
+                        minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Connection pools are only for usage with
+                                internal connection pooling and should
+                                not be used if using external connection
+                                pooling
+                            </xsd:documentation>
+                        </xsd:annotation>
+                        <xsd:complexType>
+                            <xsd:sequence>
+                                <xsd:element name="read-connection-pool"
+                                    type="read-connection-pool" minOccurs="0" />
+                                <xsd:element
+                                    name="write-connection-pool" type="connection-pool"
+                                    minOccurs="0" />
+                                <xsd:element
+                                    name="sequence-connection-pool" type="connection-pool"
+                                    minOccurs="0">
+                                    <xsd:annotation>
+                                        <xsd:documentation>
+                                            Set this tag to use the
+                                            sequence connection pool
+                                        </xsd:documentation>
+                                    </xsd:annotation>
+                                </xsd:element>
+                                <xsd:element name="connection-pool"
+                                    type="connection-pool" minOccurs="0" maxOccurs="unbounded" />
+                            </xsd:sequence>
+                        </xsd:complexType>
+                    </xsd:element>
+                    <xsd:element name="connection-policy"
+                        type="connection-policy" minOccurs="0" />
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="connection-policy">
+        <xsd:annotation>
+            <xsd:documentation>
+                Used to specify how default client sessions are acquired
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:sequence>
+            <xsd:element name="exclusive-connection" type="xsd:boolean"
+                default="false" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Specifies if an exclusive connection should be
+                        used for reads, required for VPD, or user based
+                        read security.
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="lazy" type="xsd:boolean" default="true"
+                minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Specifies if a connection should be acquired and
+                        held upfront in the client session, or only
+                        acquired when needed and then released.
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+        </xsd:sequence>
+    </xsd:complexType>
+    <xsd:complexType name="login">
+        <xsd:annotation>
+            <xsd:documentation>
+                Defines common fields for database-login and eis-login
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:sequence>
+            <xsd:element name="platform-class" type="xsd:string"
+                minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This is the element that represents the platform
+                        class name
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="user-name" type="xsd:string"
+                minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This element is used in the login as well as the
+                        Cache Synchronization feature
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="encryption-class" type="xsd:string"
+                default="org.eclipse.persistence.internal.security.JCEEncryptor"
+                minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This element is used in the login as well as the
+                        Cache Synchronization feature
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="password" type="xsd:string"
+                minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This element is used in the login as well as the
+                        Cache Synchronization feature
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="table-qualifier" type="xsd:string"
+                minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Set the default qualifier for all tables. This
+                        can be the creator of the table or database name
+                        the table exists on. This is required by some
+                        databases such as Oracle and DB2.
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="external-connection-pooling"
+                type="xsd:boolean" default="false" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Set to true if the connection should use an
+                        external connection pool
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="external-transaction-controller"
+                type="xsd:boolean" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Set to true if the session will be using an
+                        external transaction controller
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="sequencing" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Sequencing information.
+                    </xsd:documentation>
+                </xsd:annotation>
+                <xsd:complexType>
+                    <xsd:sequence>
+                        <xsd:element name="default-sequence"
+                            type="sequence" minOccurs="0">
+                            <xsd:annotation>
+                                <xsd:documentation>
+                                    Default sequence. The name is
+                                    optional. If no name provided an
+                                    empty string will be used as a name.
+                                </xsd:documentation>
+                            </xsd:annotation>
+                        </xsd:element>
+                        <xsd:element name="sequences" minOccurs="0">
+                            <xsd:annotation>
+                                <xsd:documentation>
+                                    Non default sequences. Make sure
+                                    each sequence has unique name.
+                                </xsd:documentation>
+                            </xsd:annotation>
+                            <xsd:complexType>
+                                <xsd:sequence>
+                                    <xsd:element name="sequence"
+                                        type="sequence" minOccurs="0" maxOccurs="unbounded" />
+                                </xsd:sequence>
+                            </xsd:complexType>
+                        </xsd:element>
+                    </xsd:sequence>
+                </xsd:complexType>
+            </xsd:element>
+            <xsd:element name="property" minOccurs="0"
+                maxOccurs="unbounded">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This element is an optional element of a login.
+                        It is used to define extra properties on the
+                        login
+                    </xsd:documentation>
+                </xsd:annotation>
+                <xsd:complexType>
+                    <xsd:attribute name="name" type="xsd:string"
+                        use="required" />
+                    <xsd:attribute name="value" type="xsd:string"
+                        use="required" />
+                </xsd:complexType>
+            </xsd:element>
+        </xsd:sequence>
+    </xsd:complexType>
+    <xsd:complexType name="database-login">
+        <xsd:annotation>
+            <xsd:documentation>
+                Holds the configuration information necessary to connect
+                to a JDBC driver.
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="login">
+                <xsd:sequence>
+                    <xsd:choice minOccurs="0">
+                        <xsd:sequence>
+                            <xsd:element name="driver-class"
+                                type="xsd:string">
+                                <xsd:annotation>
+                                    <xsd:documentation>
+                                        The driver class is the Java
+                                        class for the JDBC driver to be
+                                        used (e.g.
+                                        sun.jdbc.odbc.JdbcOdbcDriver.class)
+                                    </xsd:documentation>
+                                </xsd:annotation>
+                            </xsd:element>
+                            <xsd:element name="connection-url"
+                                type="xsd:string">
+                                <xsd:annotation>
+                                    <xsd:documentation>
+                                        This is the URL that will be
+                                        used to connect to the database.
+                                    </xsd:documentation>
+                                </xsd:annotation>
+                            </xsd:element>
+                        </xsd:sequence>
+                        <xsd:element name="datasource">
+                            <xsd:annotation>
+                                <xsd:documentation>
+                                    This is the URL of a datasource that
+                                    may be used by the session to
+                                    connect to the database.
+                                </xsd:documentation>
+                            </xsd:annotation>
+                            <xsd:complexType>
+                                <xsd:simpleContent>
+                                    <xsd:extension base="xsd:string">
+                                        <xsd:attribute name="lookup"
+                                            type="lookup-enum" />
+                                    </xsd:extension>
+                                </xsd:simpleContent>
+                            </xsd:complexType>
+                        </xsd:element>
+                    </xsd:choice>
+                    <xsd:element name="bind-all-parameters"
+                        type="xsd:boolean" default="true" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Set whether to bind all arguments to any
+                                SQL statement.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="cache-all-statements"
+                        type="xsd:boolean" default="false" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Set whether prepared statements should
+                                be cached.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="byte-array-binding"
+                        type="xsd:boolean" default="true" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                EclipseLink can be configured to use
+                                parameter binding for large binary data.
+                                By default EclipseLink will print this data
+                                as hex through the JDBC binary excape
+                                clause. Both binding and printing have
+                                various limits on all databases (e.g. 5k
+                                - 32k).
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="string-binding"
+                        type="xsd:boolean" default="false" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Set to true if strings should be bound.
+                                Used to help bean introspection.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="streams-for-binding"
+                        type="xsd:boolean" default="false" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                EclipseLink can be configured to use streams
+                                to store large binary data. This can
+                                improve the max size for reading/writing
+                                on some JDBC drivers.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="force-field-names-to-upper-case"
+                        type="xsd:boolean" default="false" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                This setting can be used if the
+                                application expects upper case but the
+                                database does not return consistent case
+                                (e.g. different databases).
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="optimize-data-conversion"
+                        type="xsd:boolean" default="true" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Set whether driver level data conversion
+                                optimization is enabled. This can be
+                                disabled as some drivers perform data
+                                conversion themselves incorrectly.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="trim-strings" type="xsd:boolean"
+                        default="true" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                By default CHAR field values have
+                                trailing blanks trimmed, this can be
+                                configured.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="batch-writing" type="xsd:boolean"
+                        default="false" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                EclipseLink can be configured to use batch
+                                writing. This facility allows multiple
+                                write operations to be submitted to a
+                                database for processing at once.
+                                Submitting multiple updates together,
+                                instead of individually, can greatly
+                                improve performance in some situations.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="jdbc-batch-writing"
+                        type="xsd:boolean" default="true" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Setting this tag with true indicates to
+                                EclipseLink that the JDBC driver supports
+                                batch writing. EclipseLink's internal batch
+                                writing is disabled. Setting this tag
+                                with false indicates to EclipseLink that the
+                                JDBC driver does not support batch
+                                writing. This will revert to the default
+                                behaviour which is to delegate to
+                                EclipseLink's internal batch writing.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="max-batch-writing-size"
+                        type="xsd:integer" default="32000" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Allow for the max batch writing size to
+                                be set. This allows for the batch size
+                                to be limited as most database have
+                                strict limits. The size is in
+                                characters, the default is 32000 but the
+                                real value depends on the database
+                                configuration.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="native-sql" type="xsd:boolean"
+                        default="false" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                EclipseLink can be configured to use
+                                database specific sql grammar not JDBC
+                                specific. This is because unfortunately
+                                some bridges to not support the full
+                                JDBC standard. By default EclipseLink uses
+                                the JDBC sql grammar.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="struct-converters"
+                        minOccurs="0">
+                        <xsd:complexType>
+                            <xsd:group ref="struct-converters" />
+                        </xsd:complexType>
+                    </xsd:element>
+					<xsd:element name="connection-health-validated-on-error" type="xsd:boolean" minOccurs="0">
+						<xsd:annotation>
+							<xsd:documentation>If true will cause EclipseLink to ping database to determine if an SQLException was cause by a communication failure</xsd:documentation>
+						</xsd:annotation>
+					</xsd:element>
+					<xsd:element name="query-retry-attempt-count" type="xsd:integer" minOccurs="0">
+						<xsd:annotation>
+							<xsd:documentation>Configure the number of attempts EclipseLink will make if EclipseLink is attempting to retry a query.</xsd:documentation>
+						</xsd:annotation>
+					</xsd:element>
+					<xsd:element name="delay-between-reconnect-attempts" type="xsd:integer" minOccurs="0">
+						<xsd:annotation>
+							<xsd:documentation>Configure the time in miliseconds that EclipseLink will wait between attempts to reconnect if EclipseLink is attempting to retry a query.</xsd:documentation>
+						</xsd:annotation>
+					</xsd:element>
+					<xsd:element name="ping-sql" type="xsd:string" minOccurs="0">
+						<xsd:annotation>
+							<xsd:documentation>Override the platform specific SQL that EclipseLink will issue to a connection to determine if the connection is still live.</xsd:documentation>
+						</xsd:annotation>
+					</xsd:element>
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:simpleType name="lookup-enum">
+        <xsd:restriction base="xsd:string">
+            <xsd:enumeration value="composite-name" />
+            <xsd:enumeration value="compound-name" />
+            <xsd:enumeration value="string" />
+        </xsd:restriction>
+    </xsd:simpleType>
+    <xsd:complexType name="eis-login">
+        <xsd:annotation>
+            <xsd:documentation>
+                Defines connection information and datasource
+                properties. There are three ways to connect through EIS,
+                - Provide a JNDI name to the ConnectionFactory and use
+                the default getConnection - Provide a JNDI name to the
+                ConnectionFactory, and a driver specific ConnectionSpec
+                to pass to the getConnection - Connect in a non-managed
+                way directly to the driver specific ConnectionFactory An
+                EISConnectionSpec must be provided to define how to
+                connect to the EIS adapter. The EIS platform can be used
+                to provide datasource/driver specific behavoir such as
+                InteractionSpec and Record conversion.
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="login">
+                <xsd:sequence>
+                    <xsd:element name="connection-spec-class"
+                        type="xsd:string" minOccurs="0" />
+                    <xsd:element name="connection-factory-url"
+                        type="xsd:string" minOccurs="0" />
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="xml-login">
+    	<xsd:annotation>
+    		<xsd:documentation>
+    			Defines login and platform type to be used
+    		</xsd:documentation>
+    	</xsd:annotation>
+    	<xsd:complexContent>
+    		<xsd:extension base="login">
+    			<xsd:sequence>
+    				<xsd:element name="equal-namespace-resolvers"
+    					type="xsd:boolean" maxOccurs="1" minOccurs="0">
+    				</xsd:element>
+    				<xsd:element name="document-preservation-policy"
+    					maxOccurs="1" minOccurs="0"
+    					type="document-preservation-policy">
+
+    				</xsd:element>
+    			</xsd:sequence>
+    		</xsd:extension>
+    	</xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="connection-pool">
+        <xsd:annotation>
+            <xsd:documentation>
+                Used to specify how connections should be pooled in a
+                server session.
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:sequence>
+            <xsd:element name="name" type="xsd:string" />
+            <xsd:element name="max-connections" type="xsd:integer"
+                minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        The max number of connections that will be
+                        created in the pool
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="min-connections" type="xsd:integer"
+                minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        The min number of connections that will aways be
+                        in the pool
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="login" type="login" minOccurs="0" />
+        </xsd:sequence>
+    </xsd:complexType>
+    <xsd:complexType name="read-connection-pool">
+        <xsd:annotation>
+            <xsd:documentation>
+                The read connection pool is used for read access through
+                the server session. Any of the connection pools can be
+                used for the read pool however this is the default. This
+                pool allows for concurrent reads against the same JDBC
+                connection and requires that the JDBC connection support
+                concurrent read access.
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="connection-pool">
+                <xsd:sequence>
+                    <xsd:element name="exclusive" type="xsd:boolean"
+                        default="false" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                This tag is used to specify if the
+                                connections from the read connection
+                                pool are exclusive or not
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="log">
+        <xsd:annotation>
+            <xsd:documentation>
+                Defines the common logging options
+            </xsd:documentation>
+        </xsd:annotation>
+    </xsd:complexType>
+    <xsd:complexType name="java-log">
+        <xsd:annotation>
+            <xsd:documentation>
+                Defines the options of the Java log
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="log">
+                <xsd:sequence>
+                    <xsd:element name="logging-options"
+                        type="logging-options" minOccurs="0" />
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="eclipselink-log">
+        <xsd:annotation>
+            <xsd:documentation>
+                Defines the options of the EclipseLink log
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="log">
+                <xsd:sequence>
+                    <xsd:element name="log-level" default="info"
+                        minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                This element specifies the log level for logging
+                            </xsd:documentation>
+                        </xsd:annotation>
+                        <xsd:simpleType>
+                            <xsd:restriction base="xsd:string">
+                                <xsd:enumeration value="off" />
+                                <xsd:enumeration value="severe" />
+                                <xsd:enumeration value="warning" />
+                                <xsd:enumeration value="info" />
+                                <xsd:enumeration value="config" />
+                                <xsd:enumeration value="fine" />
+                                <xsd:enumeration value="finer" />
+                                <xsd:enumeration value="finest" />
+                                <xsd:enumeration value="all" />
+                            </xsd:restriction>
+                        </xsd:simpleType>
+                    </xsd:element>
+                    <xsd:element name="file-name" type="xsd:string"
+                        minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Name of the file to write the logging to
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="logging-options"
+                        type="logging-options" minOccurs="0" />
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="server-log">
+        <xsd:annotation>
+            <xsd:documentation>
+                Defines the options of the Server log
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="log" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="logging-options">
+        <xsd:sequence>
+            <xsd:element name="log-exception-stacktrace"
+                type="xsd:boolean" default="false" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Set whether to log exception stacktrace. Without
+                        this element, the stacktrace is logged for FINER
+                        or less (FINEST)
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="print-thread" type="xsd:boolean"
+                default="false" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Set whether to log thread. Without this element,
+                        the thread is logged for FINE or less (FINER or
+                        FINEST)
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="print-session" type="xsd:boolean"
+                default="true" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Set whether to log session. Without this
+                        element, the session is always printed
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="print-connection" type="xsd:boolean"
+                default="true" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Set whether to log connection. Without this
+                        element, the connection is always printed
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="print-date" type="xsd:boolean"
+                default="true" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Set whether to log date. Without this element,
+                        the date is always printed
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+        </xsd:sequence>
+    </xsd:complexType>
+    <xsd:complexType name="transport-manager">
+        <xsd:annotation>
+            <xsd:documentation>
+                This element defines the transport mechanism of the RCM.
+                The default transport mechanism is RMI
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:sequence>
+            <xsd:element name="on-connection-error"
+                default="DiscardConnection" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This element is an optional element of transport
+                        element and has value of "DiscardConnection" or
+                        "KeepConnection". It determines whether
+                        connection to a RCM service should be dropped if
+                        there is a communication error with that RCM
+                        service. The default value for this element is
+                        "DiscardConnection".
+                    </xsd:documentation>
+                </xsd:annotation>
+                <xsd:simpleType>
+                    <xsd:restriction base="xsd:string">
+                        <xsd:enumeration value="KeepConnection" />
+                        <xsd:enumeration value="DiscardConnection" />
+                    </xsd:restriction>
+                </xsd:simpleType>
+            </xsd:element>
+        </xsd:sequence>
+    </xsd:complexType>
+    <xsd:complexType name="rmi-transport">
+        <xsd:annotation>
+            <xsd:documentation>
+                This element is an optional element of transport
+                element. It defines the RMI transport mechanism. The
+                default naming service is JNDI
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="transport-manager">
+                <xsd:sequence>
+                    <xsd:element name="send-mode" default="Asynchronous"
+                        minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                This element is an optional element of
+                                rmi element and has value of
+                                "Asynchronous" or "Synchronous". It
+                                determines whether the RCM propagates
+                                command and does not wait for command to
+                                finish its execution in asynchronous
+                                mode or wait for command to finish its
+                                execution in synchronous mode. The
+                                default value of this element is
+                                "Asynchronous".
+                            </xsd:documentation>
+                        </xsd:annotation>
+                        <xsd:simpleType>
+                            <xsd:restriction base="xsd:string">
+                                <xsd:enumeration value="Asynchronous" />
+                                <xsd:enumeration value="Synchronous" />
+                            </xsd:restriction>
+                        </xsd:simpleType>
+                    </xsd:element>
+                    <xsd:element name="discovery" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                This element is an optional element of
+                                rmi element. It determines whether the
+                                Discovery settings should be changed.
+                                Note that a default Discovery with its
+                                default settings is created when the rmi
+                                element is specified.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                        <xsd:complexType>
+                            <xsd:sequence>
+                                <xsd:element
+                                    name="multicast-group-address" type="xsd:string"
+                                    default="226.10.12.64" minOccurs="0" />
+                                <xsd:element name="multicast-port"
+                                    type="xsd:integer" default="3121" minOccurs="0" />
+                                <xsd:element name="announcement-delay"
+                                    type="xsd:integer" default="1000" minOccurs="0">
+                                    <xsd:annotation>
+                                        <xsd:documentation>
+                                            This element is an optional
+                                            element of discovery
+                                            elemenent. It determines
+                                            whether the multicast group
+                                            address should be changed.
+                                            The default value of this
+                                            element is "1000"
+                                        </xsd:documentation>
+                                    </xsd:annotation>
+                                </xsd:element>
+                                <xsd:element name="packet-time-to-live"
+                                    type="xsd:integer" default="2" minOccurs="0">
+                                    <xsd:annotation>
+                                        <xsd:documentation>
+                                            This element is an optional
+                                            element of discovery
+                                            elemenent. It determines
+                                            whether the time-to-live of
+                                            the packets that are sent
+                                            from the Discovery's
+                                            mulsticast socket should be
+                                            changed. The default value
+                                            of this element is "2"
+                                        </xsd:documentation>
+                                    </xsd:annotation>
+                                </xsd:element>
+                            </xsd:sequence>
+                        </xsd:complexType>
+                    </xsd:element>
+                    <xsd:choice minOccurs="0">
+                        <xsd:element name="jndi-naming-service"
+                            type="jndi-naming-service" />
+                        <xsd:element
+                            name="rmi-registry-naming-service">
+                            <xsd:annotation>
+                                <xsd:documentation>
+                                    This element is an optional element
+                                    of rmi elemenent. It determines
+                                    whether RMI registry should be used
+                                    for naming service
+                                </xsd:documentation>
+                            </xsd:annotation>
+                            <xsd:complexType>
+                                <xsd:sequence>
+                                    <xsd:element name="url"
+                                        type="xsd:string" minOccurs="0" />
+                                </xsd:sequence>
+                            </xsd:complexType>
+                        </xsd:element>
+                    </xsd:choice>
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="rmi-iiop-transport">
+        <xsd:annotation>
+            <xsd:documentation>
+                This element defines the RMI-IIOP transport mechanism of
+                the RCM. The default naming service is JNDI
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="rmi-transport" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="jms-topic-transport">
+        <xsd:annotation>
+            <xsd:documentation>
+                This element defines the JMS topic transport mechanism
+                of the RCM
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="transport-manager">
+                <xsd:sequence>
+                    <xsd:element name="topic-host-url" type="xsd:string"
+                        minOccurs="0" />
+                    <xsd:element name="topic-connection-factory-name"
+                        type="xsd:string" default="jms/EclipseLinkTopicConnectionFactory"
+                        minOccurs="0" />
+                    <xsd:element name="topic-name" type="xsd:string"
+                        default="jms/EclipseLinkTopic" minOccurs="0" />
+                    <xsd:element name="jndi-naming-service"
+                        type="jndi-naming-service" />
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="oc4j-jgroups-transport">
+        <xsd:annotation>
+            <xsd:documentation>
+                This element defines the OC4J JGroups transport
+                mechanism of the RCM
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="transport-manager">
+                <xsd:sequence>
+                    <xsd:element name="use-single-threaded-notification"
+                        type="xsd:boolean" default="false" minOccurs="0" />
+                    <xsd:element name="topic-name" type="xsd:string"
+                        minOccurs="0" />
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="sun-corba-transport">
+        <xsd:annotation>
+            <xsd:documentation>
+                This element defines the Sun CORBA transport mechanism
+                of the RCM
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="transport-manager" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="user-defined-transport">
+        <xsd:annotation>
+            <xsd:documentation>
+                This element is an optional element of transport
+                element. It determines whether a user implemented
+                transport mechanism that should be used.
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="transport-manager">
+                <xsd:sequence>
+                    <xsd:element name="transport-class"
+                        type="xsd:string" />
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="jndi-naming-service">
+        <xsd:sequence>
+            <xsd:element name="url" type="xsd:string" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This element is an optional element of
+                        jndi-naming-service. It determines whether the
+                        URL for naming service should be changed. 
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="user-name" type="xsd:string"
+                default="admin" minOccurs="0" />
+            <xsd:element name="encryption-class" type="xsd:string"
+                default="org.eclipse.persistence.internal.security.JCEEncryptor"
+                minOccurs="0" />
+            <xsd:element name="password" type="xsd:string"
+                default="password" minOccurs="0" />
+            <!--  TODO: Need to have a non Oracle-AS default or route through server platform by default -->
+            <xsd:element name="initial-context-factory-name"
+                type="xsd:string"
+                default="com.evermind.server.rmi.RMIInitialContextFactory"
+                minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This element is an optional element of
+                        jndi-naming-service. It determines whether the
+                        initial context factory class for naming service
+                        should be changed. 
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="property" minOccurs="0"
+                maxOccurs="unbounded">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        This element is an optional element of
+                        jndi-naming-service. It determines whether
+                        naming service requires extra property that is
+                        not defined by EclipseLink but it is required by the
+                        user application
+                    </xsd:documentation>
+                </xsd:annotation>
+                <xsd:complexType>
+                    <xsd:attribute name="name" type="xsd:string"
+                        use="required" />
+                    <xsd:attribute name="value" type="xsd:string"
+                        use="required" />
+                </xsd:complexType>
+            </xsd:element>
+        </xsd:sequence>
+    </xsd:complexType>
+    <xsd:group name="event-listener-classes">
+        <xsd:sequence>
+            <xsd:element name="event-listener-class" type="xsd:string"
+                minOccurs="0" maxOccurs="unbounded" />
+        </xsd:sequence>
+    </xsd:group>
+    <xsd:group name="struct-converters">
+        <xsd:sequence>
+            <xsd:element name="struct-converter" type="xsd:string"
+                minOccurs="0" maxOccurs="unbounded" />
+        </xsd:sequence>
+    </xsd:group>
+    <xsd:complexType name="sequence">
+        <xsd:annotation>
+            <xsd:documentation>Sequence object.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:sequence>
+            <xsd:element name="name" type="xsd:string" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Sequence name.
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+            <xsd:element name="preallocation-size" type="xsd:integer"
+                default="50" minOccurs="0">
+                <xsd:annotation>
+                    <xsd:documentation>
+                        Sequence preallocation size.
+                    </xsd:documentation>
+                </xsd:annotation>
+            </xsd:element>
+        </xsd:sequence>
+    </xsd:complexType>
+    <xsd:complexType name="default-sequence">
+        <xsd:annotation>
+            <xsd:documentation>
+                References default sequence object, overriding its name
+                and (optionally) preallocation size.
+            </xsd:documentation>
+            <xsd:documentation>
+                To use preallocation size of default sequence object,
+                set preallocation size to 0
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="sequence" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="native-sequence">
+        <xsd:annotation>
+            <xsd:documentation>
+                Database sequence mechanism used.
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="sequence" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="table-sequence">
+        <xsd:annotation>
+            <xsd:documentation>Table sequence</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="sequence">
+                <xsd:sequence>
+                    <xsd:element name="table" type="xsd:string"
+                        default="SEQUENCE" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Define the name of the sequence table.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="name-field" type="xsd:string"
+                        default="SEQ_NAME" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Define the name of the sequence name
+                                field in the sequence table.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="counter-field" type="xsd:string"
+                        default="SEQ_COUNT" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Define the name of the sequence counter
+                                field in the sequence table.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="unary-table-sequence">
+        <xsd:annotation>
+            <xsd:documentation>
+                Unary table sequence - sequence name is a table name,
+                table has a single field and a single row
+            </xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="sequence">
+                <xsd:sequence>
+                    <xsd:element name="counter-field" type="xsd:string"
+                        default="SEQUENCE" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Define the name of the sequence counter
+                                field in the sequence table.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="xmlfile-sequence">
+        <xsd:annotation>
+            <xsd:documentation>Xmlfile sequence.</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="sequence" />
+        </xsd:complexContent>
+    </xsd:complexType>
+    <xsd:complexType name="xml-sequence">
+        <xsd:annotation>
+            <xsd:documentation>Xml sequence</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+            <xsd:extension base="sequence">
+                <xsd:sequence>
+                    <xsd:element name="root-element" type="xsd:string"
+                        default="SEQUENCE" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Define the name of the sequence table.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="name-element" type="xsd:string"
+                        default="SEQ_NAME" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Define the name of the sequence name
+                                field in the sequence table.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                    <xsd:element name="counter-element"
+                        type="xsd:string" default="SEQ_COUNT" minOccurs="0">
+                        <xsd:annotation>
+                            <xsd:documentation>
+                                Define the name of the sequence counter
+                                field in the sequence table.
+                            </xsd:documentation>
+                        </xsd:annotation>
+                    </xsd:element>
+                </xsd:sequence>
+            </xsd:extension>
+        </xsd:complexContent>
+    </xsd:complexType>
+
+
+
+    <xsd:complexType name="document-preservation-policy">
+        <xsd:annotation>
+        	<xsd:documentation>
+        		This element specifies which document preservation
+        		strategy will be used.
+        	</xsd:documentation>
+        </xsd:annotation>
+        <xsd:sequence>
+    		<xsd:element name="node-ordering-policy"
+    			type="node-ordering-policy" maxOccurs="1" minOccurs="0">
+    		</xsd:element>
+    	</xsd:sequence>
+    </xsd:complexType>
+
+    <xsd:complexType name="node-ordering-policy">
+    	<xsd:annotation>
+    		<xsd:documentation>
+    			This element specifies which node ordering strategy will
+    			be used.
+    		</xsd:documentation>
+    	</xsd:annotation></xsd:complexType>
+
+    <xsd:complexType
+    	name="descriptor-level-document-preservation-policy">
+        <xsd:annotation>
+        	<xsd:documentation>
+        		An implementation of DocumentPreservation Policy that
+        		accesses the session cache to store Objects and their
+        		associated nodes.
+        	</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+    		<xsd:extension base="document-preservation-policy"></xsd:extension>
+    	</xsd:complexContent>
+    </xsd:complexType>
+
+    <xsd:complexType name="no-document-preservation-policy">
+        <xsd:annotation>
+        	<xsd:documentation>
+        		A DocumentPreservationPolicy to indicate that no
+        		document preservation work should be done.
+        	</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+    		<xsd:extension base="document-preservation-policy"></xsd:extension>
+    	</xsd:complexContent>
+    </xsd:complexType>
+
+    <xsd:complexType name="xml-binder-policy">
+        <xsd:annotation>
+        	<xsd:documentation>
+        		An implementation of DocumentPreservationPolicy that
+        		maintains bidirectional relationships between Java
+        		Objects and the XMLNodes they originated from.
+        	</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+    		<xsd:extension base="document-preservation-policy"></xsd:extension>
+    	</xsd:complexContent>
+    </xsd:complexType>
+
+    <xsd:complexType name="append-new-elements-ordering-policy">
+        <xsd:annotation>
+        	<xsd:documentation>
+        		An implementation of NodeOrderingPolicy that simply
+        		appends the new child element to the parent.
+        	</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+    		<xsd:extension base="node-ordering-policy"></xsd:extension>
+    	</xsd:complexContent>
+    </xsd:complexType>
+
+    <xsd:complexType name="ignore-new-elements-ordering-policy">
+        <xsd:annotation>
+        	<xsd:documentation>
+        		An implementation of NodeOrderingPolicy that ignores any
+        		new elements when updating a cached document.
+        	</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+    		<xsd:extension base="node-ordering-policy"></xsd:extension>
+    	</xsd:complexContent>
+    </xsd:complexType>
+
+    <xsd:complexType name="relative-position-ordering-policy">
+        <xsd:annotation>
+        	<xsd:documentation>
+        		An implementation of NodeOrderingPolicy that adds new
+        		elements to an XML Document based on the last updated
+        		sibling in their context.
+        	</xsd:documentation>
+        </xsd:annotation>
+        <xsd:complexContent>
+    		<xsd:extension base="node-ordering-policy"></xsd:extension>
+    	</xsd:complexContent>
+    </xsd:complexType>
+</xsd:schema>
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/oxm/documentpreservation/DescriptorLevelDocumentPreservationPolicy.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/oxm/documentpreservation/DescriptorLevelDocumentPreservationPolicy.java	(revision 2248)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/oxm/documentpreservation/DescriptorLevelDocumentPreservationPolicy.java	(working copy)
@@ -43,10 +43,16 @@
 public class DescriptorLevelDocumentPreservationPolicy extends DocumentPreservationPolicy {
  
     private XMLContext context;
-    public DescriptorLevelDocumentPreservationPolicy(XMLContext ctx) {
+    
+    public DescriptorLevelDocumentPreservationPolicy() {
+        super();
+        this.setNodeOrderingPolicy(new AppendNewElementsOrderingPolicy());        
+    }
+    
+    public void initialize(XMLContext ctx) {
         context = ctx;
-        this.setNodeOrderingPolicy(new AppendNewElementsOrderingPolicy());
     }
+    
     public void addObjectToCache(Object obj, Node node) {
         this.addObjectToCache(obj, node, null);
     }
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/AppendNewElementsOrderingPolicyConfig.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/AppendNewElementsOrderingPolicyConfig.java	(revision 0)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/AppendNewElementsOrderingPolicyConfig.java	(revision 0)
@@ -0,0 +1,17 @@
+/*******************************************************************************
+ * Copyright (c) 1998, 2008 Oracle. All rights reserved.
+ * This program and the accompanying materials are made available under the 
+ * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 
+ * which accompanies this distribution. 
+ * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
+ * and the Eclipse Distribution License is available at 
+ * http://www.eclipse.org/org/documents/edl-v10.php.
+ *
+ * Contributors:
+ *     rbarkhou - new Policy Config classes for XMLLogin XML Support
+ ******************************************************************************/  
+package org.eclipse.persistence.internal.sessions.factories.model.login;
+
+public class AppendNewElementsOrderingPolicyConfig extends NodeOrderingPolicyConfig {
+
+}
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/DescriptorLevelDocumentPreservationPolicyConfig.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/DescriptorLevelDocumentPreservationPolicyConfig.java	(revision 0)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/DescriptorLevelDocumentPreservationPolicyConfig.java	(revision 0)
@@ -0,0 +1,17 @@
+/*******************************************************************************
+ * Copyright (c) 1998, 2008 Oracle. All rights reserved.
+ * This program and the accompanying materials are made available under the 
+ * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 
+ * which accompanies this distribution. 
+ * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
+ * and the Eclipse Distribution License is available at 
+ * http://www.eclipse.org/org/documents/edl-v10.php.
+ *
+ * Contributors:
+ *     rbarkhou - new Policy Config classes for XMLLogin XML Support
+ ******************************************************************************/  
+package org.eclipse.persistence.internal.sessions.factories.model.login;
+
+public class DescriptorLevelDocumentPreservationPolicyConfig extends DocumentPreservationPolicyConfig {
+
+}
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/DocumentPreservationPolicyConfig.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/DocumentPreservationPolicyConfig.java	(revision 0)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/DocumentPreservationPolicyConfig.java	(revision 0)
@@ -0,0 +1,27 @@
+/*******************************************************************************
+ * Copyright (c) 1998, 2008 Oracle. All rights reserved.
+ * This program and the accompanying materials are made available under the 
+ * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 
+ * which accompanies this distribution. 
+ * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
+ * and the Eclipse Distribution License is available at 
+ * http://www.eclipse.org/org/documents/edl-v10.php.
+ *
+ * Contributors:
+ *     rbarkhou - new Policy Config classes for XMLLogin XML Support
+ ******************************************************************************/  
+package org.eclipse.persistence.internal.sessions.factories.model.login;
+
+public abstract class DocumentPreservationPolicyConfig {
+
+    private NodeOrderingPolicyConfig m_nodeOrderingPolicy;
+
+    public NodeOrderingPolicyConfig getNodeOrderingPolicy() {
+        return m_nodeOrderingPolicy;
+    }
+
+    public void setNodeOrderingPolicy(NodeOrderingPolicyConfig value) {
+        m_nodeOrderingPolicy = value;
+    }
+
+}
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/IgnoreNewElementsOrderingPolicyConfig.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/IgnoreNewElementsOrderingPolicyConfig.java	(revision 0)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/IgnoreNewElementsOrderingPolicyConfig.java	(revision 0)
@@ -0,0 +1,17 @@
+/*******************************************************************************
+ * Copyright (c) 1998, 2008 Oracle. All rights reserved.
+ * This program and the accompanying materials are made available under the 
+ * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 
+ * which accompanies this distribution. 
+ * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
+ * and the Eclipse Distribution License is available at 
+ * http://www.eclipse.org/org/documents/edl-v10.php.
+ *
+ * Contributors:
+ *     rbarkhou - new Policy Config classes for XMLLogin XML Support
+ ******************************************************************************/  
+package org.eclipse.persistence.internal.sessions.factories.model.login;
+
+public class IgnoreNewElementsOrderingPolicyConfig extends NodeOrderingPolicyConfig {
+
+}
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/NodeOrderingPolicyConfig.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/NodeOrderingPolicyConfig.java	(revision 0)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/NodeOrderingPolicyConfig.java	(revision 0)
@@ -0,0 +1,17 @@
+/*******************************************************************************
+ * Copyright (c) 1998, 2008 Oracle. All rights reserved.
+ * This program and the accompanying materials are made available under the 
+ * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 
+ * which accompanies this distribution. 
+ * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
+ * and the Eclipse Distribution License is available at 
+ * http://www.eclipse.org/org/documents/edl-v10.php.
+ *
+ * Contributors:
+ *     rbarkhou - new Policy Config classes for XMLLogin XML Support
+ ******************************************************************************/  
+package org.eclipse.persistence.internal.sessions.factories.model.login;
+
+public abstract class NodeOrderingPolicyConfig {
+
+}
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/NoDocumentPreservationPolicyConfig.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/NoDocumentPreservationPolicyConfig.java	(revision 0)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/NoDocumentPreservationPolicyConfig.java	(revision 0)
@@ -0,0 +1,17 @@
+/*******************************************************************************
+ * Copyright (c) 1998, 2008 Oracle. All rights reserved.
+ * This program and the accompanying materials are made available under the 
+ * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 
+ * which accompanies this distribution. 
+ * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
+ * and the Eclipse Distribution License is available at 
+ * http://www.eclipse.org/org/documents/edl-v10.php.
+ *
+ * Contributors:
+ *     rbarkhou - new Policy Config classes for XMLLogin XML Support
+ ******************************************************************************/  
+package org.eclipse.persistence.internal.sessions.factories.model.login;
+
+public class NoDocumentPreservationPolicyConfig extends DocumentPreservationPolicyConfig {
+
+}
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/RelativePositionOrderingPolicyConfig.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/RelativePositionOrderingPolicyConfig.java	(revision 0)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/RelativePositionOrderingPolicyConfig.java	(revision 0)
@@ -0,0 +1,17 @@
+/*******************************************************************************
+ * Copyright (c) 1998, 2008 Oracle. All rights reserved.
+ * This program and the accompanying materials are made available under the 
+ * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 
+ * which accompanies this distribution. 
+ * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
+ * and the Eclipse Distribution License is available at 
+ * http://www.eclipse.org/org/documents/edl-v10.php.
+ *
+ * Contributors:
+ *     rbarkhou - new Policy Config classes for XMLLogin XML Support
+ ******************************************************************************/  
+package org.eclipse.persistence.internal.sessions.factories.model.login;
+
+public class RelativePositionOrderingPolicyConfig extends NodeOrderingPolicyConfig {
+
+}
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/XMLBinderPolicyConfig.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/XMLBinderPolicyConfig.java	(revision 0)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/XMLBinderPolicyConfig.java	(revision 0)
@@ -0,0 +1,17 @@
+/*******************************************************************************
+ * Copyright (c) 1998, 2008 Oracle. All rights reserved.
+ * This program and the accompanying materials are made available under the 
+ * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 
+ * which accompanies this distribution. 
+ * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
+ * and the Eclipse Distribution License is available at 
+ * http://www.eclipse.org/org/documents/edl-v10.php.
+ *
+ * Contributors:
+ *     rbarkhou - new Policy Config classes for XMLLogin XML Support
+ ******************************************************************************/  
+package org.eclipse.persistence.internal.sessions.factories.model.login;
+
+public class XMLBinderPolicyConfig extends DocumentPreservationPolicyConfig {
+
+}
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/XMLLoginConfig.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/XMLLoginConfig.java	(revision 2248)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/model/login/XMLLoginConfig.java	(working copy)
@@ -12,12 +12,33 @@
  ******************************************************************************/  
 package org.eclipse.persistence.internal.sessions.factories.model.login;
 
-
 /**
  * INTERNAL:
  */
 public class XMLLoginConfig extends LoginConfig {
+
+    private boolean m_equalNamespaceResolvers;
+    private DocumentPreservationPolicyConfig m_documentPreservationPolicy;
+
     public XMLLoginConfig() {
         super();
+        m_equalNamespaceResolvers = true;
     }
+
+    public boolean getEqualNamespaceResolvers() {
+        return m_equalNamespaceResolvers;
+    }
+
+    public void setEqualNamespaceResolvers(boolean value) {
+        m_equalNamespaceResolvers = value;
+    }
+
+    public DocumentPreservationPolicyConfig getDocumentPreservationPolicy() {
+        return m_documentPreservationPolicy;
+    }
+
+    public void setDocumentPreservationPolicy(DocumentPreservationPolicyConfig value) {
+        m_documentPreservationPolicy = value;
+    }
+
 }
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/ObjectPersistenceRuntimeXMLProject_11_1_1.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/ObjectPersistenceRuntimeXMLProject_11_1_1.java	(revision 2248)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/ObjectPersistenceRuntimeXMLProject_11_1_1.java	(working copy)
@@ -48,6 +48,11 @@
 import org.eclipse.persistence.mappings.transformers.ConstantTransformer;
 import org.eclipse.persistence.oxm.XMLDescriptor;
 import org.eclipse.persistence.oxm.XMLField;
+import org.eclipse.persistence.oxm.documentpreservation.AppendNewElementsOrderingPolicy;
+import org.eclipse.persistence.oxm.documentpreservation.DocumentPreservationPolicy;
+import org.eclipse.persistence.oxm.documentpreservation.IgnoreNewElementsOrderingPolicy;
+import org.eclipse.persistence.oxm.documentpreservation.NodeOrderingPolicy;
+import org.eclipse.persistence.oxm.documentpreservation.RelativePositionOrderingPolicy;
 import org.eclipse.persistence.oxm.mappings.UnmarshalKeepAsElementPolicy;
 import org.eclipse.persistence.oxm.mappings.XMLAnyAttributeMapping;
 import org.eclipse.persistence.oxm.mappings.XMLBinaryDataMapping;
@@ -63,6 +68,9 @@
 import org.eclipse.persistence.oxm.mappings.XMLChoiceCollectionMapping;
 import org.eclipse.persistence.oxm.mappings.XMLChoiceObjectMapping;
 import org.eclipse.persistence.internal.oxm.XMLChoiceFieldToClassAssociation;
+import org.eclipse.persistence.internal.oxm.documentpreservation.DescriptorLevelDocumentPreservationPolicy;
+import org.eclipse.persistence.internal.oxm.documentpreservation.NoDocumentPreservationPolicy;
+import org.eclipse.persistence.internal.oxm.documentpreservation.XMLBinderPolicy;
 import org.eclipse.persistence.oxm.mappings.nullpolicy.AbstractNullPolicy;
 import org.eclipse.persistence.oxm.mappings.nullpolicy.IsSetNullPolicy;
 import org.eclipse.persistence.oxm.mappings.nullpolicy.NullPolicy;
@@ -146,6 +154,16 @@
 
         // 5757849 -- add metadata support for ObjectRelationalDatabaseField
         addDescriptor(buildObjectRelationalDatabaseFieldDescriptor());
+        
+        // 242452 -- add metadata support for XMLLogin's DocumentPreservationPolicy
+        addDescriptor(buildDocumentPreservationPolicyDescriptor());
+        addDescriptor(buildDescriptorLevelDocumentPreservationPolicyDescriptor());
+        addDescriptor(buildNoDocumentPreservationPolicyDescriptor());
+        addDescriptor(buildXMLBinderPolicyDescriptor());
+        addDescriptor(buildNodeOrderingPolicyDescriptor());
+        addDescriptor(buildAppendNewElementsOrderingPolicyDescriptor());
+        addDescriptor(buildIgnoreNewElementsOrderingPolicyDescriptor());
+        addDescriptor(buildRelativePositionOrderingPolicyDescriptor());
     }
 
     @Override
@@ -1104,9 +1122,98 @@
         equalNamespaceResolversMapping.setNullValue(Boolean.TRUE);
         descriptor.addMapping(equalNamespaceResolversMapping);
 
+        XMLCompositeObjectMapping documentPreservationPolicyMapping = new XMLCompositeObjectMapping();
+        documentPreservationPolicyMapping.setReferenceClass(DocumentPreservationPolicy.class);
+        documentPreservationPolicyMapping.setAttributeName("documentPreservationPolicy");
+        documentPreservationPolicyMapping.setGetMethodName("getDocumentPreservationPolicy");
+        documentPreservationPolicyMapping.setSetMethodName("setDocumentPreservationPolicy");
+        documentPreservationPolicyMapping.setXPath(getPrimaryNamespaceXPath() + "document-preservation-policy");
+        descriptor.addMapping(documentPreservationPolicyMapping);
+
         return descriptor;
     }
 
+    protected ClassDescriptor buildDocumentPreservationPolicyDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(DocumentPreservationPolicy.class);
+        descriptor.setDefaultRootElement("document-preservation-policy");
+
+        XMLCompositeObjectMapping nodeOrderingPolicyMapping = new XMLCompositeObjectMapping();
+        nodeOrderingPolicyMapping.setReferenceClass(NodeOrderingPolicy.class);
+        nodeOrderingPolicyMapping.setAttributeName("nodeOrderingPolicy");
+        nodeOrderingPolicyMapping.setGetMethodName("getNodeOrderingPolicy");
+        nodeOrderingPolicyMapping.setSetMethodName("setNodeOrderingPolicy");
+        nodeOrderingPolicyMapping.setXPath(getPrimaryNamespaceXPath() + "node-ordering-policy");
+        descriptor.addMapping(nodeOrderingPolicyMapping);
+
+        descriptor.getInheritancePolicy().setClassIndicatorField(new XMLField("@xsi:type"));
+        descriptor.getInheritancePolicy().addClassIndicator(DescriptorLevelDocumentPreservationPolicy.class, getPrimaryNamespaceXPath() + "descriptor-level-document-preservation-policy");
+        descriptor.getInheritancePolicy().addClassIndicator(NoDocumentPreservationPolicy.class, getPrimaryNamespaceXPath() + "no-document-preservation-policy");
+        descriptor.getInheritancePolicy().addClassIndicator(XMLBinderPolicy.class, getPrimaryNamespaceXPath() + "xml-binder-policy");
+
+        return descriptor;
+    }
+
+    protected ClassDescriptor buildDescriptorLevelDocumentPreservationPolicyDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(DescriptorLevelDocumentPreservationPolicy.class);
+        descriptor.getInheritancePolicy().setParentClass(DocumentPreservationPolicy.class);
+
+        return descriptor;
+    }
+
+    protected ClassDescriptor buildNoDocumentPreservationPolicyDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(NoDocumentPreservationPolicy.class);
+        descriptor.getInheritancePolicy().setParentClass(DocumentPreservationPolicy.class);
+
+        return descriptor;
+    }
+
+    protected ClassDescriptor buildXMLBinderPolicyDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(XMLBinderPolicy.class);
+        descriptor.getInheritancePolicy().setParentClass(DocumentPreservationPolicy.class);
+
+        return descriptor;
+    }
+    
+    protected ClassDescriptor buildNodeOrderingPolicyDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(NodeOrderingPolicy.class);
+
+        descriptor.getInheritancePolicy().setClassIndicatorField(new XMLField("@xsi:type"));
+        descriptor.getInheritancePolicy().addClassIndicator(AppendNewElementsOrderingPolicy.class, getPrimaryNamespaceXPath() + "append-new-elements-ordering-policy");
+        descriptor.getInheritancePolicy().addClassIndicator(IgnoreNewElementsOrderingPolicy.class, getPrimaryNamespaceXPath() + "ignore-new-elements-ordering-policy");
+        descriptor.getInheritancePolicy().addClassIndicator(RelativePositionOrderingPolicy.class, getPrimaryNamespaceXPath() + "relative-position-ordering-policy");
+
+        return descriptor;
+    }
+
+    protected ClassDescriptor buildAppendNewElementsOrderingPolicyDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(AppendNewElementsOrderingPolicy.class);
+        descriptor.getInheritancePolicy().setParentClass(NodeOrderingPolicy.class);
+
+        return descriptor;
+    }
+
+    protected ClassDescriptor buildIgnoreNewElementsOrderingPolicyDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(IgnoreNewElementsOrderingPolicy.class);
+        descriptor.getInheritancePolicy().setParentClass(NodeOrderingPolicy.class);
+
+        return descriptor;
+    }
+
+    protected ClassDescriptor buildRelativePositionOrderingPolicyDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(RelativePositionOrderingPolicy.class);
+        descriptor.getInheritancePolicy().setParentClass(NodeOrderingPolicy.class);
+
+        return descriptor;
+    }
+
     protected ClassDescriptor buildAbstractNullPolicyDescriptor() {
          XMLDescriptor aDescriptor = new XMLDescriptor();
          aDescriptor.setJavaClass(AbstractNullPolicy.class);
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/XMLSessionConfigProject_11_1_1.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/XMLSessionConfigProject_11_1_1.java	(revision 2248)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/internal/sessions/factories/XMLSessionConfigProject_11_1_1.java	(working copy)
@@ -12,10 +12,36 @@
  ******************************************************************************/  
 package org.eclipse.persistence.internal.sessions.factories;
 
+import static javax.xml.XMLConstants.W3C_XML_SCHEMA_INSTANCE_NS_URI;
+import static javax.xml.XMLConstants.W3C_XML_SCHEMA_NS_URI;
+
+import java.util.Iterator;
+
 import org.eclipse.persistence.descriptors.ClassDescriptor;
+import org.eclipse.persistence.oxm.NamespaceResolver;
 import org.eclipse.persistence.oxm.XMLDescriptor;
+import org.eclipse.persistence.oxm.XMLField;
+import org.eclipse.persistence.oxm.documentpreservation.AppendNewElementsOrderingPolicy;
+import org.eclipse.persistence.oxm.documentpreservation.DocumentPreservationPolicy;
+import org.eclipse.persistence.oxm.documentpreservation.IgnoreNewElementsOrderingPolicy;
+import org.eclipse.persistence.oxm.documentpreservation.NodeOrderingPolicy;
+import org.eclipse.persistence.oxm.documentpreservation.RelativePositionOrderingPolicy;
+import org.eclipse.persistence.oxm.mappings.XMLCompositeObjectMapping;
 import org.eclipse.persistence.oxm.mappings.XMLDirectMapping;
 import org.eclipse.persistence.oxm.mappings.nullpolicy.NullPolicy;
+import org.eclipse.persistence.internal.oxm.documentpreservation.DescriptorLevelDocumentPreservationPolicy;
+import org.eclipse.persistence.internal.oxm.documentpreservation.NoDocumentPreservationPolicy;
+import org.eclipse.persistence.internal.oxm.documentpreservation.XMLBinderPolicy;
+import org.eclipse.persistence.internal.sessions.factories.model.login.AppendNewElementsOrderingPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.DescriptorLevelDocumentPreservationPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.DocumentPreservationPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.IgnoreNewElementsOrderingPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.LoginConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.NoDocumentPreservationPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.NodeOrderingPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.RelativePositionOrderingPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.XMLBinderPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.XMLLoginConfig;
 import org.eclipse.persistence.internal.sessions.factories.model.platform.Oc4jPlatformConfig;
 import org.eclipse.persistence.internal.sessions.factories.model.platform.SunAS9PlatformConfig;
 import org.eclipse.persistence.internal.sessions.factories.model.platform.WebLogic_10_PlatformConfig;
@@ -42,6 +68,26 @@
         addDescriptor(buildServerPlatformConfigDescriptorFor(WebLogic_9_PlatformConfig.class));
         addDescriptor(buildServerPlatformConfigDescriptorFor(WebLogic_10_PlatformConfig.class));
         addDescriptor(buildServerPlatformConfigDescriptorFor(WebSphere_6_1_PlatformConfig.class));
+        
+        // 242452 -- add metadata support for XMLLogin's DocumentPreservationPolicy
+        addDescriptor(buildDocumentPreservationPolicyConfigDescriptor());
+        addDescriptor(buildDescriptorLevelDocumentPreservationPolicyConfigDescriptor());
+        addDescriptor(buildNoDocumentPreservationPolicyConfigDescriptor());
+        addDescriptor(buildXMLBinderPolicyConfigDescriptor());
+        addDescriptor(buildNodeOrderingPolicyConfigDescriptor());
+        addDescriptor(buildAppendNewElementsOrderingPolicyConfigDescriptor());
+        addDescriptor(buildIgnoreNewElementsOrderingPolicyConfigDescriptor());
+        addDescriptor(buildRelativePositionOrderingPolicyConfigDescriptor());
+        
+        // Set the namespaces on all descriptors.
+        NamespaceResolver namespaceResolver = new NamespaceResolver();
+        namespaceResolver.put("xsi", W3C_XML_SCHEMA_INSTANCE_NS_URI);
+        namespaceResolver.put("xsd", W3C_XML_SCHEMA_NS_URI);
+
+        for (Iterator descriptors = getDescriptors().values().iterator(); descriptors.hasNext();) {
+            XMLDescriptor descriptor = (XMLDescriptor)descriptors.next();
+            descriptor.setNamespaceResolver(namespaceResolver);
+        }        
     }
 
     public ClassDescriptor buildSessionConfigsDescriptor() {
@@ -132,4 +178,108 @@
 	
         return descriptor;
     }
-}
+
+    public ClassDescriptor buildXMLLoginConfigDescriptor() {
+        ClassDescriptor descriptor = super.buildXMLLoginConfigDescriptor();
+
+        XMLDirectMapping equalNamespaceResolversMapping = new XMLDirectMapping();
+        equalNamespaceResolversMapping.setAttributeName("m_equalNamespaceResolvers");
+        equalNamespaceResolversMapping.setGetMethodName("getEqualNamespaceResolvers");
+        equalNamespaceResolversMapping.setSetMethodName("setEqualNamespaceResolvers");
+        equalNamespaceResolversMapping.setXPath("equal-namespace-resolvers/text()");
+        equalNamespaceResolversMapping.setNullValue(Boolean.TRUE);
+        descriptor.addMapping(equalNamespaceResolversMapping);
+
+        XMLCompositeObjectMapping documentPreservationPolicyMapping = new XMLCompositeObjectMapping();
+        documentPreservationPolicyMapping.setReferenceClass(DocumentPreservationPolicyConfig.class);
+        documentPreservationPolicyMapping.setAttributeName("m_documentPreservationPolicy");
+        documentPreservationPolicyMapping.setGetMethodName("getDocumentPreservationPolicy");
+        documentPreservationPolicyMapping.setSetMethodName("setDocumentPreservationPolicy");
+        documentPreservationPolicyMapping.setXPath("document-preservation-policy");
+        descriptor.addMapping(documentPreservationPolicyMapping);
+
+        return descriptor;
+    }
+
+    protected ClassDescriptor buildDocumentPreservationPolicyConfigDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(DocumentPreservationPolicyConfig.class);
+        descriptor.setDefaultRootElement("document-preservation-policy");
+
+        XMLCompositeObjectMapping nodeOrderingPolicyMapping = new XMLCompositeObjectMapping();
+        nodeOrderingPolicyMapping.setReferenceClass(NodeOrderingPolicyConfig.class);
+        nodeOrderingPolicyMapping.setAttributeName("m_nodeOrderingPolicy");
+        nodeOrderingPolicyMapping.setGetMethodName("getNodeOrderingPolicy");
+        nodeOrderingPolicyMapping.setSetMethodName("setNodeOrderingPolicy");
+        nodeOrderingPolicyMapping.setXPath("node-ordering-policy");
+        descriptor.addMapping(nodeOrderingPolicyMapping);
+
+        descriptor.getInheritancePolicy().setClassIndicatorField(new XMLField("@xsi:type"));
+        descriptor.getInheritancePolicy().addClassIndicator(DescriptorLevelDocumentPreservationPolicyConfig.class, "descriptor-level-document-preservation-policy");
+        descriptor.getInheritancePolicy().addClassIndicator(NoDocumentPreservationPolicyConfig.class, "no-document-preservation-policy");
+        descriptor.getInheritancePolicy().addClassIndicator(XMLBinderPolicyConfig.class, "xml-binder-policy");
+
+        return descriptor;
+    }
+
+    protected ClassDescriptor buildDescriptorLevelDocumentPreservationPolicyConfigDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(DescriptorLevelDocumentPreservationPolicyConfig.class);
+        descriptor.getInheritancePolicy().setParentClass(DocumentPreservationPolicyConfig.class);
+
+        return descriptor;
+    }
+
+    protected ClassDescriptor buildNoDocumentPreservationPolicyConfigDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(NoDocumentPreservationPolicyConfig.class);
+        descriptor.getInheritancePolicy().setParentClass(DocumentPreservationPolicyConfig.class);
+
+        return descriptor;
+    }
+
+    protected ClassDescriptor buildXMLBinderPolicyConfigDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(XMLBinderPolicyConfig.class);
+        descriptor.getInheritancePolicy().setParentClass(DocumentPreservationPolicyConfig.class);
+
+        return descriptor;
+    }
+    
+    protected ClassDescriptor buildNodeOrderingPolicyConfigDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(NodeOrderingPolicyConfig.class);
+
+        descriptor.getInheritancePolicy().setClassIndicatorField(new XMLField("@xsi:type"));
+        descriptor.getInheritancePolicy().addClassIndicator(AppendNewElementsOrderingPolicyConfig.class, "append-new-elements-ordering-policy");
+        descriptor.getInheritancePolicy().addClassIndicator(IgnoreNewElementsOrderingPolicyConfig.class, "ignore-new-elements-ordering-policy");
+        descriptor.getInheritancePolicy().addClassIndicator(RelativePositionOrderingPolicyConfig.class, "relative-position-ordering-policy");
+
+        return descriptor;
+    }
+
+    protected ClassDescriptor buildAppendNewElementsOrderingPolicyConfigDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(AppendNewElementsOrderingPolicyConfig.class);
+        descriptor.getInheritancePolicy().setParentClass(NodeOrderingPolicyConfig.class);
+
+        return descriptor;
+    }
+
+    protected ClassDescriptor buildIgnoreNewElementsOrderingPolicyConfigDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(IgnoreNewElementsOrderingPolicyConfig.class);
+        descriptor.getInheritancePolicy().setParentClass(NodeOrderingPolicyConfig.class);
+
+        return descriptor;
+    }
+
+    protected ClassDescriptor buildRelativePositionOrderingPolicyConfigDescriptor() {
+        XMLDescriptor descriptor = new XMLDescriptor();
+        descriptor.setJavaClass(RelativePositionOrderingPolicyConfig.class);
+        descriptor.getInheritancePolicy().setParentClass(NodeOrderingPolicyConfig.class);
+
+        return descriptor;
+    }
+
+}
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/AppendNewElementsOrderingPolicy.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/AppendNewElementsOrderingPolicy.java	(revision 2248)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/AppendNewElementsOrderingPolicy.java	(working copy)
@@ -24,11 +24,12 @@
  * 
  * @see org.eclipse.persistence.oxm.documentpreservation.NodeOrderingPolicy
  * @author mmacivor
- *
+ * @author rbarkhouse - changed to subclass (NodeOrderingPolicy changed to abstract superclass)
  */
-public class AppendNewElementsOrderingPolicy implements NodeOrderingPolicy {
+public class AppendNewElementsOrderingPolicy extends NodeOrderingPolicy {
+
     public void appendNode(Node parent, Node newChild, Node previousSibling) {
         parent.appendChild(newChild);
     }    
-}
 
+}
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/DocumentPreservationPolicy.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/DocumentPreservationPolicy.java	(revision 2248)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/DocumentPreservationPolicy.java	(working copy)
@@ -12,6 +12,7 @@
  ******************************************************************************/  
 package org.eclipse.persistence.oxm.documentpreservation;
 
+import org.eclipse.persistence.oxm.XMLContext;
 import org.eclipse.persistence.oxm.mappings.XMLMapping;
 
 import org.w3c.dom.Node;
@@ -58,4 +59,7 @@
     
     public abstract boolean shouldPreserveDocument();
     
+    public void initialize(XMLContext context) {
+    }
+
 }
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/IgnoreNewElementsOrderingPolicy.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/IgnoreNewElementsOrderingPolicy.java	(revision 2248)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/IgnoreNewElementsOrderingPolicy.java	(working copy)
@@ -19,12 +19,16 @@
 /**
  * INTERNAL:
  * <p><b>Purpose:</b>An implementation of NodeOrderingPolicy that ignores any new elements when
- * update a cached document. This is used for the JAXB 2.0 Binder implementation. 
+ * updating a cached document. This is used for the JAXB 2.0 Binder implementation. 
+ *
+ * @see org.eclipse.persistence.oxm.documentpreservation.NodeOrderingPolicy
  * @author mmacivor
- *
+ * @author rbarkhouse - changed to subclass (NodeOrderingPolicy changed to abstract superclass) 
  */
-public class IgnoreNewElementsOrderingPolicy implements NodeOrderingPolicy {
+public class IgnoreNewElementsOrderingPolicy extends NodeOrderingPolicy {
+
     public void appendNode(Node parent, Node newChild, Node previousSibling) {
-        //no op
+        // No-op
     }      
-}
+
+}
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/NodeOrderingPolicy.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/NodeOrderingPolicy.java	(revision 2248)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/NodeOrderingPolicy.java	(working copy)
@@ -15,13 +15,15 @@
 import org.w3c.dom.Node;
 
 /**
- * <p><b>Purpose:</b>Provide an interface that specifies how new XML Elements are added to an 
+ * <p><b>Purpose:</b>Provide a policy that specifies how new XML Elements are added to an 
  * existing XML Document.
  * 
  * @see org.eclipse.persistence.oxm.documentpreservation.DocumentPreservationPolicy
  * @author mmacivor
- *
+ * @author rbarkhouse - changed to abstract superclass 
  */
-public interface NodeOrderingPolicy {
-    public void appendNode(Node parent, Node newChild, Node previousSibling);
-}
+public abstract class NodeOrderingPolicy {
+
+    public abstract void appendNode(Node parent, Node newChild, Node previousSibling);
+
+}
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/RelativePositionOrderingPolicy.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/RelativePositionOrderingPolicy.java	(revision 2248)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/documentpreservation/RelativePositionOrderingPolicy.java	(working copy)
@@ -1,15 +1,15 @@
 /*******************************************************************************
  * Copyright (c) 1998, 2008 Oracle. All rights reserved.
- * This program and the accompanying materials are made available under the 
- * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 
- * which accompanies this distribution. 
+ * This program and the accompanying materials are made available under the
+ * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0
+ * which accompanies this distribution.
  * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
- * and the Eclipse Distribution License is available at 
+ * and the Eclipse Distribution License is available at
  * http://www.eclipse.org/org/documents/edl-v10.php.
  *
  * Contributors:
  *     Oracle - initial API and implementation from Oracle TopLink
- ******************************************************************************/  
+ ******************************************************************************/
 package org.eclipse.persistence.oxm.documentpreservation;
 
 import org.w3c.dom.Node;
@@ -21,28 +21,29 @@
  * <p><b>Purpose:</b>An implementation of NodeOrderingPolicy that adds new elements to an XML Document
  * based on the last updated sibling in their context.
  * <p><b>Responsibilities:</b>Add a new element as a child based on the provided last updated sibling.
- * 
+ *
+ * @see org.eclipse.persistence.oxm.documentpreservation.NodeOrderingPolicy
  * @author mmacivor
- * @see org.eclipse.persistence.oxm.documentpreservation.NodeOrderingPolicy
+ * @author rbarkhouse - changed to subclass (NodeOrderingPolicy changed to abstract superclass)
  */
-public class RelativePositionOrderingPolicy implements NodeOrderingPolicy {
-    
+public class RelativePositionOrderingPolicy extends NodeOrderingPolicy {
+
     public void appendNode(Node parent, Node newChild, Node previousSibling){
-        if(previousSibling != null) {
+        if (previousSibling != null) {
             Node nextSibling = previousSibling.getNextSibling();
-            if(nextSibling != null) {
+            if (nextSibling != null) {
                 parent.insertBefore(newChild, nextSibling);
             } else {
                 parent.appendChild(newChild);
             }
         }
         else {
-            if(parent.hasChildNodes()) {
+            if (parent.hasChildNodes()) {
                 parent.insertBefore(newChild, parent.getFirstChild());
             } else {
                 parent.appendChild(newChild);
             }
-        }        
-    }        
-}
+        }
+    }
 
+}
\ No newline at end of file
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/XMLContext.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/XMLContext.java	(revision 2248)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/oxm/XMLContext.java	(working copy)
@@ -564,7 +564,7 @@
             while (iterator.hasNext()) {
                 XMLDescriptor xmlDescriptor = (XMLDescriptor) iterator.next();
                 if (xmlDescriptor.shouldPreserveDocument()) {
-                    login.setDocumentPreservationPolicy(new DescriptorLevelDocumentPreservationPolicy(this));
+                    login.setDocumentPreservationPolicy(new DescriptorLevelDocumentPreservationPolicy());
                     break;
                 }
             }
@@ -572,6 +572,8 @@
         if (login.getDocumentPreservationPolicy() == null) {
             login.setDocumentPreservationPolicy(new NoDocumentPreservationPolicy());
         }
+        
+        login.getDocumentPreservationPolicy().initialize(this);
 
         if (login.getDocumentPreservationPolicy().shouldPreserveDocument() && !hasDocumentPreservation) {
             hasDocumentPreservation = true;
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/sessions/factories/XMLProjectReader.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/sessions/factories/XMLProjectReader.java	(revision 2248)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/sessions/factories/XMLProjectReader.java	(working copy)
@@ -62,7 +62,8 @@
     protected static Project project;
     public static final String SCHEMA_DIR = "xsd/";
     public static final String OPM_SCHEMA = "object-persistence_1_0.xsd";
-    public static final String ECLIPSELINK_SCHEMA = "eclipselink_persistence_map_1.0.xsd";
+    public static final String ECLIPSELINK_SCHEMA = "eclipselink_persistence_map_1.1.xsd";
+    public static final String ECLIPSELINK_1_0_SCHEMA = "eclipselink_persistence_map_1.0.xsd";    
     public static final String TOPLINK_11_SCHEMA = "toplink-object-persistence_11_1_1.xsd";
     public static final String TOPLINK_10_SCHEMA = "toplink-object-persistence_10_1_3.xsd";
 
@@ -110,7 +111,7 @@
     public static Project read(Reader reader, ClassLoader classLoader) {
         // Since a reader is pass and it can only be streamed once (mark does not work)
         // It must be first read into a buffer so multiple readers can be used to
-        // determine the format.  This does not effect performance severly.
+        // determine the format.  This does not effect performance severely.
         StringWriter writer;
         Document document;
         try {
@@ -131,23 +132,32 @@
             try {
                 document = parser.parse(new StringReader(writer.toString()));
             } catch (Exception parseException) {
-                // If the parse fails, it may be because the format was 11.1.1
-                try{
+                // If the parse fails, it may be because the format was EclipseLink 1.0
+                try {
                     if (shouldUseSchemaValidation()) {
-                        schema = SCHEMA_DIR + TOPLINK_11_SCHEMA;
+                        schema = SCHEMA_DIR + ECLIPSELINK_1_0_SCHEMA;
                     }
                     parser = createXMLParser(xmlPlatform, true, false, schema);
                     document = parser.parse(new StringReader(writer.toString()));
-                } catch (Exception eclipselinkParseException){
-                    // If the parse validation fails, it may be because the format was 904 which is
-                    // not support in eclipselink, just not valid, through original exception.
-                    throw parseException;
-            	}
+                } catch (Exception parseException2){
+                    // If the parse fails, it may be because the format was 11.1.1
+                    try {
+                        if (shouldUseSchemaValidation()) {
+                            schema = SCHEMA_DIR + TOPLINK_11_SCHEMA;
+                        }
+                        parser = createXMLParser(xmlPlatform, true, false, schema);
+                        document = parser.parse(new StringReader(writer.toString()));
+                    } catch (Exception parseException3){
+                        // If the parse validation fails, it may be because the format was 904 which is
+                        // not support in eclipselink, just not valid, through original exception.
+                        throw parseException;
+                    }
 
-                String version = document.getDocumentElement().getAttribute("version");
-                // If 10.1.3 format use old format read.
-                if ((version == null) || (version.indexOf("1.0") == -1)) {
-                    throw parseException;
+                    String version = document.getDocumentElement().getAttribute("version");
+                    // If 10.1.3 format use old format read.
+                    if ((version == null) || (version.indexOf("1.0") == -1)) {
+                        throw parseException;
+                    }
                 }
             }
         } catch (Exception exception) {
Index: foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/sessions/factories/XMLSessionConfigLoader.java
===================================================================
--- foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/sessions/factories/XMLSessionConfigLoader.java	(revision 2248)
+++ foundation/org.eclipse.persistence.core/src/org/eclipse/persistence/sessions/factories/XMLSessionConfigLoader.java	(working copy)
@@ -79,7 +79,7 @@
     /** Used to store the entity resolver to validate the XML schema when parsing. */
     protected PersistenceEntityResolver entityResolver;
 
-    public static final String ECLIPSELINK_SESSIONS_SCHEMA = "xsd/eclipselink_sessions_1.0.xsd";
+    public static final String ECLIPSELINK_SESSIONS_SCHEMA = "xsd/eclipselink_sessions_1.1.xsd";
     protected static final String DEFAULT_RESOURCE_NAME = "sessions.xml";
     protected static final String DEFAULT_RESOURCE_NAME_IN_META_INF = "META-INF/sessions.xml";
 
Index: moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/OXTestSuite.java
===================================================================
--- moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/OXTestSuite.java	(revision 2248)
+++ moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/OXTestSuite.java	(working copy)
@@ -20,6 +20,7 @@
 import org.eclipse.persistence.testing.oxm.mappings.DeploymentXMLMappingTestSuite;
 import org.eclipse.persistence.testing.oxm.mappings.MappingTestSuite;
 import org.eclipse.persistence.testing.oxm.xpathengine.XPathEngineTestSuite;
+import org.eclipse.persistence.testing.oxm.xmllogin.XMLLoginTestSuite;
 import org.eclipse.persistence.testing.oxm.xmlmarshaller.XMLMarshallerTestSuite;
 import org.eclipse.persistence.testing.oxm.schemareference.XMLSchemaReferenceTestSuite;
 import org.eclipse.persistence.testing.oxm.inheritance.InheritanceTestSuite;
@@ -61,6 +62,8 @@
         suite.addTest(XMLBinderTestSuite.suite());
 
         suite.addTest(XMLRootTestSuite.suite());
+        
+        suite.addTest(XMLLoginTestSuite.suite());
 
         //this suite does not include the JAXBDOM and JAXBSAX test suites as they need system properties set to run.     
         return suite;
Index: moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginSessionsXMLTestCases.java
===================================================================
--- moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginSessionsXMLTestCases.java	(revision 0)
+++ moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginSessionsXMLTestCases.java	(revision 0)
@@ -0,0 +1,158 @@
+package org.eclipse.persistence.testing.oxm.xmllogin;
+
+import java.io.File;
+
+import junit.framework.TestCase;
+
+import org.eclipse.persistence.internal.sessions.factories.XMLSessionConfigWriter;
+import org.eclipse.persistence.internal.sessions.factories.model.SessionConfigs;
+import org.eclipse.persistence.internal.sessions.factories.model.login.AppendNewElementsOrderingPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.DescriptorLevelDocumentPreservationPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.IgnoreNewElementsOrderingPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.NoDocumentPreservationPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.RelativePositionOrderingPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.XMLBinderPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.XMLLoginConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.session.DatabaseSessionConfig;
+import org.eclipse.persistence.oxm.platform.DOMPlatform;
+import org.eclipse.persistence.oxm.platform.SAXPlatform;
+import org.eclipse.persistence.sessions.factories.XMLSessionConfigLoader;
+
+public class XMLLoginSessionsXMLTestCases extends TestCase {
+
+    private DatabaseSessionConfig m_sessionConfig;
+    private XMLLoginConfig m_loginConfig;
+
+    private final String SESSION_NAME = "XMLLoginSessionsXMLTestCases";
+    private final String SESSION_FILE_NAME = "XMLLoginSessionsXMLTestCases-sessions.xml";
+    
+    public XMLLoginSessionsXMLTestCases(String name) {
+        super(name);
+    }
+
+    public void setUp() {
+        m_sessionConfig = new DatabaseSessionConfig();
+        m_sessionConfig.setName(SESSION_NAME);
+        m_loginConfig = new XMLLoginConfig();
+        m_sessionConfig.setLoginConfig(m_loginConfig);
+    }
+    
+    public static void main(String[] args) {
+        String[] arguments = { "-c", "org.eclipse.persistence.testing.oxm.xmllogin.XMLLoginSessionsXMLTestCases" };
+        junit.textui.TestRunner.main(arguments);
+    }
+    
+    // Bug 242452 - test 'DatasourcePlatform' in sessions.xml
+    public void testDataSourcePlatform() {
+        DatabaseSessionConfig roundTrippedConfig;
+        XMLLoginConfig roundTrippedLoginConfig;
+        
+        // DatasourcePlatform = SAXPlatform
+        // ================================        
+        m_loginConfig.setPlatformClass(new SAXPlatform().getClass().getName());
+        
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig();
+        
+        assertEquals(m_loginConfig.getPlatformClass(), roundTrippedLoginConfig.getPlatformClass());
+        
+        // DatasourcePlatform = DOMPlatform
+        // ================================        
+        m_loginConfig.setPlatformClass(new DOMPlatform().getClass().getName());
+        
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig();
+        
+        assertEquals(m_loginConfig.getPlatformClass(), roundTrippedLoginConfig.getPlatformClass());
+    }
+
+    // Bug - test 'EqualNamespaceResolvers' in sessions.xml
+    public void testEqualNamespaceResolvers() {
+        DatabaseSessionConfig roundTrippedConfig; 
+        XMLLoginConfig roundTrippedLoginConfig; 
+        
+        // EqualNamespaceResolvers = true
+        // ==============================
+        m_loginConfig.setEqualNamespaceResolvers(true);
+
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig();
+        
+        assertEquals(m_loginConfig.getEqualNamespaceResolvers(), roundTrippedLoginConfig.getEqualNamespaceResolvers());
+        
+        // EqualNamespaceResolvers = false
+        // ===============================
+        m_loginConfig.setEqualNamespaceResolvers(false);
+
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig();
+        
+        assertEquals(m_loginConfig.getEqualNamespaceResolvers(), roundTrippedLoginConfig.getEqualNamespaceResolvers());
+    }
+    
+    // Bug - test 'DocumentPreservationPolicy' in sessions.xml
+    public void testDocumentPreservationPolicy() {
+        DatabaseSessionConfig roundTrippedConfig; 
+        XMLLoginConfig roundTrippedLoginConfig; 
+        
+        // DocumentPreservationPolicy = DescriptorLevelDocumentPreservationPolicy
+        // NodeOrderingPolicy = AppendNewElementsOrderingPolicy
+        // ======================================================================
+        m_loginConfig.setDocumentPreservationPolicy(new DescriptorLevelDocumentPreservationPolicyConfig());
+        m_loginConfig.getDocumentPreservationPolicy().setNodeOrderingPolicy(new AppendNewElementsOrderingPolicyConfig());
+
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig(); 
+        
+        assertEquals(m_loginConfig.getDocumentPreservationPolicy().getClass(), roundTrippedLoginConfig.getDocumentPreservationPolicy().getClass());
+        assertEquals(m_loginConfig.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass(), 
+                roundTrippedLoginConfig.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass());
+        
+        // DocumentPreservationPolicy = NoDocumentPreservationPolicy
+        // NodeOrderingPolicy = IgnoreNewElementsOrderingPolicy
+        // =========================================================
+        m_loginConfig.setDocumentPreservationPolicy(new NoDocumentPreservationPolicyConfig());
+        m_loginConfig.getDocumentPreservationPolicy().setNodeOrderingPolicy(new IgnoreNewElementsOrderingPolicyConfig());
+
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig(); 
+        
+        assertEquals(m_loginConfig.getDocumentPreservationPolicy().getClass(), roundTrippedLoginConfig.getDocumentPreservationPolicy().getClass());
+        assertEquals(m_loginConfig.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass(), 
+                roundTrippedLoginConfig.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass());
+        
+        // DocumentPreservationPolicy = XMLBinderPolicy
+        // NodeOrderingPolicy = RelativePositionOrderingPolicy
+        // ===================================================
+        m_loginConfig.setDocumentPreservationPolicy(new XMLBinderPolicyConfig());
+        m_loginConfig.getDocumentPreservationPolicy().setNodeOrderingPolicy(new RelativePositionOrderingPolicyConfig());
+
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig(); 
+        
+        assertEquals(m_loginConfig.getDocumentPreservationPolicy().getClass(), roundTrippedLoginConfig.getDocumentPreservationPolicy().getClass());
+        assertEquals(m_loginConfig.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass(), 
+                roundTrippedLoginConfig.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass());
+    }
+
+    // Write the SessionConfig out to sessions.xml, then read it back in and return
+    // the round-tripped SessionConfig.
+    public DatabaseSessionConfig writeAndReadSessionsXML() {
+        SessionConfigs configs = new SessionConfigs();
+        configs.addSessionConfig(m_sessionConfig);
+        configs.setVersion("0");
+        XMLSessionConfigWriter.write(configs, SESSION_FILE_NAME);
+        
+        XMLSessionConfigLoader sessionLoader = new XMLSessionConfigLoader(SESSION_FILE_NAME);
+        SessionConfigs readConfigs = sessionLoader.loadConfigsForMappingWorkbench(this.getClass().getClassLoader());
+        
+        // There is only one session in this sessions.xml
+        return (DatabaseSessionConfig) readConfigs.getSessionConfigs().firstElement();
+    }
+    
+    public void tearDown() {
+        File tempFile = new File(SESSION_FILE_NAME);
+        tempFile.delete();
+    }
+    
+}
\ No newline at end of file
Index: moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginTestSuite.java
===================================================================
--- moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginTestSuite.java	(revision 0)
+++ moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginTestSuite.java	(revision 0)
@@ -0,0 +1,32 @@
+/*******************************************************************************
+ * Copyright (c) 1998, 2008 Oracle. All rights reserved.
+ * This program and the accompanying materials are made available under the 
+ * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 
+ * which accompanies this distribution. 
+ * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
+ * and the Eclipse Distribution License is available at 
+ * http://www.eclipse.org/org/documents/edl-v10.php.
+ *
+ * Contributors:
+ *     rbarkhou - new test cases for XMLLogin
+ ******************************************************************************/  
+package org.eclipse.persistence.testing.oxm.xmllogin;
+
+import org.eclipse.persistence.testing.oxm.xmlconversionmanager.DoubleToBigDecimalTestCases;
+
+import junit.framework.Test;
+import junit.framework.TestCase;
+import junit.framework.TestSuite;
+
+public class XMLLoginTestSuite extends TestCase {
+
+    public static Test suite() {
+        TestSuite suite = new TestSuite("XMLLogin Test Suite");
+
+        suite.addTestSuite(XMLLoginDeploymentXMLTestCases.class);
+        suite.addTestSuite(XMLLoginSessionsXMLTestCases.class);
+        
+        return suite;
+    }
+    
+}
\ No newline at end of file
Index: moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginDeploymentXMLTestCases.java
===================================================================
--- moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginDeploymentXMLTestCases.java	(revision 0)
+++ moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginDeploymentXMLTestCases.java	(revision 0)
@@ -0,0 +1,150 @@
+package org.eclipse.persistence.testing.oxm.xmllogin;
+
+import java.io.StringReader;
+import java.io.StringWriter;
+
+import junit.framework.TestCase;
+
+import org.eclipse.persistence.internal.oxm.documentpreservation.DescriptorLevelDocumentPreservationPolicy;
+import org.eclipse.persistence.internal.oxm.documentpreservation.NoDocumentPreservationPolicy;
+import org.eclipse.persistence.internal.oxm.documentpreservation.XMLBinderPolicy;
+import org.eclipse.persistence.oxm.XMLContext;
+import org.eclipse.persistence.oxm.XMLLogin;
+import org.eclipse.persistence.oxm.documentpreservation.AppendNewElementsOrderingPolicy;
+import org.eclipse.persistence.oxm.documentpreservation.IgnoreNewElementsOrderingPolicy;
+import org.eclipse.persistence.oxm.documentpreservation.RelativePositionOrderingPolicy;
+import org.eclipse.persistence.oxm.platform.DOMPlatform;
+import org.eclipse.persistence.oxm.platform.SAXPlatform;
+import org.eclipse.persistence.sessions.Project;
+import org.eclipse.persistence.sessions.factories.XMLProjectReader;
+import org.eclipse.persistence.sessions.factories.XMLProjectWriter;
+
+public class XMLLoginDeploymentXMLTestCases extends TestCase {
+    
+    private Project m_project;
+    private XMLLogin m_login;
+    
+    public XMLLoginDeploymentXMLTestCases(String name) {
+        super(name);
+    }
+    
+    public static void main(String[] args) {
+        String[] arguments = { "-c", "org.eclipse.persistence.testing.oxm.xmllogin.XMLLoginDeploymentXMLTestCases" };
+        junit.textui.TestRunner.main(arguments);
+    }
+
+    public void setUp() {
+        m_project = new Project();
+        m_login = new XMLLogin();
+        m_project.setLogin(m_login);
+    }
+    
+    // Bug 242452 - test 'DatasourcePlatform' in project.xml
+    public void testDataSourcePlatform() {
+        Project roundTrippedProject;
+        XMLLogin roundTrippedLogin;
+
+        // DatasourcePlatform = SAXPlatform
+        // ================================        
+        m_login.setDatasourcePlatform(new SAXPlatform());
+        
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.getDatasourcePlatform().getClass(), roundTrippedLogin.getDatasourcePlatform().getClass());
+
+        // DatasourcePlatform = DOMPlatform
+        // ================================
+        m_login.setDatasourcePlatform(new DOMPlatform());
+        
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.getDatasourcePlatform().getClass(), roundTrippedLogin.getDatasourcePlatform().getClass());
+    }
+
+    // Bug - test 'EqualNamespaceResolvers' in project.xml
+    public void testEqualNamespaceResolvers() {
+        Project roundTrippedProject; 
+        XMLLogin roundTrippedLogin; 
+        
+        // EqualNamespaceResolvers = true
+        // ==============================
+        m_login.setEqualNamespaceResolvers(true);
+
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.hasEqualNamespaceResolvers(), roundTrippedLogin.hasEqualNamespaceResolvers());
+        
+        // EqualNamespaceResolvers = false
+        // ===============================
+        m_login.setEqualNamespaceResolvers(false);
+
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.hasEqualNamespaceResolvers(), roundTrippedLogin.hasEqualNamespaceResolvers());
+    }
+
+    // Bug - test 'DocumentPreservationPolicy' in project.xml
+    public void testDocumentPreservationPolicy() {
+        Project roundTrippedProject; 
+        XMLLogin roundTrippedLogin; 
+        
+        // DocumentPreservationPolicy = DescriptorLevelDocumentPreservationPolicy
+        // NodeOrderingPolicy = AppendNewElementsOrderingPolicy        
+        // ======================================================================
+        m_login.setDocumentPreservationPolicy(new DescriptorLevelDocumentPreservationPolicy());
+        m_login.getDocumentPreservationPolicy().setNodeOrderingPolicy(new AppendNewElementsOrderingPolicy());
+
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.getDocumentPreservationPolicy().getClass(), roundTrippedLogin.getDocumentPreservationPolicy().getClass());
+        assertEquals(m_login.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass(), 
+                roundTrippedLogin.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass());
+        
+
+        // NodeOrderingPolicy = IgnoreNewElementsOrderingPolicy
+        // DocumentPreservationPolicy = NoDocumentPreservationPolicy
+        // =========================================================
+        m_login.setDocumentPreservationPolicy(new NoDocumentPreservationPolicy());
+        m_login.getDocumentPreservationPolicy().setNodeOrderingPolicy(new IgnoreNewElementsOrderingPolicy());
+
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.getDocumentPreservationPolicy().getClass(), roundTrippedLogin.getDocumentPreservationPolicy().getClass());
+        assertEquals(m_login.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass(), 
+                roundTrippedLogin.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass());
+        
+        // DocumentPreservationPolicy = XMLBinderPolicy
+        // NodeOrderingPolicy = RelativePositionOrderingPolicy        
+        // ===================================================
+        m_login.setDocumentPreservationPolicy(new XMLBinderPolicy());
+        m_login.getDocumentPreservationPolicy().setNodeOrderingPolicy(new RelativePositionOrderingPolicy());
+        
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.getDocumentPreservationPolicy().getClass(), roundTrippedLogin.getDocumentPreservationPolicy().getClass());
+        assertEquals(m_login.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass(), 
+                roundTrippedLogin.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass());
+    }
+
+    // Write the Project out to deployment XML, then read it back in and return
+    // the round-tripped Project.
+    public Project writeAndReadProject() {
+        StringWriter buffer = new StringWriter();
+
+        XMLProjectWriter.write(m_project, buffer);
+        
+        StringReader in = new StringReader(buffer.getBuffer().toString());
+        
+        XMLProjectReader.setShouldUseSchemaValidation(true);
+        
+        return XMLProjectReader.read(in);
+    }
+    
+}
\ No newline at end of file
Index: moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginDeploymentXMLTestCases.java
===================================================================
--- moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginDeploymentXMLTestCases.java	(revision 0)
+++ moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginDeploymentXMLTestCases.java	(revision 0)
@@ -0,0 +1,150 @@
+package org.eclipse.persistence.testing.oxm.xmllogin;
+
+import java.io.StringReader;
+import java.io.StringWriter;
+
+import junit.framework.TestCase;
+
+import org.eclipse.persistence.internal.oxm.documentpreservation.DescriptorLevelDocumentPreservationPolicy;
+import org.eclipse.persistence.internal.oxm.documentpreservation.NoDocumentPreservationPolicy;
+import org.eclipse.persistence.internal.oxm.documentpreservation.XMLBinderPolicy;
+import org.eclipse.persistence.oxm.XMLContext;
+import org.eclipse.persistence.oxm.XMLLogin;
+import org.eclipse.persistence.oxm.documentpreservation.AppendNewElementsOrderingPolicy;
+import org.eclipse.persistence.oxm.documentpreservation.IgnoreNewElementsOrderingPolicy;
+import org.eclipse.persistence.oxm.documentpreservation.RelativePositionOrderingPolicy;
+import org.eclipse.persistence.oxm.platform.DOMPlatform;
+import org.eclipse.persistence.oxm.platform.SAXPlatform;
+import org.eclipse.persistence.sessions.Project;
+import org.eclipse.persistence.sessions.factories.XMLProjectReader;
+import org.eclipse.persistence.sessions.factories.XMLProjectWriter;
+
+public class XMLLoginDeploymentXMLTestCases extends TestCase {
+    
+    private Project m_project;
+    private XMLLogin m_login;
+    
+    public XMLLoginDeploymentXMLTestCases(String name) {
+        super(name);
+    }
+    
+    public static void main(String[] args) {
+        String[] arguments = { "-c", "org.eclipse.persistence.testing.oxm.xmllogin.XMLLoginDeploymentXMLTestCases" };
+        junit.textui.TestRunner.main(arguments);
+    }
+
+    public void setUp() {
+        m_project = new Project();
+        m_login = new XMLLogin();
+        m_project.setLogin(m_login);
+    }
+    
+    // Bug 242452 - test 'DatasourcePlatform' in project.xml
+    public void testDataSourcePlatform() {
+        Project roundTrippedProject;
+        XMLLogin roundTrippedLogin;
+
+        // DatasourcePlatform = SAXPlatform
+        // ================================        
+        m_login.setDatasourcePlatform(new SAXPlatform());
+        
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.getDatasourcePlatform().getClass(), roundTrippedLogin.getDatasourcePlatform().getClass());
+
+        // DatasourcePlatform = DOMPlatform
+        // ================================
+        m_login.setDatasourcePlatform(new DOMPlatform());
+        
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.getDatasourcePlatform().getClass(), roundTrippedLogin.getDatasourcePlatform().getClass());
+    }
+
+    // Bug - test 'EqualNamespaceResolvers' in project.xml
+    public void testEqualNamespaceResolvers() {
+        Project roundTrippedProject; 
+        XMLLogin roundTrippedLogin; 
+        
+        // EqualNamespaceResolvers = true
+        // ==============================
+        m_login.setEqualNamespaceResolvers(true);
+
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.hasEqualNamespaceResolvers(), roundTrippedLogin.hasEqualNamespaceResolvers());
+        
+        // EqualNamespaceResolvers = false
+        // ===============================
+        m_login.setEqualNamespaceResolvers(false);
+
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.hasEqualNamespaceResolvers(), roundTrippedLogin.hasEqualNamespaceResolvers());
+    }
+
+    // Bug - test 'DocumentPreservationPolicy' in project.xml
+    public void testDocumentPreservationPolicy() {
+        Project roundTrippedProject; 
+        XMLLogin roundTrippedLogin; 
+        
+        // DocumentPreservationPolicy = DescriptorLevelDocumentPreservationPolicy
+        // NodeOrderingPolicy = AppendNewElementsOrderingPolicy        
+        // ======================================================================
+        m_login.setDocumentPreservationPolicy(new DescriptorLevelDocumentPreservationPolicy());
+        m_login.getDocumentPreservationPolicy().setNodeOrderingPolicy(new AppendNewElementsOrderingPolicy());
+
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.getDocumentPreservationPolicy().getClass(), roundTrippedLogin.getDocumentPreservationPolicy().getClass());
+        assertEquals(m_login.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass(), 
+                roundTrippedLogin.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass());
+        
+
+        // NodeOrderingPolicy = IgnoreNewElementsOrderingPolicy
+        // DocumentPreservationPolicy = NoDocumentPreservationPolicy
+        // =========================================================
+        m_login.setDocumentPreservationPolicy(new NoDocumentPreservationPolicy());
+        m_login.getDocumentPreservationPolicy().setNodeOrderingPolicy(new IgnoreNewElementsOrderingPolicy());
+
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.getDocumentPreservationPolicy().getClass(), roundTrippedLogin.getDocumentPreservationPolicy().getClass());
+        assertEquals(m_login.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass(), 
+                roundTrippedLogin.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass());
+        
+        // DocumentPreservationPolicy = XMLBinderPolicy
+        // NodeOrderingPolicy = RelativePositionOrderingPolicy        
+        // ===================================================
+        m_login.setDocumentPreservationPolicy(new XMLBinderPolicy());
+        m_login.getDocumentPreservationPolicy().setNodeOrderingPolicy(new RelativePositionOrderingPolicy());
+        
+        roundTrippedProject = writeAndReadProject();
+        roundTrippedLogin = (XMLLogin) roundTrippedProject.getDatasourceLogin(); 
+        
+        assertEquals(m_login.getDocumentPreservationPolicy().getClass(), roundTrippedLogin.getDocumentPreservationPolicy().getClass());
+        assertEquals(m_login.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass(), 
+                roundTrippedLogin.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass());
+    }
+
+    // Write the Project out to deployment XML, then read it back in and return
+    // the round-tripped Project.
+    public Project writeAndReadProject() {
+        StringWriter buffer = new StringWriter();
+
+        XMLProjectWriter.write(m_project, buffer);
+        
+        StringReader in = new StringReader(buffer.getBuffer().toString());
+        
+        XMLProjectReader.setShouldUseSchemaValidation(true);
+        
+        return XMLProjectReader.read(in);
+    }
+    
+}
\ No newline at end of file
Index: moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginSessionsXMLTestCases.java
===================================================================
--- moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginSessionsXMLTestCases.java	(revision 0)
+++ moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginSessionsXMLTestCases.java	(revision 0)
@@ -0,0 +1,158 @@
+package org.eclipse.persistence.testing.oxm.xmllogin;
+
+import java.io.File;
+
+import junit.framework.TestCase;
+
+import org.eclipse.persistence.internal.sessions.factories.XMLSessionConfigWriter;
+import org.eclipse.persistence.internal.sessions.factories.model.SessionConfigs;
+import org.eclipse.persistence.internal.sessions.factories.model.login.AppendNewElementsOrderingPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.DescriptorLevelDocumentPreservationPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.IgnoreNewElementsOrderingPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.NoDocumentPreservationPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.RelativePositionOrderingPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.XMLBinderPolicyConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.login.XMLLoginConfig;
+import org.eclipse.persistence.internal.sessions.factories.model.session.DatabaseSessionConfig;
+import org.eclipse.persistence.oxm.platform.DOMPlatform;
+import org.eclipse.persistence.oxm.platform.SAXPlatform;
+import org.eclipse.persistence.sessions.factories.XMLSessionConfigLoader;
+
+public class XMLLoginSessionsXMLTestCases extends TestCase {
+
+    private DatabaseSessionConfig m_sessionConfig;
+    private XMLLoginConfig m_loginConfig;
+
+    private final String SESSION_NAME = "XMLLoginSessionsXMLTestCases";
+    private final String SESSION_FILE_NAME = "XMLLoginSessionsXMLTestCases-sessions.xml";
+    
+    public XMLLoginSessionsXMLTestCases(String name) {
+        super(name);
+    }
+
+    public void setUp() {
+        m_sessionConfig = new DatabaseSessionConfig();
+        m_sessionConfig.setName(SESSION_NAME);
+        m_loginConfig = new XMLLoginConfig();
+        m_sessionConfig.setLoginConfig(m_loginConfig);
+    }
+    
+    public static void main(String[] args) {
+        String[] arguments = { "-c", "org.eclipse.persistence.testing.oxm.xmllogin.XMLLoginSessionsXMLTestCases" };
+        junit.textui.TestRunner.main(arguments);
+    }
+    
+    // Bug 242452 - test 'DatasourcePlatform' in sessions.xml
+    public void testDataSourcePlatform() {
+        DatabaseSessionConfig roundTrippedConfig;
+        XMLLoginConfig roundTrippedLoginConfig;
+        
+        // DatasourcePlatform = SAXPlatform
+        // ================================        
+        m_loginConfig.setPlatformClass(new SAXPlatform().getClass().getName());
+        
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig();
+        
+        assertEquals(m_loginConfig.getPlatformClass(), roundTrippedLoginConfig.getPlatformClass());
+        
+        // DatasourcePlatform = DOMPlatform
+        // ================================        
+        m_loginConfig.setPlatformClass(new DOMPlatform().getClass().getName());
+        
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig();
+        
+        assertEquals(m_loginConfig.getPlatformClass(), roundTrippedLoginConfig.getPlatformClass());
+    }
+
+    // Bug - test 'EqualNamespaceResolvers' in sessions.xml
+    public void testEqualNamespaceResolvers() {
+        DatabaseSessionConfig roundTrippedConfig; 
+        XMLLoginConfig roundTrippedLoginConfig; 
+        
+        // EqualNamespaceResolvers = true
+        // ==============================
+        m_loginConfig.setEqualNamespaceResolvers(true);
+
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig();
+        
+        assertEquals(m_loginConfig.getEqualNamespaceResolvers(), roundTrippedLoginConfig.getEqualNamespaceResolvers());
+        
+        // EqualNamespaceResolvers = false
+        // ===============================
+        m_loginConfig.setEqualNamespaceResolvers(false);
+
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig();
+        
+        assertEquals(m_loginConfig.getEqualNamespaceResolvers(), roundTrippedLoginConfig.getEqualNamespaceResolvers());
+    }
+    
+    // Bug - test 'DocumentPreservationPolicy' in sessions.xml
+    public void testDocumentPreservationPolicy() {
+        DatabaseSessionConfig roundTrippedConfig; 
+        XMLLoginConfig roundTrippedLoginConfig; 
+        
+        // DocumentPreservationPolicy = DescriptorLevelDocumentPreservationPolicy
+        // NodeOrderingPolicy = AppendNewElementsOrderingPolicy
+        // ======================================================================
+        m_loginConfig.setDocumentPreservationPolicy(new DescriptorLevelDocumentPreservationPolicyConfig());
+        m_loginConfig.getDocumentPreservationPolicy().setNodeOrderingPolicy(new AppendNewElementsOrderingPolicyConfig());
+
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig(); 
+        
+        assertEquals(m_loginConfig.getDocumentPreservationPolicy().getClass(), roundTrippedLoginConfig.getDocumentPreservationPolicy().getClass());
+        assertEquals(m_loginConfig.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass(), 
+                roundTrippedLoginConfig.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass());
+        
+        // DocumentPreservationPolicy = NoDocumentPreservationPolicy
+        // NodeOrderingPolicy = IgnoreNewElementsOrderingPolicy
+        // =========================================================
+        m_loginConfig.setDocumentPreservationPolicy(new NoDocumentPreservationPolicyConfig());
+        m_loginConfig.getDocumentPreservationPolicy().setNodeOrderingPolicy(new IgnoreNewElementsOrderingPolicyConfig());
+
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig(); 
+        
+        assertEquals(m_loginConfig.getDocumentPreservationPolicy().getClass(), roundTrippedLoginConfig.getDocumentPreservationPolicy().getClass());
+        assertEquals(m_loginConfig.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass(), 
+                roundTrippedLoginConfig.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass());
+        
+        // DocumentPreservationPolicy = XMLBinderPolicy
+        // NodeOrderingPolicy = RelativePositionOrderingPolicy
+        // ===================================================
+        m_loginConfig.setDocumentPreservationPolicy(new XMLBinderPolicyConfig());
+        m_loginConfig.getDocumentPreservationPolicy().setNodeOrderingPolicy(new RelativePositionOrderingPolicyConfig());
+
+        roundTrippedConfig = writeAndReadSessionsXML();
+        roundTrippedLoginConfig = (XMLLoginConfig) roundTrippedConfig.getLoginConfig(); 
+        
+        assertEquals(m_loginConfig.getDocumentPreservationPolicy().getClass(), roundTrippedLoginConfig.getDocumentPreservationPolicy().getClass());
+        assertEquals(m_loginConfig.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass(), 
+                roundTrippedLoginConfig.getDocumentPreservationPolicy().getNodeOrderingPolicy().getClass());
+    }
+
+    // Write the SessionConfig out to sessions.xml, then read it back in and return
+    // the round-tripped SessionConfig.
+    public DatabaseSessionConfig writeAndReadSessionsXML() {
+        SessionConfigs configs = new SessionConfigs();
+        configs.addSessionConfig(m_sessionConfig);
+        configs.setVersion("0");
+        XMLSessionConfigWriter.write(configs, SESSION_FILE_NAME);
+        
+        XMLSessionConfigLoader sessionLoader = new XMLSessionConfigLoader(SESSION_FILE_NAME);
+        SessionConfigs readConfigs = sessionLoader.loadConfigsForMappingWorkbench(this.getClass().getClassLoader());
+        
+        // There is only one session in this sessions.xml
+        return (DatabaseSessionConfig) readConfigs.getSessionConfigs().firstElement();
+    }
+    
+    public void tearDown() {
+        File tempFile = new File(SESSION_FILE_NAME);
+        tempFile.delete();
+    }
+    
+}
\ No newline at end of file
Index: moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginTestSuite.java
===================================================================
--- moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginTestSuite.java	(revision 0)
+++ moxy/eclipselink.moxy.test/src/org/eclipse/persistence/testing/oxm/xmllogin/XMLLoginTestSuite.java	(revision 0)
@@ -0,0 +1,32 @@
+/*******************************************************************************
+ * Copyright (c) 1998, 2008 Oracle. All rights reserved.
+ * This program and the accompanying materials are made available under the 
+ * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 
+ * which accompanies this distribution. 
+ * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
+ * and the Eclipse Distribution License is available at 
+ * http://www.eclipse.org/org/documents/edl-v10.php.
+ *
+ * Contributors:
+ *     rbarkhou - new test cases for XMLLogin
+ ******************************************************************************/  
+package org.eclipse.persistence.testing.oxm.xmllogin;
+
+import org.eclipse.persistence.testing.oxm.xmlconversionmanager.DoubleToBigDecimalTestCases;
+
+import junit.framework.Test;
+import junit.framework.TestCase;
+import junit.framework.TestSuite;
+
+public class XMLLoginTestSuite extends TestCase {
+
+    public static Test suite() {
+        TestSuite suite = new TestSuite("XMLLogin Test Suite");
+
+        suite.addTestSuite(XMLLoginDeploymentXMLTestCases.class);
+        suite.addTestSuite(XMLLoginSessionsXMLTestCases.class);
+        
+        return suite;
+    }
+    
+}
\ No newline at end of file

Back to the top