blob: 72df2d15ca84df03487c5dd8d90a7052df3f760d [file] [log] [blame]
<?xml version="1.0" encoding="UTF-8"?>
<xsd:schema
targetNamespace="https://jakarta.ee/xml/ns/jakartaee"
xmlns:jakartaee="https://jakarta.ee/xml/ns/jakartaee"
xmlns:xsd="http://www.w3.org/2001/XMLSchema"
elementFormDefault="qualified"
attributeFormDefault="unqualified"
version="11">
<xsd:annotation>
<xsd:documentation>
Copyright (c) 2009, 2023 Oracle and/or its affiliates and others.
All rights reserved.
This program and the accompanying materials are made available under the
terms of the Eclipse Public License v. 2.0, which is available at
http://www.eclipse.org/legal/epl-2.0.
This Source Code may also be made available under the following Secondary
Licenses when the conditions for such availability set forth in the
Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
version 2 with the GNU Classpath Exception, which is available at
https://www.gnu.org/software/classpath/license.html.
SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
</xsd:documentation>
</xsd:annotation>
<xsd:annotation>
<xsd:documentation>
The following definitions that appear in the common
shareable schema(s) of Jakarta EE deployment descriptors should be
interpreted with respect to the context they are included:
Deployment Component may indicate one of the following:
Jakarta EE application;
application client;
web application;
enterprise bean;
resource adapter;
Deployment File may indicate one of the following:
ear file;
war file;
jar file;
rar file;
</xsd:documentation>
</xsd:annotation>
<xsd:import namespace="http://www.w3.org/XML/1998/namespace"
schemaLocation="xml.xsd"/>
<xsd:include schemaLocation="jakartaee_web_services_client_2_0.xsd"/>
<!-- **************************************************** -->
<xsd:group name="descriptionGroup">
<xsd:annotation>
<xsd:documentation>
This group keeps the usage of the contained description related
elements consistent across Jakarta EE deployment descriptors.
All elements may occur multiple times with different languages,
to support localization of the content.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="display-name"
type="jakartaee:display-nameType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="icon"
type="jakartaee:iconType"
minOccurs="0"
maxOccurs="unbounded"/>
</xsd:sequence>
</xsd:group>
<!-- **************************************************** -->
<xsd:group name="jndiEnvironmentRefsGroup">
<xsd:annotation>
<xsd:documentation>
This group keeps the usage of the contained JNDI environment
reference elements consistent across Jakarta EE deployment descriptors.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="env-entry"
type="jakartaee:env-entryType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="ejb-ref"
type="jakartaee:ejb-refType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="ejb-local-ref"
type="jakartaee:ejb-local-refType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:group ref="jakartaee:service-refGroup"/>
<xsd:element name="resource-ref"
type="jakartaee:resource-refType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="resource-env-ref"
type="jakartaee:resource-env-refType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="message-destination-ref"
type="jakartaee:message-destination-refType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="persistence-context-ref"
type="jakartaee:persistence-context-refType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="persistence-unit-ref"
type="jakartaee:persistence-unit-refType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="post-construct"
type="jakartaee:lifecycle-callbackType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="pre-destroy"
type="jakartaee:lifecycle-callbackType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="data-source"
type="jakartaee:data-sourceType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="jms-connection-factory"
type="jakartaee:jms-connection-factoryType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="jms-destination"
type="jakartaee:jms-destinationType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="mail-session"
type="jakartaee:mail-sessionType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="connection-factory"
type="jakartaee:connection-factory-resourceType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="administered-object"
type="jakartaee:administered-objectType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="context-service"
type="jakartaee:context-serviceType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="managed-executor"
type="jakartaee:managed-executorType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="managed-scheduled-executor"
type="jakartaee:managed-scheduled-executorType"
minOccurs="0" maxOccurs="unbounded"/>
<xsd:element name="managed-thread-factory"
type="jakartaee:managed-thread-factoryType"
minOccurs="0" maxOccurs="unbounded"/>
</xsd:sequence>
</xsd:group>
<!-- **************************************************** -->
<xsd:group name="resourceGroup">
<xsd:annotation>
<xsd:documentation>
This group collects elements that are common to most
JNDI resource elements.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:group ref="jakartaee:resourceBaseGroup"/>
<xsd:element name="lookup-name"
type="jakartaee:xsdStringType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
The JNDI name to be looked up to resolve a resource reference.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
</xsd:group>
<!-- **************************************************** -->
<xsd:group name="resourceBaseGroup">
<xsd:annotation>
<xsd:documentation>
This group collects elements that are common to all the
JNDI resource elements. It does not include the lookup-name
element, that is only applicable to some resource elements.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="mapped-name"
type="jakartaee:xsdStringType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
A product specific name that this resource should be
mapped to. The name of this resource, as defined by the
resource's name element or defaulted, is a name that is
local to the application component using the resource.
(It's a name in the JNDI java:comp/env namespace.) Many
application servers provide a way to map these local
names to names of resources known to the application
server. This mapped name is often a global JNDI name,
but may be a name of any form.
Application servers are not required to support any
particular form or type of mapped name, nor the ability
to use mapped names. The mapped name is
product-dependent and often installation-dependent. No
use of a mapped name is portable.
]]>
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="injection-target"
type="jakartaee:injection-targetType"
minOccurs="0"
maxOccurs="unbounded"/>
</xsd:sequence>
</xsd:group>
<!-- **************************************************** -->
<xsd:complexType name="administered-objectType">
<xsd:annotation>
<xsd:documentation>
Configuration of an administered object.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Description of this administered object.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
The name element specifies the JNDI name of the
administered object being defined.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="interface-name"
type="jakartaee:fully-qualified-classType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
The administered object's interface type.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="class-name"
type="jakartaee:fully-qualified-classType">
<xsd:annotation>
<xsd:documentation>
The administered object's class name.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="resource-adapter"
type="jakartaee:string">
<xsd:annotation>
<xsd:documentation>
Resource adapter name.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="property"
type="jakartaee:propertyType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
Property of the administered object property. This may be a
vendor-specific property.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id"
type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="connection-factory-resourceType">
<xsd:annotation>
<xsd:documentation>
Configuration of a Connector Connection Factory resource.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Description of this resource.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
The name element specifies the JNDI name of the
resource being defined.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="interface-name"
type="jakartaee:fully-qualified-classType">
<xsd:annotation>
<xsd:documentation>
The fully qualified class name of the connection factory
interface.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="resource-adapter"
type="jakartaee:string">
<xsd:annotation>
<xsd:documentation>
Resource adapter name.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="max-pool-size"
type="jakartaee:xsdIntegerType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Maximum number of connections that should be concurrently
allocated for a connection pool.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="min-pool-size"
type="jakartaee:xsdIntegerType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Minimum number of connections that should be concurrently
allocated for a connection pool.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="transaction-support"
type="jakartaee:transaction-supportType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
The level of transaction support the connection factory
needs to support.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="property"
type="jakartaee:propertyType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
Resource property. This may be a vendor-specific
property.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id"
type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="context-serviceType">
<xsd:annotation>
<xsd:documentation>
Configuration of a ContextService.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Description of this ContextService.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
JNDI name of the ContextService instance being defined.
The JNDI name must be in a valid Jakarta EE namespace,
such as java:comp, java:module, java:app, or java:global.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="qualifier"
type="jakartaee:fully-qualified-classType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
A ContextService injection point annotated with these qualifier annotations
injects a bean that is produced by this context-service element.
Applications can define their own Producers for ContextService injection points
as long as the qualifier annotations on the producer do not conflict with the
non-empty qualifier list of a context-service.
You can specify a single qualifier element with no value to indicate an
empty list of qualifier annotation classes.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="cleared"
type="jakartaee:string"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
Types of context to clear whenever a thread runs a
contextual task or action. The thread's previous context
is restored afterward. Context types that are defined by
the Jakarta EE Concurrency specification include:
Application, Security, Transaction,
and Remaining, which means all available thread context
types that are not specified elsewhere. You can also specify
vendor-specific context types. Absent other configuration,
cleared context defaults to Transaction. You can specify
a single cleared element with no value to indicate an
empty list of context types to clear. If neither
propagated nor unchanged specify (or default to) Remaining,
then Remaining is automatically appended to the list of
cleared context types.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="propagated"
type="jakartaee:string"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
Types of context to capture from the requesting thread
and propagate to a thread that runs a contextual task
or action. The captured context is re-established
when threads run the contextual task or action,
with the respective thread's previous context being
restored afterward. Context types that are defined by
the Jakarta EE Concurrency specification include:
Application, Security,
and Remaining, which means all available thread context
types that are not specified elsewhere. You can also specify
vendor-specific context types. Absent other configuration,
propagated context defaults to Remaining. You can specify
a single propagated element with no value to indicate that
no context types should be propagated.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="unchanged"
type="jakartaee:string"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
Types of context that are left alone when a thread runs a
contextual task or action. Context types that are defined
by the Jakarta EE Concurrency specification include:
Application, Security, Transaction,
and Remaining, which means all available thread context
types that are not specified elsewhere. You can also specify
vendor-specific context types. Absent other configuration,
unchanged context defaults to empty. You can specify
a single unchanged element with no value to indicate that
no context types should be left unchanged.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="property"
type="jakartaee:propertyType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
Vendor-specific property.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="data-sourceType">
<xsd:annotation>
<xsd:documentation>
Configuration of a DataSource.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Description of this DataSource.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
The name element specifies the JNDI name of the
data source being defined.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="class-name"
type="jakartaee:fully-qualified-classType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
DataSource, XADataSource or ConnectionPoolDataSource
implementation class.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="server-name"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Database server name.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="port-number"
type="jakartaee:xsdIntegerType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Port number where a server is listening for requests.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="database-name"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Name of a database on a server.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="url"
type="jakartaee:jdbc-urlType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
A JDBC URL. If the <code>url</code> property is specified
along with other standard <code>DataSource</code> properties
such as <code>serverName</code>, <code>databaseName</code>
and <code>portNumber</code>, the more specific properties will
take precedence and <code>url</code> will be ignored.
]]>
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="user"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
User name to use for connection authentication.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="password"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Password to use for connection authentication.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="property"
type="jakartaee:propertyType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
JDBC DataSource property. This may be a vendor-specific
property or a less commonly used DataSource property.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="login-timeout"
type="jakartaee:xsdIntegerType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Sets the maximum time in seconds that this data source
will wait while attempting to connect to a database.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="transactional"
type="jakartaee:xsdBooleanType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Set to false if connections should not participate in
transactions.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="isolation-level"
type="jakartaee:isolation-levelType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Isolation level for connections.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="initial-pool-size"
type="jakartaee:xsdIntegerType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Number of connections that should be created when a
connection pool is initialized.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="max-pool-size"
type="jakartaee:xsdIntegerType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Maximum number of connections that should be concurrently
allocated for a connection pool.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="min-pool-size"
type="jakartaee:xsdIntegerType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Minimum number of connections that should be concurrently
allocated for a connection pool.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="max-idle-time"
type="jakartaee:xsdIntegerType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
The number of seconds that a physical connection should
remain unused in the pool before the connection is
closed for a connection pool.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="max-statements"
type="jakartaee:xsdIntegerType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
The total number of statements that a connection pool
should keep open.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="descriptionType">
<xsd:annotation>
<xsd:documentation>
The description type is used by a description element to
provide text describing the parent element. The elements
that use this type should include any information that the
Deployment Component's Deployment File file producer wants
to provide to the consumer of the Deployment Component's
Deployment File (i.e., to the Deployer). Typically, the
tools used by such a Deployment File consumer will display
the description when processing the parent element that
contains the description.
The lang attribute defines the language that the
description is provided in. The default value is "en" (English).
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:extension base="jakartaee:xsdStringType">
<xsd:attribute ref="xml:lang"/>
</xsd:extension>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:simpleType name="dewey-versionType">
<xsd:annotation>
<xsd:documentation>
This type defines a dewey decimal that is used
to describe versions of documents.
</xsd:documentation>
</xsd:annotation>
<xsd:restriction base="xsd:token">
<xsd:pattern value="\.?[0-9]+(\.[0-9]+)*"/>
</xsd:restriction>
</xsd:simpleType>
<!-- **************************************************** -->
<xsd:complexType name="display-nameType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The display-name type contains a short name that is intended
to be displayed by tools. It is used by display-name
elements. The display name need not be unique.
Example:
...
<display-name xml:lang="en">
Employee Self Service
</display-name>
The value of the xml:lang attribute is "en" (English) by default.
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:extension base="jakartaee:string">
<xsd:attribute ref="xml:lang"/>
</xsd:extension>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="ejb-linkType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The ejb-linkType is used by ejb-link
elements in the ejb-ref or ejb-local-ref elements to specify
that an enterprise bean reference is linked to enterprise bean.
The value of the ejb-link element must be the ejb-name of an
enterprise bean in the same ejb-jar file or in another ejb-jar
file in the same Jakarta EE application unit.
Alternatively, the name in the ejb-link element may be
composed of a path name specifying the ejb-jar containing the
referenced enterprise bean with the ejb-name of the target
bean appended and separated from the path name by "#". The
path name is relative to the Deployment File containing
Deployment Component that is referencing the enterprise
bean. This allows multiple enterprise beans with the same
ejb-name to be uniquely identified.
Examples:
<ejb-link>EmployeeRecord</ejb-link>
<ejb-link>../products/product.jar#ProductEJB</ejb-link>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="ejb-local-refType">
<xsd:annotation>
<xsd:documentation>
The ejb-local-refType is used by ejb-local-ref elements for
the declaration of a reference to an enterprise bean's local
home or to the local business interface of a 3.0 bean.
The declaration consists of:
- an optional description
- the enterprise bean's reference name used in the code of the
Deployment Component that's referencing the enterprise bean.
- the optional expected type of the referenced enterprise bean
- the optional expected local interface of the referenced
enterprise bean or the local business interface of the
referenced enterprise bean.
- the optional expected local home interface of the referenced
enterprise bean. Not applicable if this ejb-local-ref refers
to the local business interface of a 3.0 bean.
- optional ejb-link information, used to specify the
referenced enterprise bean
- optional elements to define injection of the named enterprise
bean into a component field or property.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="ejb-ref-name"
type="jakartaee:ejb-ref-nameType"/>
<xsd:element name="ejb-ref-type"
type="jakartaee:ejb-ref-typeType"
minOccurs="0"/>
<xsd:element name="local-home"
type="jakartaee:local-homeType"
minOccurs="0"/>
<xsd:element name="local"
type="jakartaee:localType"
minOccurs="0"/>
<xsd:element name="ejb-link"
type="jakartaee:ejb-linkType"
minOccurs="0"/>
<xsd:group ref="jakartaee:resourceGroup"/>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="ejb-ref-nameType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The ejb-ref-name element contains the name of an enterprise bean reference.
The enterprise bean reference is an entry in the Deployment Component's
environment and is relative to the java:comp/env context. The name must
be unique within the Deployment Component.
It is recommended that name is prefixed with "ejb/".
Example:
<ejb-ref-name>ejb/Payroll</ejb-ref-name>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:jndi-nameType"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="ejb-refType">
<xsd:annotation>
<xsd:documentation>
The ejb-refType is used by ejb-ref elements for the
declaration of a reference to an enterprise bean's home or
to the remote business interface of a 3.0 bean.
The declaration consists of:
- an optional description
- the enterprise bean's reference name used in the code of
the Deployment Component that's referencing the enterprise
bean.
- the optional expected type of the referenced enterprise bean
- the optional remote interface of the referenced enterprise bean
or the remote business interface of the referenced enterprise
bean
- the optional expected home interface of the referenced
enterprise bean. Not applicable if this ejb-ref
refers to the remote business interface of a 3.0 bean.
- optional ejb-link information, used to specify the
referenced enterprise bean
- optional elements to define injection of the named enterprise
bean into a component field or property
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="ejb-ref-name"
type="jakartaee:ejb-ref-nameType"/>
<xsd:element name="ejb-ref-type"
type="jakartaee:ejb-ref-typeType"
minOccurs="0"/>
<xsd:element name="home"
type="jakartaee:homeType"
minOccurs="0"/>
<xsd:element name="remote"
type="jakartaee:remoteType"
minOccurs="0"/>
<xsd:element name="ejb-link"
type="jakartaee:ejb-linkType"
minOccurs="0"/>
<xsd:group ref="jakartaee:resourceGroup"/>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="ejb-ref-typeType">
<xsd:annotation>
<xsd:documentation>
The ejb-ref-typeType contains the expected type of the
referenced enterprise bean.
The ejb-ref-type designates a value
that must be one of the following:
Entity
Session
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string">
<xsd:enumeration value="Entity"/>
<xsd:enumeration value="Session"/>
</xsd:restriction>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="emptyType">
<xsd:annotation>
<xsd:documentation>
This type is used to designate an empty
element when used.
</xsd:documentation>
</xsd:annotation>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="env-entryType">
<xsd:annotation>
<xsd:documentation>
The env-entryType is used to declare an application's
environment entry. The declaration consists of an optional
description, the name of the environment entry, a type
(optional if the value is injected, otherwise required), and
an optional value.
It also includes optional elements to define injection of
the named resource into fields or JavaBeans properties.
If a value is not specified and injection is requested,
no injection will occur and no entry of the specified name
will be created. This allows an initial value to be
specified in the source code without being incorrectly
changed when no override has been specified.
If a value is not specified and no injection is requested,
a value must be supplied during deployment.
This type is used by env-entry elements.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="env-entry-name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The env-entry-name element contains the name of a
Deployment Component's environment entry. The name
is a JNDI name relative to the java:comp/env
context. The name must be unique within a
Deployment Component. The uniqueness
constraints must be defined within the declared
context.
Example:
<env-entry-name>minAmount</env-entry-name>
]]>
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="env-entry-type"
type="jakartaee:env-entry-type-valuesType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The env-entry-type element contains the Java language
type of the environment entry. If an injection target
is specified for the environment entry, the type may
be omitted, or must match the type of the injection
target. If no injection target is specified, the type
is required.
Example:
<env-entry-type>java.lang.Integer</env-entry-type>
]]>
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="env-entry-value"
type="jakartaee:xsdStringType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The env-entry-value designates the value of a
Deployment Component's environment entry. The value
must be a String that is valid for the
constructor of the specified type that takes a
single String parameter, or for java.lang.Character,
a single character.
Example:
<env-entry-value>100.00</env-entry-value>
]]>
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:group ref="jakartaee:resourceGroup"/>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="env-entry-type-valuesType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
This type contains the fully-qualified Java type of the
environment entry value that is expected by the
application's code.
The following are the legal values of env-entry-type-valuesType:
java.lang.Boolean
java.lang.Byte
java.lang.Character
java.lang.String
java.lang.Short
java.lang.Integer
java.lang.Long
java.lang.Float
java.lang.Double
java.lang.Class
any enumeration type (i.e. a subclass of java.lang.Enum)
Examples:
<env-entry-type>java.lang.Boolean</env-entry-type>
<env-entry-type>java.lang.Class</env-entry-type>
<env-entry-type>com.example.Color</env-entry-type>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:fully-qualified-classType"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="fully-qualified-classType">
<xsd:annotation>
<xsd:documentation>
The elements that use this type designate the name of a
Java class or interface. The name is in the form of a
"binary name", as defined in the JLS. This is the form
of name used in Class.forName(). Tools that need the
canonical name (the name used in source code) will need
to convert this binary name to the canonical name.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="generic-booleanType">
<xsd:annotation>
<xsd:documentation>
This type defines four different values which can designate
boolean values. This includes values yes and no which are
not designated by xsd:boolean
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string">
<xsd:enumeration value="true"/>
<xsd:enumeration value="false"/>
<xsd:enumeration value="yes"/>
<xsd:enumeration value="no"/>
</xsd:restriction>
</xsd:simpleContent>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="iconType">
<xsd:annotation>
<xsd:documentation>
The icon type contains small-icon and large-icon elements
that specify the file names for small and large GIF, JPEG,
or PNG icon images used to represent the parent element in a
GUI tool.
The xml:lang attribute defines the language that the
icon file names are provided in. Its value is "en" (English)
by default.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="small-icon" type="jakartaee:pathType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The small-icon element contains the name of a file
containing a small (16 x 16) icon image. The file
name is a relative path within the Deployment
Component's Deployment File.
The image may be in the GIF, JPEG, or PNG format.
The icon can be used by tools.
Example:
<small-icon>employee-service-icon16x16.jpg</small-icon>
]]>
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="large-icon" type="jakartaee:pathType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The large-icon element contains the name of a file
containing a large
(32 x 32) icon image. The file name is a relative
path within the Deployment Component's Deployment
File.
The image may be in the GIF, JPEG, or PNG format.
The icon can be used by tools.
Example:
<large-icon>employee-service-icon32x32.jpg</large-icon>
]]>
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute ref="xml:lang"/>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="injection-targetType">
<xsd:annotation>
<xsd:documentation>
An injection target specifies a class and a name within
that class into which a resource should be injected.
The injection target class specifies the fully qualified
class name that is the target of the injection. The
Jakarta EE specifications describe which classes can be an
injection target.
The injection target name specifies the target within
the specified class. The target is first looked for as a
JavaBeans property name. If not found, the target is
looked for as a field name.
The specified resource will be injected into the target
during initialization of the class by either calling the
set method for the target property or by setting a value
into the named field.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="injection-target-class"
type="jakartaee:fully-qualified-classType"/>
<xsd:element name="injection-target-name"
type="jakartaee:java-identifierType"/>
</xsd:sequence>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:simpleType name="isolation-levelType">
<xsd:annotation>
<xsd:documentation>
The following transaction isolation levels are allowed
(see documentation for the java.sql.Connection interface):
TRANSACTION_READ_UNCOMMITTED
TRANSACTION_READ_COMMITTED
TRANSACTION_REPEATABLE_READ
TRANSACTION_SERIALIZABLE
</xsd:documentation>
</xsd:annotation>
<xsd:restriction base="xsd:string">
<xsd:enumeration value="TRANSACTION_READ_UNCOMMITTED"/>
<xsd:enumeration value="TRANSACTION_READ_COMMITTED"/>
<xsd:enumeration value="TRANSACTION_REPEATABLE_READ"/>
<xsd:enumeration value="TRANSACTION_SERIALIZABLE"/>
</xsd:restriction>
</xsd:simpleType>
<!-- **************************************************** -->
<xsd:complexType name="java-identifierType">
<xsd:annotation>
<xsd:documentation>
The java-identifierType defines a Java identifier.
The users of this type should further verify that
the content does not contain Java reserved keywords.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string">
<xsd:pattern value="($|_|\p{L})(\p{L}|\p{Nd}|_|$)*"/>
</xsd:restriction>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="java-typeType">
<xsd:annotation>
<xsd:documentation>
This is a generic type that designates a Java primitive
type or a fully qualified name of a Java interface/type,
or an array of such types.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string">
<xsd:pattern value="[^\p{Z}]*"/>
</xsd:restriction>
</xsd:simpleContent>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="jdbc-urlType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The jdbc-urlType contains the url pattern of the mapping.
It must follow the rules specified in Section 9.3 of the
JDBC Specification where the format is:
jdbc:<subprotocol>:<subname>
Example:
<url>jdbc:mysql://localhost:3307/testdb</url>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string">
<xsd:pattern value="jdbc:(.*):(.*)"/>
</xsd:restriction>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="jms-connection-factoryType">
<xsd:annotation>
<xsd:documentation>
Configuration of a Messaging Connection Factory.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Description of this Messaging Connection Factory.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
The name element specifies the JNDI name of the
messaging connection factory being defined.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="interface-name"
type="jakartaee:fully-qualified-classType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Fully-qualified name of the messaging connection factory
interface. Permitted values are jakarta.jms.ConnectionFactory,
jakarta.jms.QueueConnectionFactory, or
jakarta.jms.TopicConnectionFactory. If not specified,
jakarta.jms.ConnectionFactory will be used.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="class-name"
type="jakartaee:fully-qualified-classType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Fully-qualified name of the messaging connection factory
implementation class. Ignored if a resource adapter
is used.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="resource-adapter"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Resource adapter name. If not specified, the application
server will define the default behavior, which may or may
not involve the use of a resource adapter.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="user"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
User name to use for connection authentication.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="password"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Password to use for connection authentication.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="client-id"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Client id to use for connection.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="property"
type="jakartaee:propertyType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
Messaging Connection Factory property. This may be a vendor-specific
property or a less commonly used ConnectionFactory property.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="transactional"
type="jakartaee:xsdBooleanType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Set to false if connections should not participate in
transactions.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="max-pool-size"
type="jakartaee:xsdIntegerType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Maximum number of connections that should be concurrently
allocated for a connection pool.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="min-pool-size"
type="jakartaee:xsdIntegerType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Minimum number of connections that should be concurrently
allocated for a connection pool.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id"
type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="jms-destinationType">
<xsd:annotation>
<xsd:documentation>
Configuration of a Messaging Destination.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Description of this Messaging Destination.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
The name element specifies the JNDI name of the
messaging destination being defined.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="interface-name"
type="jakartaee:fully-qualified-classType">
<xsd:annotation>
<xsd:documentation>
Fully-qualified name of the messaging destination interface.
Permitted values are jakarta.jms.Queue and jakarta.jms.Topic
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="class-name"
type="jakartaee:fully-qualified-classType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Fully-qualified name of the messaging destination implementation
class. Ignored if a resource adapter is used unless the
resource adapter defines more than one destination implementation
class for the specified interface.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="resource-adapter"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Resource adapter name. If not specified, the application
server will define the default behavior, which may or may
not involve the use of a resource adapter.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="destination-name"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Name of the queue or topic.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="property"
type="jakartaee:propertyType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
Messaging Destination property. This may be a vendor-specific
property or a less commonly used Destination property.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id"
type="xsd:ID"/>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="jndi-nameType">
<xsd:annotation>
<xsd:documentation>
The jndi-nameType type designates a JNDI name in the
Deployment Component's environment and is relative to the
java:comp/env context. A JNDI name must be unique within the
Deployment Component.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="homeType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The homeType defines the fully-qualified name of
an enterprise bean's home interface.
Example:
<home>com.aardvark.payroll.PayrollHome</home>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:fully-qualified-classType"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="lifecycle-callbackType">
<xsd:annotation>
<xsd:documentation>
The lifecycle-callback type specifies a method on a
class to be called when a lifecycle event occurs.
Note that each class may have only one lifecycle callback
method for any given event and that the method may not
be overloaded.
If the lifefycle-callback-class element is missing then
the class defining the callback is assumed to be the
component class in scope at the place in the descriptor
in which the callback definition appears.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="lifecycle-callback-class"
type="jakartaee:fully-qualified-classType"
minOccurs="0"/>
<xsd:element name="lifecycle-callback-method"
type="jakartaee:java-identifierType"/>
</xsd:sequence>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="listenerType">
<xsd:annotation>
<xsd:documentation>
The listenerType indicates the deployment properties for a web
application listener bean.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:group ref="jakartaee:descriptionGroup"/>
<xsd:element name="listener-class"
type="jakartaee:fully-qualified-classType">
<xsd:annotation>
<xsd:documentation>
The listener-class element declares a class in the
application must be registered as a web
application listener bean. The value is the fully
qualified classname of the listener class.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="localType">
<xsd:annotation>
<xsd:documentation>
The localType defines the fully-qualified name of an
enterprise bean's local interface.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:fully-qualified-classType"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="local-homeType">
<xsd:annotation>
<xsd:documentation>
The local-homeType defines the fully-qualified
name of an enterprise bean's local home interface.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:fully-qualified-classType"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="mail-sessionType">
<xsd:annotation>
<xsd:documentation>
Configuration of a Mail Session resource.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Description of this Mail Session resource.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
The name element specifies the JNDI name of the
Mail Session resource being defined.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="store-protocol"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Storage protocol.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="store-protocol-class"
type="jakartaee:fully-qualified-classType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Service provider store protocol implementation class
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="transport-protocol"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Transport protocol.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="transport-protocol-class"
type="jakartaee:fully-qualified-classType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Service provider transport protocol implementation class
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="host"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Mail server host name.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="user"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Mail server user name.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="password"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Password.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="from"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Email address to indicate the message sender.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="property"
type="jakartaee:propertyType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
Mail server property. This may be a vendor-specific
property.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id"
type="xsd:ID"/>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="managed-executorType">
<xsd:annotation>
<xsd:documentation>
Configuration of a ManagedExecutorService.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Description of this ManagedExecutorService.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
JNDI name of the ManagedExecutorService instance being defined.
The JNDI name must be in a valid Jakarta EE namespace,
such as java:comp, java:module, java:app, or java:global.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="context-service-ref"
type="jakartaee:jndi-nameType"
minOccurs="0"
maxOccurs="1">
<xsd:annotation>
<xsd:documentation>
Refers to the name of a ContextServiceDefinition or
context-service deployment descriptor element,
which determines how context is applied to tasks and actions
that run on this executor.
The name must be in a valid Jakarta EE namespace,
such as java:comp, java:module, java:app, or java:global.
In the absence of a configured value,
java:comp/DefaultContextService is used.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="qualifier"
type="jakartaee:fully-qualified-classType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
A ManagedExecutorService injection point annotated with these qualifier annotations
injects a bean that is produced by this managed-executor element.
Applications can define their own Producers for ManagedExecutorService injection points
as long as the qualifier annotations on the producer do not conflict with the
non-empty qualifier list of a managed-executor.
You can specify a single qualifier element with no value to indicate an
empty list of qualifier annotation classes.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="max-async"
type="jakartaee:xsdPositiveIntegerType"
minOccurs="0"
maxOccurs="1">
<xsd:annotation>
<xsd:documentation>
Upper bound on contextual tasks and actions that this executor
will simultaneously execute asynchronously. This constraint does
not apply to tasks and actions that the executor runs inline,
such as when a thread requests CompletableFuture.join and the
action runs inline if it has not yet started.
The default is unbounded, although still subject to
resource constraints of the system.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="hung-task-threshold"
type="jakartaee:xsdPositiveIntegerType"
minOccurs="0"
maxOccurs="1">
<xsd:annotation>
<xsd:documentation>
The amount of time in milliseconds that a task or action
can execute before it is considered hung.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="virtual"
type="jakartaee:true-falseType"
minOccurs="0"
maxOccurs="1">
<xsd:annotation>
<xsd:documentation>
Indicates whether this executor is requested to
create virtual threads for tasks that do not run inline.
When true, the executor can create
virtual threads if it is capable of doing so
and if the request is not overridden by vendor-specific
configuration that restricts the use of virtual threads.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="property"
type="jakartaee:propertyType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
Vendor-specific property.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="managed-scheduled-executorType">
<xsd:annotation>
<xsd:documentation>
Configuration of a ManagedScheduledExecutorService.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Description of this ManagedScheduledExecutorService.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
JNDI name of the ManagedScheduledExecutorService instance
being defined.
The JNDI name must be in a valid Jakarta EE namespace,
such as java:comp, java:module, java:app, or java:global.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="context-service-ref"
type="jakartaee:jndi-nameType"
minOccurs="0"
maxOccurs="1">
<xsd:annotation>
<xsd:documentation>
Refers to the name of a ContextServiceDefinition or
context-service deployment descriptor element,
which determines how context is applied to tasks and actions
that run on this executor.
The name must be in a valid Jakarta EE namespace,
such as java:comp, java:module, java:app, or java:global.
In the absence of a configured value,
java:comp/DefaultContextService is used.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="qualifier"
type="jakartaee:fully-qualified-classType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
A ManagedScheduledExecutorService injection point annotated with these qualifier annotations
injects a bean that is produced by this managed-scheduled-executor element.
Applications can define their own Producers for ManagedScheduledExecutorService injection points
as long as the qualifier annotations on the producer do not conflict with the
non-empty qualifier list of a managed-scheduled-executor.
You can specify a single qualifier element with no value to indicate an
empty list of qualifier annotation classes.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="max-async"
type="jakartaee:xsdPositiveIntegerType"
minOccurs="0"
maxOccurs="1">
<xsd:annotation>
<xsd:documentation>
Upper bound on contextual tasks and actions that this executor
will simultaneously execute asynchronously. This constraint does
not apply to tasks and actions that the executor runs inline,
such as when a thread requests CompletableFuture.join and the
action runs inline if it has not yet started. This constraint also
does not apply to tasks that are scheduled via the schedule methods.
The default is unbounded, although still subject to
resource constraints of the system.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="hung-task-threshold"
type="jakartaee:xsdPositiveIntegerType"
minOccurs="0"
maxOccurs="1">
<xsd:annotation>
<xsd:documentation>
The amount of time in milliseconds that a task or action
can execute before it is considered hung.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="virtual"
type="jakartaee:true-falseType"
minOccurs="0"
maxOccurs="1">
<xsd:annotation>
<xsd:documentation>
Indicates whether this executor is requested to
create virtual threads for tasks that do not run inline.
When true, the executor can create
virtual threads if it is capable of doing so
and if the request is not overridden by vendor-specific
configuration that restricts the use of virtual threads.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="property"
type="jakartaee:propertyType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
Vendor-specific property.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="managed-thread-factoryType">
<xsd:annotation>
<xsd:documentation>
Configuration of a ManagedThreadFactory.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
Description of this ManagedThreadFactory.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
JNDI name of the ManagedThreadFactory instance being defined.
The JNDI name must be in a valid Jakarta EE namespace,
such as java:comp, java:module, java:app, or java:global.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="context-service-ref"
type="jakartaee:jndi-nameType"
minOccurs="0"
maxOccurs="1">
<xsd:annotation>
<xsd:documentation>
Refers to the name of a ContextServiceDefinition or
context-service deployment descriptor element,
which determines how context is applied to threads
from this thread factory.
The name must be in a valid Jakarta EE namespace,
such as java:comp, java:module, java:app, or java:global.
In the absence of a configured value,
java:comp/DefaultContextService is used.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="qualifier"
type="jakartaee:fully-qualified-classType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
A ManagedThreadFactory injection point annotated with these qualifier annotations
injects a bean that is produced by this managed-thread-factory element.
Applications can define their own Producers for ManagedThreadFactory injection points
as long as the qualifier annotations on the producer do not conflict with the
non-empty qualifier list of a managed-thread-factory.
You can specify a single qualifier element with no value to indicate an
empty list of qualifier annotation classes.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="priority"
type="jakartaee:priorityType"
minOccurs="0"
maxOccurs="1">
<xsd:annotation>
<xsd:documentation>
Priority for threads created by this thread factory.
The default is 5 (java.lang.Thread.NORM_PRIORITY).
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="virtual"
type="jakartaee:true-falseType"
minOccurs="0"
maxOccurs="1">
<xsd:annotation>
<xsd:documentation>
Indicates whether this executor is requested to
create virtual threads for tasks that do not run inline.
When true, the executor can create
virtual threads if it is capable of doing so
and if the request is not overridden by vendor-specific
configuration that restricts the use of virtual threads.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="property"
type="jakartaee:propertyType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
Vendor-specific property.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="param-valueType">
<xsd:annotation>
<xsd:documentation>
This type is a general type that can be used to declare
parameter/value lists.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="param-name"
type="jakartaee:string">
<xsd:annotation>
<xsd:documentation>
The param-name element contains the name of a
parameter.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="param-value"
type="jakartaee:xsdStringType">
<xsd:annotation>
<xsd:documentation>
The param-value element contains the value of a
parameter.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="pathType">
<xsd:annotation>
<xsd:documentation>
The elements that use this type designate either a relative
path or an absolute path starting with a "/".
In elements that specify a pathname to a file within the
same Deployment File, relative filenames (i.e., those not
starting with "/") are considered relative to the root of
the Deployment File's namespace. Absolute filenames (i.e.,
those starting with "/") also specify names in the root of
the Deployment File's namespace. In general, relative names
are preferred. The exception is .war files where absolute
names are preferred for consistency with the Servlet API.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="persistence-context-refType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The persistence-context-ref element contains a declaration
of Deployment Component's reference to a persistence context
associated within a Deployment Component's
environment. It consists of:
- an optional description
- the persistence context reference name
- an optional persistence unit name. If not specified,
the default persistence unit is assumed.
- an optional specification as to whether
the persistence context type is Transaction or
Extended. If not specified, Transaction is assumed.
- an optional specification as to whether
the persistence context synchronization with the current
transaction is Synchronized or Unsynchronized. If not
specified, Synchronized is assumed.
- an optional list of persistence properties
- optional injection targets
Examples:
<persistence-context-ref>
<persistence-context-ref-name>myPersistenceContext
</persistence-context-ref-name>
</persistence-context-ref>
<persistence-context-ref>
<persistence-context-ref-name>myPersistenceContext
</persistence-context-ref-name>
<persistence-unit-name>PersistenceUnit1
</persistence-unit-name>
<persistence-context-type>Extended</persistence-context-type>
</persistence-context-ref>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="persistence-context-ref-name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
The persistence-context-ref-name element specifies
the name of a persistence context reference; its
value is the environment entry name used in
Deployment Component code. The name is a JNDI name
relative to the java:comp/env context.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="persistence-unit-name"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
The Application Assembler(or BeanProvider) may use the
following syntax to avoid the need to rename persistence
units to have unique names within a Jakarta EE application.
The Application Assembler specifies the pathname of the
root of the persistence.xml file for the referenced
persistence unit and appends the name of the persistence
unit separated from the pathname by #. The pathname is
relative to the referencing application component jar file.
In this manner, multiple persistence units with the same
persistence unit name may be uniquely identified when the
Application Assembler cannot change persistence unit names.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="persistence-context-type"
type="jakartaee:persistence-context-typeType"
minOccurs="0"/>
<xsd:element name="persistence-context-synchronization"
type="jakartaee:persistence-context-synchronizationType"
minOccurs="0"/>
<xsd:element name="persistence-property"
type="jakartaee:propertyType"
minOccurs="0"
maxOccurs="unbounded">
<xsd:annotation>
<xsd:documentation>
Used to specify properties for the container or persistence
provider. Vendor-specific properties may be included in
the set of properties. Properties that are not recognized
by a vendor must be ignored. Entries that make use of the
namespace jakarta.persistence and its subnamespaces must not
be used for vendor-specific properties. The namespace
jakarta.persistence is reserved for use by the specification.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:group ref="jakartaee:resourceBaseGroup"/>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="persistence-context-synchronizationType">
<xsd:annotation>
<xsd:documentation>
The persistence-context-synchronizationType specifies
whether a container-managed persistence context is automatically
synchronized with the current transaction.
The value of the persistence-context-synchronization element
must be one of the following:
Synchronized
Unsynchronized
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string">
<xsd:enumeration value="Synchronized"/>
<xsd:enumeration value="Unsynchronized"/>
</xsd:restriction>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="persistence-context-typeType">
<xsd:annotation>
<xsd:documentation>
The persistence-context-typeType specifies the transactional
nature of a persistence context reference.
The value of the persistence-context-type element must be
one of the following:
Transaction
Extended
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string">
<xsd:enumeration value="Transaction"/>
<xsd:enumeration value="Extended"/>
</xsd:restriction>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="priorityType">
<xsd:annotation>
<xsd:documentation>
Specifies a thread priority value in the range of
1 (java.lang.Thread.MIN_PRIORITY) to 10 (java.lang.Thread.MAX_PRIORITY).
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:xsdPositiveIntegerType">
<xsd:maxInclusive value="10"/>
</xsd:restriction>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="propertyType">
<xsd:annotation>
<xsd:documentation>
Specifies a name/value pair.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="name"
type="jakartaee:xsdStringType">
</xsd:element>
<xsd:element name="value"
type="jakartaee:xsdStringType">
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="persistence-unit-refType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The persistence-unit-ref element contains a declaration
of Deployment Component's reference to a persistence unit
associated within a Deployment Component's
environment. It consists of:
- an optional description
- the persistence unit reference name
- an optional persistence unit name. If not specified,
the default persistence unit is assumed.
- optional injection targets
Examples:
<persistence-unit-ref>
<persistence-unit-ref-name>myPersistenceUnit
</persistence-unit-ref-name>
</persistence-unit-ref>
<persistence-unit-ref>
<persistence-unit-ref-name>myPersistenceUnit
</persistence-unit-ref-name>
<persistence-unit-name>PersistenceUnit1
</persistence-unit-name>
</persistence-unit-ref>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="persistence-unit-ref-name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
The persistence-unit-ref-name element specifies
the name of a persistence unit reference; its
value is the environment entry name used in
Deployment Component code. The name is a JNDI name
relative to the java:comp/env context.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="persistence-unit-name"
type="jakartaee:string"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
The Application Assembler(or BeanProvider) may use the
following syntax to avoid the need to rename persistence
units to have unique names within a Jakarta EE application.
The Application Assembler specifies the pathname of the
root of the persistence.xml file for the referenced
persistence unit and appends the name of the persistence
unit separated from the pathname by #. The pathname is
relative to the referencing application component jar file.
In this manner, multiple persistence units with the same
persistence unit name may be uniquely identified when the
Application Assembler cannot change persistence unit names.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:group ref="jakartaee:resourceBaseGroup"/>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="remoteType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The remote element contains the fully-qualified name
of the enterprise bean's remote interface.
Example:
<remote>com.wombat.empl.EmployeeService</remote>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:fully-qualified-classType"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="resource-env-refType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The resource-env-refType is used to define
resource-env-ref elements. It contains a declaration of a
Deployment Component's reference to an administered object
associated with a resource in the Deployment Component's
environment. It consists of an optional description, the
resource environment reference name, and an optional
indication of the resource environment reference type
expected by the Deployment Component code.
It also includes optional elements to define injection of
the named resource into fields or JavaBeans properties.
The resource environment type must be supplied unless an
injection target is specified, in which case the type
of the target is used. If both are specified, the type
must be assignment compatible with the type of the injection
target.
Example:
<resource-env-ref>
<resource-env-ref-name>jms/StockQueue
</resource-env-ref-name>
<resource-env-ref-type>jakarta.jms.Queue
</resource-env-ref-type>
</resource-env-ref>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="resource-env-ref-name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
The resource-env-ref-name element specifies the name
of a resource environment reference; its value is
the environment entry name used in
the Deployment Component code. The name is a JNDI
name relative to the java:comp/env context and must
be unique within a Deployment Component.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="resource-env-ref-type"
type="jakartaee:fully-qualified-classType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
The resource-env-ref-type element specifies the type
of a resource environment reference. It is the
fully qualified name of a Java language class or
interface.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:group ref="jakartaee:resourceGroup"/>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- ***************************************************** -->
<xsd:complexType name="resource-refType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The resource-refType contains a declaration of a
Deployment Component's reference to an external resource. It
consists of an optional description, the resource manager
connection factory reference name, an optional indication of
the resource manager connection factory type expected by the
Deployment Component code, an optional type of authentication
(Application or Container), and an optional specification of
the shareability of connections obtained from the resource
(Shareable or Unshareable).
It also includes optional elements to define injection of
the named resource into fields or JavaBeans properties.
The connection factory type must be supplied unless an
injection target is specified, in which case the type
of the target is used. If both are specified, the type
must be assignment compatible with the type of the injection
target.
Example:
<resource-ref>
<res-ref-name>jdbc/EmployeeAppDB</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
<res-sharing-scope>Shareable</res-sharing-scope>
</resource-ref>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="res-ref-name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
The res-ref-name element specifies the name of a
resource manager connection factory reference.
The name is a JNDI name relative to the
java:comp/env context.
The name must be unique within a Deployment File.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="res-type"
type="jakartaee:fully-qualified-classType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
The res-type element specifies the type of the data
source. The type is specified by the fully qualified
Java language class or interface
expected to be implemented by the data source.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="res-auth"
type="jakartaee:res-authType"
minOccurs="0"/>
<xsd:element name="res-sharing-scope"
type="jakartaee:res-sharing-scopeType"
minOccurs="0"/>
<xsd:group ref="jakartaee:resourceGroup"/>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="res-authType">
<xsd:annotation>
<xsd:documentation>
The res-authType specifies whether the Deployment Component
code signs on programmatically to the resource manager, or
whether the Container will sign on to the resource manager
on behalf of the Deployment Component. In the latter case,
the Container uses information that is supplied by the
Deployer.
The value must be one of the two following:
Application
Container
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string">
<xsd:enumeration value="Application"/>
<xsd:enumeration value="Container"/>
</xsd:restriction>
</xsd:simpleContent>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="res-sharing-scopeType">
<xsd:annotation>
<xsd:documentation>
The res-sharing-scope type specifies whether connections
obtained through the given resource manager connection
factory reference can be shared. The value, if specified,
must be one of the two following:
Shareable
Unshareable
The default value is Shareable.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string">
<xsd:enumeration value="Shareable"/>
<xsd:enumeration value="Unshareable"/>
</xsd:restriction>
</xsd:simpleContent>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="run-asType">
<xsd:annotation>
<xsd:documentation>
The run-asType specifies the run-as identity to be
used for the execution of a component. It contains an
optional description, and the name of a security role.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="role-name"
type="jakartaee:role-nameType"/>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="role-nameType">
<xsd:annotation>
<xsd:documentation>
The role-nameType designates the name of a security role.
The name must conform to the lexical rules for a token.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="security-roleType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The security-roleType contains the definition of a security
role. The definition consists of an optional description of
the security role, and the security role name.
Example:
<security-role>
<description>
This role includes all employees who are authorized
to access the employee service application.
</description>
<role-name>employee</role-name>
</security-role>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="role-name"
type="jakartaee:role-nameType"/>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="security-role-refType">
<xsd:annotation>
<xsd:documentation>
The security-role-refType contains the declaration of a
security role reference in a component's or a
Deployment Component's code. The declaration consists of an
optional description, the security role name used in the
code, and an optional link to a security role. If the
security role is not specified, the Deployer must choose an
appropriate security role.
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="role-name"
type="jakartaee:role-nameType">
<xsd:annotation>
<xsd:documentation>
The value of the role-name element must be the String used
as the parameter to the
EJBContext.isCallerInRole(String roleName) method or the
HttpServletRequest.isUserInRole(String role) method.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="role-link"
type="jakartaee:role-nameType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
The role-link element is a reference to a defined
security role. The role-link element must contain
the name of one of the security roles defined in the
security-role elements.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="xsdQNameType">
<xsd:annotation>
<xsd:documentation>
This type adds an "id" attribute to xsd:QName.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:extension base="xsd:QName">
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:extension>
</xsd:simpleContent>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="xsdBooleanType">
<xsd:annotation>
<xsd:documentation>
This type adds an "id" attribute to xsd:boolean.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:extension base="xsd:boolean">
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:extension>
</xsd:simpleContent>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="xsdNMTOKENType">
<xsd:annotation>
<xsd:documentation>
This type adds an "id" attribute to xsd:NMTOKEN.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:extension base="xsd:NMTOKEN">
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:extension>
</xsd:simpleContent>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="xsdAnyURIType">
<xsd:annotation>
<xsd:documentation>
This type adds an "id" attribute to xsd:anyURI.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:extension base="xsd:anyURI">
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:extension>
</xsd:simpleContent>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="xsdIntegerType">
<xsd:annotation>
<xsd:documentation>
This type adds an "id" attribute to xsd:integer.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:extension base="xsd:integer">
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:extension>
</xsd:simpleContent>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="xsdPositiveIntegerType">
<xsd:annotation>
<xsd:documentation>
This type adds an "id" attribute to xsd:positiveInteger.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:extension base="xsd:positiveInteger">
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:extension>
</xsd:simpleContent>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="xsdNonNegativeIntegerType">
<xsd:annotation>
<xsd:documentation>
This type adds an "id" attribute to xsd:nonNegativeInteger.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:extension base="xsd:nonNegativeInteger">
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:extension>
</xsd:simpleContent>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="xsdStringType">
<xsd:annotation>
<xsd:documentation>
This type adds an "id" attribute to xsd:string.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:extension base="xsd:string">
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:extension>
</xsd:simpleContent>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="string">
<xsd:annotation>
<xsd:documentation>
This is a special string datatype that is defined by Jakarta EE as
a base type for defining collapsed strings. When schemas
require trailing/leading space elimination as well as
collapsing the existing whitespace, this base type may be
used.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:extension base="xsd:token">
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:extension>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="true-falseType">
<xsd:annotation>
<xsd:documentation>
This simple type designates a boolean with only two
permissible values
- true
- false
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:xsdBooleanType">
<xsd:pattern value="(true|false)"/>
</xsd:restriction>
</xsd:simpleContent>
</xsd:complexType>
<!-- ************************************************** -->
<xsd:complexType name="url-patternType">
<xsd:annotation>
<xsd:documentation>
The url-patternType contains the url pattern of the mapping.
It must follow the rules specified in Section 11.2 of the
Servlet API Specification. This pattern is assumed to be in
URL-decoded form and must not contain CR(#xD) or LF(#xA).
If it contains those characters, the container must inform
the developer with a descriptive error message.
The container must preserve all characters including whitespaces.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:extension base="xsd:string"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="message-destinationType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The message-destinationType specifies a message
destination. The logical destination described by this
element is mapped to a physical destination by the Deployer.
The message destination element contains:
- an optional description
- an optional display-name
- an optional icon
- a message destination name which must be unique
among message destination names within the same
Deployment File.
- an optional mapped name
- an optional lookup name
Example:
<message-destination>
<message-destination-name>CorporateStocks
</message-destination-name>
</message-destination>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:group ref="jakartaee:descriptionGroup"/>
<xsd:element name="message-destination-name"
type="jakartaee:string">
<xsd:annotation>
<xsd:documentation>
The message-destination-name element specifies a
name for a message destination. This name must be
unique among the names of message destinations
within the Deployment File.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="mapped-name"
type="jakartaee:xsdStringType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
A product specific name that this message destination
should be mapped to. Each message-destination-ref
element that references this message destination will
define a name in the namespace of the referencing
component or in one of the other predefined namespaces.
Many application servers provide a way to map these
local names to names of resources known to the
application server. This mapped name is often a global
JNDI name, but may be a name of any form. Each of the
local names should be mapped to this same global name.
Application servers are not required to support any
particular form or type of mapped name, nor the ability
to use mapped names. The mapped name is
product-dependent and often installation-dependent. No
use of a mapped name is portable.
]]>
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="lookup-name"
type="jakartaee:xsdStringType"
minOccurs="0">
<xsd:annotation>
<xsd:documentation>
The JNDI name to be looked up to resolve the message destination.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="message-destination-refType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The message-destination-ref element contains a declaration
of Deployment Component's reference to a message destination
associated with a resource in Deployment Component's
environment. It consists of:
- an optional description
- the message destination reference name
- an optional message destination type
- an optional specification as to whether
the destination is used for
consuming or producing messages, or both.
if not specified, "both" is assumed.
- an optional link to the message destination
- optional injection targets
The message destination type must be supplied unless an
injection target is specified, in which case the type
of the target is used. If both are specified, the type
must be assignment compatible with the type of the injection
target.
Examples:
<message-destination-ref>
<message-destination-ref-name>jms/StockQueue
</message-destination-ref-name>
<message-destination-type>jakarta.jms.Queue
</message-destination-type>
<message-destination-usage>Consumes
</message-destination-usage>
<message-destination-link>CorporateStocks
</message-destination-link>
</message-destination-ref>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:sequence>
<xsd:element name="description"
type="jakartaee:descriptionType"
minOccurs="0"
maxOccurs="unbounded"/>
<xsd:element name="message-destination-ref-name"
type="jakartaee:jndi-nameType">
<xsd:annotation>
<xsd:documentation>
The message-destination-ref-name element specifies
the name of a message destination reference; its
value is the environment entry name used in
Deployment Component code.
</xsd:documentation>
</xsd:annotation>
</xsd:element>
<xsd:element name="message-destination-type"
type="jakartaee:message-destination-typeType"
minOccurs="0"/>
<xsd:element name="message-destination-usage"
type="jakartaee:message-destination-usageType"
minOccurs="0"/>
<xsd:element name="message-destination-link"
type="jakartaee:message-destination-linkType"
minOccurs="0"/>
<xsd:group ref="jakartaee:resourceGroup"/>
</xsd:sequence>
<xsd:attribute name="id" type="xsd:ID"/>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="message-destination-usageType">
<xsd:annotation>
<xsd:documentation>
The message-destination-usageType specifies the use of the
message destination indicated by the reference. The value
indicates whether messages are consumed from the message
destination, produced for the destination, or both. The
Assembler makes use of this information in linking producers
of a destination with its consumers.
The value of the message-destination-usage element must be
one of the following:
Consumes
Produces
ConsumesProduces
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string">
<xsd:enumeration value="Consumes"/>
<xsd:enumeration value="Produces"/>
<xsd:enumeration value="ConsumesProduces"/>
</xsd:restriction>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="message-destination-typeType">
<xsd:annotation>
<xsd:documentation>
<![CDATA[
The message-destination-typeType specifies the type of
the destination. The type is specified by the Java interface
expected to be implemented by the destination.
Example:
<message-destination-type>jakarta.jms.Queue
</message-destination-type>
]]>
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:fully-qualified-classType"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="message-destination-linkType">
<xsd:annotation>
<xsd:documentation>
The message-destination-linkType is used to link a message
destination reference or message-driven bean to a message
destination.
The Assembler sets the value to reflect the flow of messages
between producers and consumers in the application.
The value must be the message-destination-name of a message
destination in the same Deployment File or in another
Deployment File in the same Jakarta EE application unit.
Alternatively, the value may be composed of a path name
specifying a Deployment File containing the referenced
message destination with the message-destination-name of the
destination appended and separated from the path name by
"#". The path name is relative to the Deployment File
containing Deployment Component that is referencing the
message destination. This allows multiple message
destinations with the same name to be uniquely identified.
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string"/>
</xsd:simpleContent>
</xsd:complexType>
<!-- **************************************************** -->
<xsd:complexType name="transaction-supportType">
<xsd:annotation>
<xsd:documentation>
The transaction-supportType specifies the level of
transaction support provided by the resource adapter. It is
used by transaction-support elements.
The value must be one of the following:
NoTransaction
LocalTransaction
XATransaction
</xsd:documentation>
</xsd:annotation>
<xsd:simpleContent>
<xsd:restriction base="jakartaee:string">
<xsd:enumeration value="NoTransaction"/>
<xsd:enumeration value="LocalTransaction"/>
<xsd:enumeration value="XATransaction"/>
</xsd:restriction>
</xsd:simpleContent>
</xsd:complexType>
</xsd:schema>