Class CmsXmlContentDefinition
- All Implemented Interfaces:
Cloneable
- Since:
- 6.0.0
-
Nested Class Summary
Modifier and TypeClassDescriptionstatic enum
Enumeration of possible sequence types in a content definition. -
Field Summary
Modifier and TypeFieldDescriptionstatic final String
Constant for the XML schema attribute "mapto".static final String
Constant for the XML schema attribute "elementFormDefault".static final String
Constant for the XML schema attribute "maxOccurs".static final String
Constant for the XML schema attribute "minOccurs".static final String
Constant for the XML schema attribute "name".static final String
Constant for the XML schema attribute "schemaLocation".static final String
Constant for the XML schema attribute "type".static final String
Constant for the XML schema attribute "use".static final String
Constant for the XML schema attribute value "language".static final String
Constant for the XML schema attribute value "1".static final String
Constant for the XML schema attribute value "optional".static final String
Constant for the XML schema attribute value "qualified".static final String
Constant for the XML schema attribute value "required".static final String
Constant for the XML schema attribute value "unbounded".static final String
Constant for the XML schema attribute value "0".static final String
The opencms default type definition include.static final org.dom4j.Namespace
The schema definition namespace.static final org.dom4j.QName
Constant for the "annotation" node in the XML schema namespace.static final org.dom4j.QName
Constant for the "appinfo" node in the XML schema namespace.static final org.dom4j.QName
Constant for the "attribute" node in the XML schema namespace.static final org.dom4j.QName
Constant for the "choice" node in the XML schema namespace.static final org.dom4j.QName
Constant for the "complexType" node in the XML schema namespace.static final org.dom4j.QName
Constant for the "element" node in the XML schema namespace.static final org.dom4j.QName
Constant for the "include" node in the XML schema namespace.static final org.dom4j.QName
Constant for the "schema" node in the XML schema namespace.static final org.dom4j.QName
Constant for the "sequence" node in the XML schema namespace. -
Constructor Summary
ModifierConstructorDescriptionprotected
Required empty constructor for clone operation.CmsXmlContentDefinition
(String innerName, String schemaLocation) Creates a new XML content definition.CmsXmlContentDefinition
(String outerName, String innerName, String schemaLocation) Creates a new XML content definition. -
Method Summary
Modifier and TypeMethodDescriptionorg.dom4j.Element
addDefaultXml
(CmsObject cms, I_CmsXmlDocument document, org.dom4j.Element root, Locale locale) Adds the missing default XML according to this content definition to the given document element.void
addInclude
(CmsXmlContentDefinition nestedSchema) Adds a nested (included) XML content definition.void
addType
(I_CmsXmlSchemaType type) Adds the given content type.clone()
Creates a clone of this XML content definition.org.dom4j.Element
createDefaultXml
(CmsObject cms, I_CmsXmlDocument document, org.dom4j.Element root, Locale locale) Generates the default XML content for this content definition, and append it to the given root element.org.dom4j.Document
createDocument
(CmsObject cms, I_CmsXmlDocument document, Locale locale) Generates a valid XML document according to the XML schema of this content definition.org.dom4j.Element
createLocale
(CmsObject cms, I_CmsXmlDocument document, org.dom4j.Element root, Locale locale) Generates a valid locale (language) element for the XML schema of this content definition.protected static String
createTypeName
(String name) Creates the name of the type attribute from the given content name.boolean
boolean
findSchemaTypesForPath
(String path, BiConsumer<I_CmsXmlSchemaType, String> consumer) Iterates over all schema types along a given xpath, starting from a root content definition.void
freeze()
Freezes this content definition, making all internal data structures unmodifiable.int
Returns the maxOccurs value for the choice in case this is axsd:choice
content definition.static CmsXmlContentDefinition
getContentDefinitionForResource
(CmsObject cms, CmsResource resource) Factory method that returns the XML content definition instance for a given resource.static CmsXmlContentDefinition
getContentDefinitionForType
(CmsObject cms, String typeName) Reads the content definition which is configured for a resource type.Returns the selected XML content handler for this XML content definition.static I_CmsXmlContentHandler
getContentHandlerForResource
(CmsObject cms, CmsResource resource) Returns a content handler instance for the given resource.Returns the set of nested (included) XML content definitions.Returns the inner element name of this content definition.Returns the outer element name of this content definition.org.dom4j.Document
Generates an XML schema for the content definition.Returns the location from which the XML schema was read (XML system id).getSchemaType
(String elementPath) Returns the schema type for the given element name, ornull
if no node is defined with this name.Returns the internal set of schema type names.Returns the sequence type of this content definition.Returns the main type name of this XML content definition.Returns the type sequence, contains instances ofI_CmsXmlSchemaType
.int
Gets the version.int
hashCode()
protected void
setInnerName
(String innerName) Sets the inner element name to use for the content definition.protected void
setOuterName
(String outerName) Sets the outer element name to use for the content definition.toString()
static CmsXmlContentDefinition
unmarshal
(byte[] xmlData, String schemaLocation, EntityResolver resolver) Factory method to unmarshal (read) a XML content definition instance from a byte array that contains XML data.static CmsXmlContentDefinition
unmarshal
(String xmlData, String schemaLocation, EntityResolver resolver) Factory method to unmarshal (read) a XML content definition instance from a String that contains XML data.static CmsXmlContentDefinition
unmarshal
(String schemaLocation, EntityResolver resolver) Factory method to unmarshal (read) a XML content definition instance from a given XML schema location.static CmsXmlContentDefinition
Factory method to unmarshal (read) a XML content definition instance from a XML document.static CmsXmlContentDefinition
Factory method to unmarshal (read) a XML content definition instance from the OpenCms VFS resource name.static CmsXmlContentDefinition
unmarshal
(InputSource source, String schemaLocation, EntityResolver resolver) Factory method to unmarshal (read) a XML content definition instance from a XML InputSource.protected static String
validateAttribute
(org.dom4j.Element element, String attributeName, String requiredValue) Validates if a given attribute exists at the given element with an (optional) specified value.protected static void
validateAttributesExists
(org.dom4j.Element element, String[] requiredAttributes, String[] optionalAttributes) Validates if a given element has exactly the required attributes set.protected static org.opencms.xml.CmsXmlComplexTypeSequence
validateComplexTypeSequence
(org.dom4j.Element element, Set<CmsXmlContentDefinition> includes) Validates the given element as a complex type sequence.
-
Field Details
-
XSD_ATTRIBUTE_DEFAULT
Constant for the XML schema attribute "mapto".- See Also:
-
XSD_ATTRIBUTE_ELEMENT_FORM_DEFAULT
Constant for the XML schema attribute "elementFormDefault".- See Also:
-
XSD_ATTRIBUTE_MAX_OCCURS
Constant for the XML schema attribute "maxOccurs".- See Also:
-
XSD_ATTRIBUTE_MIN_OCCURS
Constant for the XML schema attribute "minOccurs".- See Also:
-
XSD_ATTRIBUTE_NAME
Constant for the XML schema attribute "name".- See Also:
-
XSD_ATTRIBUTE_SCHEMA_LOCATION
Constant for the XML schema attribute "schemaLocation".- See Also:
-
XSD_ATTRIBUTE_TYPE
Constant for the XML schema attribute "type".- See Also:
-
XSD_ATTRIBUTE_USE
Constant for the XML schema attribute "use".- See Also:
-
XSD_ATTRIBUTE_VALUE_LANGUAGE
Constant for the XML schema attribute value "language".- See Also:
-
XSD_ATTRIBUTE_VALUE_ONE
Constant for the XML schema attribute value "1".- See Also:
-
XSD_ATTRIBUTE_VALUE_OPTIONAL
Constant for the XML schema attribute value "optional".- See Also:
-
XSD_ATTRIBUTE_VALUE_QUALIFIED
Constant for the XML schema attribute value "qualified".- See Also:
-
XSD_ATTRIBUTE_VALUE_REQUIRED
Constant for the XML schema attribute value "required".- See Also:
-
XSD_ATTRIBUTE_VALUE_UNBOUNDED
Constant for the XML schema attribute value "unbounded".- See Also:
-
XSD_ATTRIBUTE_VALUE_ZERO
Constant for the XML schema attribute value "0".- See Also:
-
XSD_INCLUDE_OPENCMS
The opencms default type definition include.- See Also:
-
XSD_NAMESPACE
The schema definition namespace. -
XSD_NODE_ANNOTATION
Constant for the "annotation" node in the XML schema namespace. -
XSD_NODE_APPINFO
Constant for the "appinfo" node in the XML schema namespace. -
XSD_NODE_ATTRIBUTE
Constant for the "attribute" node in the XML schema namespace. -
XSD_NODE_CHOICE
Constant for the "choice" node in the XML schema namespace. -
XSD_NODE_COMPLEXTYPE
Constant for the "complexType" node in the XML schema namespace. -
XSD_NODE_ELEMENT
Constant for the "element" node in the XML schema namespace. -
XSD_NODE_INCLUDE
Constant for the "include" node in the XML schema namespace. -
XSD_NODE_SCHEMA
Constant for the "schema" node in the XML schema namespace. -
XSD_NODE_SEQUENCE
Constant for the "sequence" node in the XML schema namespace.
-
-
Constructor Details
-
CmsXmlContentDefinition
Creates a new XML content definition.- Parameters:
innerName
- the inner element name to use for the content definitonschemaLocation
- the location from which the XML schema was read (system id)
-
CmsXmlContentDefinition
Creates a new XML content definition.- Parameters:
outerName
- the outer element name to use for the content definitioninnerName
- the inner element name to use for the content definitionschemaLocation
- the location from which the XML schema was read (system id)
-
CmsXmlContentDefinition
protected CmsXmlContentDefinition()Required empty constructor for clone operation.
-
-
Method Details
-
getContentDefinitionForResource
public static CmsXmlContentDefinition getContentDefinitionForResource(CmsObject cms, CmsResource resource) throws CmsException Factory method that returns the XML content definition instance for a given resource.- Parameters:
cms
- the cms-objectresource
- the resource- Returns:
- the XML content definition
- Throws:
CmsException
- if something goes wrong
-
getContentDefinitionForType
public static CmsXmlContentDefinition getContentDefinitionForType(CmsObject cms, String typeName) throws CmsException Reads the content definition which is configured for a resource type.- Parameters:
cms
- the current CMS contexttypeName
- the type name- Returns:
- the content definition
- Throws:
CmsException
- if something goes wrong
-
getContentHandlerForResource
public static I_CmsXmlContentHandler getContentHandlerForResource(CmsObject cms, CmsResource resource) throws CmsException Returns a content handler instance for the given resource.- Parameters:
cms
- the cms-objectresource
- the resource- Returns:
- the content handler
- Throws:
CmsException
- if something goes wrong
-
unmarshal
public static CmsXmlContentDefinition unmarshal(byte[] xmlData, String schemaLocation, EntityResolver resolver) throws CmsXmlException Factory method to unmarshal (read) a XML content definition instance from a byte array that contains XML data.- Parameters:
xmlData
- the XML data in a byte arrayschemaLocation
- the location from which the XML schema was read (system id)resolver
- the XML entity resolver to use- Returns:
- a XML content definition instance unmarshalled from the byte array
- Throws:
CmsXmlException
- if something goes wrong
-
unmarshal
public static CmsXmlContentDefinition unmarshal(CmsObject cms, String resourcename) throws CmsXmlException Factory method to unmarshal (read) a XML content definition instance from the OpenCms VFS resource name.- Parameters:
cms
- the current users CmsObjectresourcename
- the resource name to unmarshal the XML content definition from- Returns:
- a XML content definition instance unmarshalled from the VFS resource
- Throws:
CmsXmlException
- if something goes wrong
-
unmarshal
public static CmsXmlContentDefinition unmarshal(org.dom4j.Document document, String schemaLocation) throws CmsXmlException Factory method to unmarshal (read) a XML content definition instance from a XML document.This method does additional validation to ensure the document has the required XML structure for a OpenCms content definition schema.
- Parameters:
document
- the XML document to generate a XML content definition fromschemaLocation
- the location from which the XML schema was read (system id)- Returns:
- a XML content definition instance unmarshalled from the XML document
- Throws:
CmsXmlException
- if something goes wrong
-
unmarshal
public static CmsXmlContentDefinition unmarshal(InputSource source, String schemaLocation, EntityResolver resolver) throws CmsXmlException Factory method to unmarshal (read) a XML content definition instance from a XML InputSource.- Parameters:
source
- the XML InputSource to useschemaLocation
- the location from which the XML schema was read (system id)resolver
- the XML entity resolver to use- Returns:
- a XML content definition instance unmarshalled from the InputSource
- Throws:
CmsXmlException
- if something goes wrong
-
unmarshal
public static CmsXmlContentDefinition unmarshal(String schemaLocation, EntityResolver resolver) throws CmsXmlException, SAXException, IOException Factory method to unmarshal (read) a XML content definition instance from a given XML schema location.The XML content definition data to unmarshal will be read from the provided schema location using an XML InputSource.
- Parameters:
schemaLocation
- the location from which to read the XML schema (system id)resolver
- the XML entity resolver to use- Returns:
- a XML content definition instance unmarshalled from the InputSource
- Throws:
CmsXmlException
- if something goes wrongSAXException
- if the XML schema location could not be converted to an XML InputSourceIOException
- if the XML schema location could not be converted to an XML InputSource
-
unmarshal
public static CmsXmlContentDefinition unmarshal(String xmlData, String schemaLocation, EntityResolver resolver) throws CmsXmlException Factory method to unmarshal (read) a XML content definition instance from a String that contains XML data.- Parameters:
xmlData
- the XML data in a StringschemaLocation
- the location from which the XML schema was read (system id)resolver
- the XML entity resolver to use- Returns:
- a XML content definition instance unmarshalled from the byte array
- Throws:
CmsXmlException
- if something goes wrong
-
createTypeName
Creates the name of the type attribute from the given content name.- Parameters:
name
- the name to use- Returns:
- the name of the type attribute
-
validateAttribute
protected static String validateAttribute(org.dom4j.Element element, String attributeName, String requiredValue) throws CmsXmlException Validates if a given attribute exists at the given element with an (optional) specified value.If the required value is not
null
, the attribute must have exactly this value set.If no value is required, some simple validation is performed on the attribute value, like a check that the value does not have leading or trailing white spaces.
- Parameters:
element
- the element to validateattributeName
- the attribute to check forrequiredValue
- the required value of the attribute, ornull
if any value is allowed- Returns:
- the value of the attribute
- Throws:
CmsXmlException
- if the element does not have the required attribute set, or if the validation fails
-
validateAttributesExists
protected static void validateAttributesExists(org.dom4j.Element element, String[] requiredAttributes, String[] optionalAttributes) throws CmsXmlException Validates if a given element has exactly the required attributes set.- Parameters:
element
- the element to validaterequiredAttributes
- the list of required attributesoptionalAttributes
- the list of optional attributes- Throws:
CmsXmlException
- if the validation fails
-
validateComplexTypeSequence
protected static org.opencms.xml.CmsXmlComplexTypeSequence validateComplexTypeSequence(org.dom4j.Element element, Set<CmsXmlContentDefinition> includes) throws CmsXmlException Validates the given element as a complex type sequence.- Parameters:
element
- the element to validateincludes
- the XML schema includes- Returns:
- a data structure containing the validated complex type sequence data
- Throws:
CmsXmlException
- if the validation fails
-
addDefaultXml
public org.dom4j.Element addDefaultXml(CmsObject cms, I_CmsXmlDocument document, org.dom4j.Element root, Locale locale) Adds the missing default XML according to this content definition to the given document element.In case the root element already contains sub nodes, only missing sub nodes are added.
- Parameters:
cms
- the current users OpenCms contextdocument
- the document where the XML is added in (required for default XML generation)root
- the root node to add the missing XML forlocale
- the locale to add the XML for- Returns:
- the given root element with the missing content added
-
addInclude
Adds a nested (included) XML content definition.- Parameters:
nestedSchema
- the nested (included) XML content definition to add
-
addType
Adds the given content type.- Parameters:
type
- the content type to add- Throws:
CmsXmlException
- in case an unregistered type is added
-
clone
Creates a clone of this XML content definition. -
createDefaultXml
public org.dom4j.Element createDefaultXml(CmsObject cms, I_CmsXmlDocument document, org.dom4j.Element root, Locale locale) Generates the default XML content for this content definition, and append it to the given root element.Please note: The default values for the annotations are read from the content definition of the given document. For a nested content definitions, this means that all defaults are set in the annotations of the "outer" or "main" content definition.
- Parameters:
cms
- the current users OpenCms contextdocument
- the OpenCms XML document the XML is created forroot
- the node of the document where to append the generated XML tolocale
- the locale to create the default element in the document with- Returns:
- the default XML content for this content definition, and append it to the given root element
-
createDocument
Generates a valid XML document according to the XML schema of this content definition.- Parameters:
cms
- the current users OpenCms contextdocument
- the OpenCms XML document the XML is created forlocale
- the locale to create the default element in the document with- Returns:
- a valid XML document according to the XML schema of this content definition
-
createLocale
public org.dom4j.Element createLocale(CmsObject cms, I_CmsXmlDocument document, org.dom4j.Element root, Locale locale) Generates a valid locale (language) element for the XML schema of this content definition.- Parameters:
cms
- the current users OpenCms contextdocument
- the OpenCms XML document the XML is created forroot
- the root node of the document where to append the locale tolocale
- the locale to create the default element in the document with- Returns:
- a valid XML element for the locale according to the XML schema of this content definition
-
equals
-
findSchemaTypesForPath
Iterates over all schema types along a given xpath, starting from a root content definition.- Parameters:
path
- the pathconsumer
- a handler that consumes both the schema type and the remaining suffix of the path, relative to the schema type- Returns:
- true if for all path components a schema type could be found
-
freeze
Freezes this content definition, making all internal data structures unmodifiable.This is required to prevent modification of a cached content definition.
-
getChoiceMaxOccurs
Returns the maxOccurs value for the choice in case this is axsd:choice
content definition.This content definition is a
xsd:choice
sequence if the returned value is larger then 0.- Returns:
- the maxOccurs value for the choice in case this is a
xsd:choice
content definition
-
getContentHandler
Returns the selected XML content handler for this XML content definition.If no specific XML content handler was provided in the "appinfo" node of the XML schema, the default XML content handler
is used.CmsDefaultXmlContentHandler
- Returns:
- the contentHandler
-
getIncludes
Returns the set of nested (included) XML content definitions.- Returns:
- the set of nested (included) XML content definitions
-
getInnerName
Returns the inner element name of this content definition.- Returns:
- the inner element name of this content definition
-
getOuterName
Returns the outer element name of this content definition.- Returns:
- the outer element name of this content definition
-
getSchema
Generates an XML schema for the content definition.- Returns:
- the generated XML schema
-
getSchemaLocation
Returns the location from which the XML schema was read (XML system id).- Returns:
- the location from which the XML schema was read (XML system id)
-
getSchemaType
Returns the schema type for the given element name, ornull
if no node is defined with this name.- Parameters:
elementPath
- the element xpath to look up the type for- Returns:
- the type for the given element name, or
null
if no node is defined with this name
-
getSchemaTypes
Returns the internal set of schema type names.- Returns:
- the internal set of schema type names
-
getSequenceType
Returns the sequence type of this content definition.- Returns:
- the sequence type of this content definition
-
getTypeName
Returns the main type name of this XML content definition.- Returns:
- the main type name of this XML content definition
-
getTypeSequence
Returns the type sequence, contains instances ofI_CmsXmlSchemaType
.- Returns:
- the type sequence, contains instances of
I_CmsXmlSchemaType
-
getVersion
Gets the version.- Returns:
- the version number
-
hashCode
-
toString
-
setInnerName
Sets the inner element name to use for the content definition.- Parameters:
innerName
- the inner element name to set
-
setOuterName
Sets the outer element name to use for the content definition.- Parameters:
outerName
- the outer element name to set
-