Apache Geronimo > Index > Development > XML Schemas > Apache Geronimo v2.2 XML Schemas | User List | Dev List | Wiki | Issue Tracker |
|
Documentation for geronimo-application-2.0Table of ContentsSchema Document Properties
Declared Namespaces
<xs:schema
targetNamespace="http://geronimo.apache.org/xml/ns/j2ee/application-2.0" elementFormDefault="qualified" attributeFormDefault="unqualified" version="1.0">
<xs:import
namespace="http://geronimo.apache.org/xml/ns/deployment-1.2" schemaLocation="geronimo-module-1.2.xsd"/>
... </xs:schema>Global DeclarationsElement: application
<geronimo:application
application-name=" xs:string [0..1] 'An optional attribute used to define the application name for main parent enterprise application defined in ear module.' "><sys:environment> ... </sys:environment> [1]
'Reference to environment element defined in imported \"geronimo-module-1.2.xsd\"' <geronimo:module>
geronimo:moduleType
</geronimo:module> [0..*]
'An optional module element which defines various modules included in the enterprise application archive. It mirrors the moduleType defined by application_1_4.xsd and adds an optional alt-dd element defining a Geronimo specific deployment descriptor.' <geronimo:ext-module>
geronimo:ext-moduleType
</geronimo:ext-module> [0..*]
'It is used to define modules included in this application externally and these module could be included in the archive, or they may reside in Geronimo repository. It defines optional internal-path or external-path to module/repository element being referenced.' <geronimo:security> ... </geronimo:security> [0..1]
'Reference to security element defined in this schema. If this optional element is present, all web and EJB modules must make the appropriate access checks as outlined in the JACC spec. This element groups the security role mapping settings for the application.' <sys:service> ... </sys:service> [0..*]
</geronimo:application>'Reference to service element defined in imported \"geronimo-module-1.2.xsd\".' Element: clustering
<geronimo:clustering/>
Element: security
<geronimo:security/>
Global DefinitionsComplex Type: abstract-clusteringType
<.../>
<xs:complexType
name="abstract-clusteringType" abstract="true">
<xs:sequence/> </xs:complexType>Complex Type: abstract-securityType
<.../>
<xs:complexType
name="abstract-securityType" abstract="true">
<xs:sequence/> </xs:complexType>Complex Type: applicationType
<...
application-name=" xs:string [0..1] 'An optional attribute used to define the application name for main parent enterprise application defined in ear module.' "><sys:environment> ... </sys:environment> [1]
'Reference to environment element defined in imported \"geronimo-module-1.2.xsd\"' <geronimo:module>
geronimo:moduleType
</geronimo:module> [0..*]
'An optional module element which defines various modules included in the enterprise application archive. It mirrors the moduleType defined by application_1_4.xsd and adds an optional alt-dd element defining a Geronimo specific deployment descriptor.' <geronimo:ext-module>
geronimo:ext-moduleType
</geronimo:ext-module> [0..*]
'It is used to define modules included in this application externally and these module could be included in the archive, or they may reside in Geronimo repository. It defines optional internal-path or external-path to module/repository element being referenced.' <geronimo:security> ... </geronimo:security> [0..1]
</...>'Reference to security element defined in this schema. If this optional element is present, all web and EJB modules must make the appropriate access checks as outlined in the JACC spec. This element groups the security role mapping settings for the application.' <xs:complexType
name="applicationType">
<xs:sequence>
<xs:element
name="ext-module" type="
geronimo:ext-moduleType
" minOccurs="0" maxOccurs="unbounded"/>
</xs:sequence><--TODO application name should be settable using name-key in the environment. Does this work? -->
</xs:complexType>Complex Type: ext-moduleType
<...>
Start Choice [1] <geronimo:connector>
geronimo:pathType
</geronimo:connector> [1]
'The presence of this element is indicative of J2EE module type to be resource adapter module, and the value of this element provides URI of resource adapter archive file path relative to the enterprise application package main directory.' <geronimo:ejb>
geronimo:pathType
</geronimo:ejb> [1]
'The presence of this element is indicative of J2EE module type to be EJB module, and the value of this element provides URI of EJB archive file path relative to the enterprise application package main directory.' <geronimo:java>
geronimo:pathType
</geronimo:java> [1]
'The presence of this element is indicative of J2EE module type to be Java Application client module, and the value of this element provides URI of application client java archive file path relative to the enterprise application package main directory.' <geronimo:web>
geronimo:pathType
</geronimo:web> [1]
End Choice
'The presence of this element is indicative of Web module type to be EJB module, and the value of this element provides URI of Web archive file path relative to the enterprise application package main directory.' Start Choice [1] <geronimo:internal-path>
xs:token </geronimo:internal-path> [1]
'The element indicates that the module is a part of this enterprise application. The value of this element specifies the path of module relative to internal path indicates that the module is packaged in the EAR, and a path specified here is relative to the enterprise application package main directory.' <geronimo:external-path>
sys:patternType
</geronimo:external-path> [1]
End Choice
'The element indicates that the module is not a part of this enterprise application, but rather located matching the supplied pattern in a Geronimo repository.' Allow any elements from a namespace other than this schema's namespace (lax validation). [1]
</...><xs:complexType
name="ext-moduleType">
<xs:sequence> </xs:complexType><xs:choice>
</xs:choice>
<xs:choice>
</xs:choice>
<--TODO consider an alt-spec-dd element-->
<--Do not allow vendor plan inside ear. If it is in the ear, this does not need to be an external module -->
<xs:any
namespace="##other" processContents="lax"/> </xs:sequence>Complex Type: moduleType
<...>
Start Choice [1] <geronimo:connector>
geronimo:pathType
</geronimo:connector> [1]
'The presence of this element is indicative of J2EE module type to be resource adapter module, and the value of this element provides URI of resource adapter archive file path relative to the enterprise application package main directory.' <geronimo:ejb>
geronimo:pathType
</geronimo:ejb> [1]
'The presence of this element is indicative of J2EE module type to be EJB module, and the value of this element provides URI of EJB archive file path relative to the enterprise application package main directory.' <geronimo:java>
geronimo:pathType
</geronimo:java> [1]
'The presence of this element is indicative of J2EE module type to be Java Application client module, and the value of this element provides URI of application client java archive file path relative to the enterprise application package main directory.' <geronimo:web>
geronimo:pathType
</geronimo:web> [1]
End Choice
'The presence of this element is indicative of Web module type to be EJB module, and the value of this element provides URI of Web archive file path relative to the enterprise application package main directory.' Start Choice [1] <geronimo:alt-dd>
geronimo:pathType
</geronimo:alt-dd> [1]
'Specifies an optional URI to the post-assembly version of the Geronimo specific deployment descriptor file for a particular J2EE module relative to the enterprise application package main directory.' Allow any elements from a namespace other than this schema's namespace (lax validation). [1]
End Choice
</...> <xs:complexType
name="moduleType">
<xs:sequence> </xs:complexType><xs:choice>
</xs:choice>
<xs:choice>
</xs:sequence><xs:any
namespace="##other" processContents="lax"/> </xs:choice>Complex Type: pathType
Complex Type: string
LegendComplex Type:Schema Component Type
AusAddressSchema Component Name
If this schema component is a type definition, its type hierarchy is shown in a gray-bordered box.
The table above displays the properties of this schema component.
<...
country="Australia"
>
<unitNo> string </unitNo> [0..1] <houseNo> string </houseNo> [1] <street> string </street> [1] Start Choice [1] <city> string </city> [1] <town> string </town> [1] End Choice <state> AusStates </state> [1] <postcode> string <<pattern = [1-9][0-9]{3}>> </postcode> [1] </...> The XML Instance Representation table above shows the schema component's content as an XML instance.
<complexType
name="AusAddress">
<complexContent> <extension base=" Address "> <sequence> <element name="state" type=" AusStates "/> <element name="postcode"> <simpleType> <restriction base=" string "> <pattern value="[1-9][0-9]{3}"/> </restriction> </simpleType> </element> </sequence> <attribute name="country" type=" string " fixed="Australia"/> </extension> </complexContent> </complexType> The Schema Component Representation table above displays the underlying XML representation of the schema component. (Annotations are not shown.)
GlossaryAbstract (Applies to complex type definitions and element declarations). An abstract element or complex type cannot used to validate an element instance. If there is a reference to an abstract element, only element declarations that can substitute the abstract element can be used to validate the instance. For references to abstract type definitions, only derived types can be used. All Model Group Child elements can be provided in any order in instances. See: http://www.w3.org/TR/xmlschema-1/#element-all. Choice Model Group Only one from the list of child elements and model groups can be provided in instances. See: http://www.w3.org/TR/xmlschema-1/#element-choice. Collapse Whitespace Policy Replace tab, line feed, and carriage return characters with space character (Unicode character 32). Then, collapse contiguous sequences of space characters into single space character, and remove leading and trailing space characters.
Disallowed Substitutions
(Applies to element declarations). If substitution is specified, then substitution group members cannot be used in place of the given element declaration to validate element instances. If derivation methods, e.g. extension, restriction, are specified, then the given element declaration will not validate element instances that have types derived from the element declaration's type using the specified derivation methods. Normally, element instances can override their declaration's type by specifying an Key Constraint Like Uniqueness Constraint, but additionally requires that the specified value(s) must be provided. See: http://www.w3.org/TR/xmlschema-1/#cIdentity-constraint_Definitions. Key Reference Constraint Ensures that the specified value(s) must match value(s) from a Key Constraint or Uniqueness Constraint. See: http://www.w3.org/TR/xmlschema-1/#cIdentity-constraint_Definitions. Model Group Groups together element content, specifying the order in which the element content can occur and the number of times the group of element content may be repeated. See: http://www.w3.org/TR/xmlschema-1/#Model_Groups.
Nillable
(Applies to element declarations). If an element declaration is nillable, instances can use the Notation A notation is used to identify the format of a piece of data. Values of elements and attributes that are of type, NOTATION, must come from the names of declared notations. See: http://www.w3.org/TR/xmlschema-1/#cNotation_Declarations. Preserve Whitespace Policy Preserve whitespaces exactly as they appear in instances. Prohibited Derivations (Applies to type definitions). Derivation methods that cannot be used to create sub-types from a given type definition. Prohibited Substitutions (Applies to complex type definitions). Prevents sub-types that have been derived using the specified derivation methods from validating element instances in place of the given type definition. Replace Whitespace Policy Replace tab, line feed, and carriage return characters with space character (Unicode character 32). Sequence Model Group Child elements and model groups must be provided in the specified order in instances. See: http://www.w3.org/TR/xmlschema-1/#element-sequence. Substitution Group Elements that are members of a substitution group can be used wherever the head element of the substitution group is referenced. Substitution Group Exclusions (Applies to element declarations). Prohibits element declarations from nominating themselves as being able to substitute a given element declaration, if they have types that are derived from the original element's type using the specified derivation methods. Target Namespace The target namespace identifies the namespace that components in this schema belongs to. If no target namespace is provided, then the schema components do not belong to any namespace. Uniqueness Constraint Ensures uniqueness of an element/attribute value, or a combination of values, within a specified scope. See: http://www.w3.org/TR/xmlschema-1/#cIdentity-constraint_Definitions. |