-/*\r
- * Copyright 2001-2005 Internet2\r
- * \r
- * Licensed under the Apache License, Version 2.0 (the "License");\r
- * you may not use this file except in compliance with the License.\r
- * You may obtain a copy of the License at\r
- *\r
- * http://www.apache.org/licenses/LICENSE-2.0\r
- *\r
- * Unless required by applicable law or agreed to in writing, software\r
- * distributed under the License is distributed on an "AS IS" BASIS,\r
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
- * See the License for the specific language governing permissions and\r
- * limitations under the License.\r
- */\r
-\r
-#include <cxxtest/TestSuite.h>\r
-#include <xmltooling/AbstractAttributeExtensibleXMLObject.h>\r
-#include <xmltooling/AbstractDOMCachingXMLObject.h>\r
-#include <xmltooling/AbstractExtensibleXMLObject.h>\r
-#include <xmltooling/exceptions.h>\r
-#include <xmltooling/XMLObjectBuilder.h>\r
-#include <xmltooling/XMLToolingConfig.h>\r
-#include <xmltooling/io/AbstractXMLObjectMarshaller.h>\r
-#include <xmltooling/io/AbstractXMLObjectUnmarshaller.h>\r
-#include <xmltooling/util/ParserPool.h>\r
-#include <xmltooling/util/XMLObjectChildrenList.h>\r
-#include <xmltooling/util/XMLHelper.h>\r
-\r
-using namespace xmltooling;\r
-using namespace std;\r
-\r
-extern ParserPool* validatingPool;\r
-extern ParserPool* nonvalidatingPool;\r
-extern string data_path;\r
-\r
-#if defined (_MSC_VER)\r
- #pragma warning( push )\r
- #pragma warning( disable : 4250 4251 )\r
-#endif\r
-\r
-class SimpleXMLObject : public AbstractDOMCachingXMLObject\r
-{\r
-public:\r
- static const XMLCh NAMESPACE[];\r
- static const XMLCh NAMESPACE_PREFIX[];\r
- static const XMLCh LOCAL_NAME[];\r
- static const XMLCh ID_ATTRIB_NAME[];\r
-\r
- SimpleXMLObject() : AbstractDOMCachingXMLObject(NAMESPACE, LOCAL_NAME, NAMESPACE_PREFIX), m_id(NULL), m_value(NULL) {}\r
- virtual ~SimpleXMLObject() {\r
- XMLString::release(&m_id);\r
- XMLString::release(&m_value);\r
- }\r
- \r
- const XMLCh* getId() const { return m_id; }\r
- void setId(const XMLCh* id) { m_id=prepareForAssignment(m_id,id); }\r
-\r
- const XMLCh* getValue() const { return m_value; }\r
- void setValue(const XMLCh* value) { m_value=prepareForAssignment(m_value,value); }\r
- \r
- VectorOf(SimpleXMLObject) getSimpleXMLObjects() {\r
- return VectorOf(SimpleXMLObject)(this, m_simples, &m_children, m_children.end());\r
- }\r
- \r
- SimpleXMLObject* clone() const {\r
- auto_ptr<XMLObject> domClone(AbstractDOMCachingXMLObject::clone());\r
- SimpleXMLObject* ret=dynamic_cast<SimpleXMLObject*>(domClone.get());\r
- if (ret) {\r
- domClone.release();\r
- return ret;\r
- }\r
-\r
- ret=new SimpleXMLObject();\r
- ret->setId(m_id);\r
- ret->setValue(m_value);\r
- xmltooling::clone(m_children, ret->m_children);\r
- return ret;\r
- }\r
-\r
-private:\r
- XMLCh* m_id;\r
- XMLCh* m_value;\r
- vector<SimpleXMLObject*> m_simples;\r
-};\r
-\r
-class SimpleXMLObjectBuilder : public XMLObjectBuilder\r
-{\r
-public:\r
- SimpleXMLObject* buildObject() const {\r
- return new SimpleXMLObject();\r
- }\r
-};\r
-\r
-class SimpleXMLObjectMarshaller : public AbstractXMLObjectMarshaller\r
-{\r
-public:\r
- SimpleXMLObjectMarshaller() {}\r
-\r
-private:\r
- void marshallAttributes(const XMLObject& xmlObject, DOMElement* domElement) const {\r
- const SimpleXMLObject& simpleXMLObject = dynamic_cast<const SimpleXMLObject&>(xmlObject);\r
- \r
- if(simpleXMLObject.getId()) {\r
- domElement->setAttributeNS(NULL, SimpleXMLObject::ID_ATTRIB_NAME, simpleXMLObject.getId());\r
- domElement->setIdAttributeNS(NULL, SimpleXMLObject::ID_ATTRIB_NAME);\r
- }\r
- }\r
-\r
- void marshallElementContent(const XMLObject& xmlObject, DOMElement* domElement) const {\r
- const SimpleXMLObject& simpleXMLObject = dynamic_cast<const SimpleXMLObject&>(xmlObject);\r
-\r
- if(simpleXMLObject.getValue()) {\r
- domElement->setTextContent(simpleXMLObject.getValue());\r
- }\r
- }\r
-};\r
-\r
-class SimpleXMLObjectUnmarshaller : public AbstractXMLObjectUnmarshaller\r
-{\r
-public:\r
- SimpleXMLObjectUnmarshaller() {}\r
-\r
-private:\r
- void processChildElement(XMLObject& parentXMLObject, XMLObject* childXMLObject) const {\r
- SimpleXMLObject& simpleXMLObject = dynamic_cast<SimpleXMLObject&>(parentXMLObject);\r
-\r
- SimpleXMLObject* child = dynamic_cast<SimpleXMLObject*>(childXMLObject);\r
- if (child) {\r
- simpleXMLObject.getSimpleXMLObjects().push_back(child);\r
- }\r
- else {\r
- throw UnmarshallingException("Unknown child element cannot be added to parent object.");\r
- }\r
- }\r
-\r
- void processAttribute(XMLObject& xmlObject, const DOMAttr* attribute) const {\r
- SimpleXMLObject& simpleXMLObject = dynamic_cast<SimpleXMLObject&>(xmlObject);\r
-\r
- if (XMLString::equals(attribute->getLocalName(),SimpleXMLObject::ID_ATTRIB_NAME)) {\r
- simpleXMLObject.setId(attribute->getValue());\r
- }\r
- else {\r
- throw UnmarshallingException("Unknown attribute cannot be processed by parent object.");\r
- }\r
- }\r
-\r
- void processElementContent(XMLObject& xmlObject, const XMLCh* elementContent) const {\r
- SimpleXMLObject& simpleXMLObject = dynamic_cast<SimpleXMLObject&>(xmlObject);\r
- \r
- simpleXMLObject.setValue(elementContent);\r
- }\r
-\r
-};\r
-\r
-class WildcardXMLObjectMarshaller;\r
-\r
-class WildcardXMLObject : public AbstractExtensibleXMLObject, public AbstractAttributeExtensibleXMLObject\r
-{\r
- friend class WildcardXMLObjectMarshaller;\r
-public:\r
- WildcardXMLObject(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix)\r
- : AbstractDOMCachingXMLObject(nsURI, localName, prefix),\r
- AbstractExtensibleXMLObject(nsURI, localName, prefix),\r
- AbstractAttributeExtensibleXMLObject(nsURI, localName, prefix) {}\r
- virtual ~WildcardXMLObject() {}\r
- \r
- WildcardXMLObject* clone() const {\r
- auto_ptr<XMLObject> domClone(AbstractDOMCachingXMLObject::clone());\r
- WildcardXMLObject* ret=dynamic_cast<WildcardXMLObject*>(domClone.get());\r
- if (ret) {\r
- domClone.release();\r
- return ret;\r
- }\r
-\r
- ret=new WildcardXMLObject(\r
- getElementQName().getNamespaceURI(),getElementQName().getLocalPart(),getElementQName().getPrefix()\r
- );\r
- for (map<QName,XMLCh*>::const_iterator i=m_attributeMap.begin(); i!=m_attributeMap.end(); i++) {\r
- ret->m_attributeMap[i->first]=XMLString::replicate(i->second);\r
- }\r
- xmltooling::clone(m_children, ret->m_children);\r
- return ret;\r
- }\r
-};\r
-\r
-class WildcardXMLObjectBuilder : public XMLObjectBuilder\r
-{\r
-public:\r
- XMLObject* buildObject() const {\r
- throw XMLObjectException("No default builder available.");\r
- }\r
-\r
- WildcardXMLObject* buildObject(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix) const {\r
- return new WildcardXMLObject(nsURI,localName,prefix);\r
- }\r
-};\r
-\r
-class WildcardXMLObjectMarshaller : public AbstractXMLObjectMarshaller\r
-{\r
-public:\r
- WildcardXMLObjectMarshaller() : AbstractXMLObjectMarshaller() {}\r
-\r
-private:\r
- void marshallAttributes(const XMLObject& xmlObject, DOMElement* domElement) const {\r
- const WildcardXMLObject& wcXMLObject = dynamic_cast<const WildcardXMLObject&>(xmlObject);\r
-\r
- for (map<QName,XMLCh*>::const_iterator i=wcXMLObject.m_attributeMap.begin(); i!=wcXMLObject.m_attributeMap.end(); i++) {\r
- DOMAttr* attr=domElement->getOwnerDocument()->createAttributeNS(i->first.getNamespaceURI(),i->first.getLocalPart());\r
- if (i->first.hasPrefix())\r
- attr->setPrefix(i->first.getPrefix());\r
- attr->setNodeValue(i->second);\r
- domElement->setAttributeNode(attr);\r
- }\r
- }\r
-\r
- void marshallElementContent(const XMLObject& xmlObject, DOMElement* domElement) const {\r
- const WildcardXMLObject& wcXMLObject = dynamic_cast<const WildcardXMLObject&>(xmlObject);\r
-\r
- if(wcXMLObject.getTextContent()) {\r
- domElement->appendChild(domElement->getOwnerDocument()->createTextNode(wcXMLObject.getTextContent()));\r
- }\r
- }\r
-};\r
-\r
-class WildcardXMLObjectUnmarshaller : public AbstractXMLObjectUnmarshaller\r
-{\r
-public:\r
- WildcardXMLObjectUnmarshaller() {}\r
-\r
-private:\r
- XMLObject* buildXMLObject(const DOMElement* domElement) const {\r
- const WildcardXMLObjectBuilder* builder =\r
- dynamic_cast<const WildcardXMLObjectBuilder*>(XMLObjectBuilder::getBuilder(domElement));\r
- if (builder)\r
- return builder->buildObject(domElement->getNamespaceURI(),domElement->getLocalName(),domElement->getPrefix());\r
- throw UnmarshallingException("Failed to locate WildcardObjectBuilder for element.");\r
- }\r
-\r
- void processChildElement(XMLObject& parentXMLObject, XMLObject* childXMLObject) const {\r
- WildcardXMLObject& wcXMLObject = dynamic_cast<WildcardXMLObject&>(parentXMLObject);\r
-\r
- wcXMLObject.getXMLObjects().push_back(childXMLObject);\r
- }\r
-\r
- void processAttribute(XMLObject& xmlObject, const DOMAttr* attribute) const {\r
- WildcardXMLObject& wcXMLObject = dynamic_cast<WildcardXMLObject&>(xmlObject);\r
- \r
- wcXMLObject.setAttribute(\r
- QName(attribute->getNamespaceURI(),attribute->getLocalName(),attribute->getPrefix()),\r
- attribute->getNodeValue()\r
- );\r
- }\r
-\r
- void processElementContent(XMLObject& xmlObject, const XMLCh* elementContent) const {\r
- WildcardXMLObject& wcXMLObject = dynamic_cast<WildcardXMLObject&>(xmlObject);\r
- \r
- wcXMLObject.setTextContent(elementContent);\r
- }\r
-\r
-};\r
-\r
-#if defined (_MSC_VER)\r
- #pragma warning( pop )\r
-#endif\r
+/**
+ * Licensed to the University Corporation for Advanced Internet
+ * Development, Inc. (UCAID) under one or more contributor license
+ * agreements. See the NOTICE file distributed with this work for
+ * additional information regarding copyright ownership.
+ *
+ * UCAID licenses this file to you under the Apache License,
+ * Version 2.0 (the "License"); you may not use this file except
+ * in compliance with the License. You may obtain a copy of the
+ * License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
+ * either express or implied. See the License for the specific
+ * language governing permissions and limitations under the License.
+ */
+
+#include <cxxtest/TestSuite.h>
+#include <xmltooling/AbstractAttributeExtensibleXMLObject.h>
+#include <xmltooling/AbstractComplexElement.h>
+#include <xmltooling/ElementProxy.h>
+#include <xmltooling/exceptions.h>
+#include <xmltooling/XMLObjectBuilder.h>
+#include <xmltooling/XMLToolingConfig.h>
+#include <xmltooling/io/AbstractXMLObjectMarshaller.h>
+#include <xmltooling/io/AbstractXMLObjectUnmarshaller.h>
+#include <xmltooling/impl/AnyElement.h>
+#include <xmltooling/impl/UnknownElement.h>
+#include <xmltooling/util/ParserPool.h>
+#include <xmltooling/util/XMLConstants.h>
+#include <xmltooling/util/XMLHelper.h>
+#include <xmltooling/util/XMLObjectChildrenList.h>
+
+#ifndef XMLTOOLING_NO_XMLSEC
+ #include <xmltooling/signature/Signature.h>
+ using namespace xmlsignature;
+#endif
+
+using namespace xmltooling;
+using namespace xercesc;
+using namespace std;
+
+extern string data_path;
+
+#if defined (_MSC_VER)
+ #pragma warning( push )
+ #pragma warning( disable : 4250 4251 )
+#endif
+
+class SimpleXMLObject
+ : public AbstractAttributeExtensibleXMLObject,
+ public AbstractComplexElement,
+ public AbstractDOMCachingXMLObject,
+ public AbstractXMLObjectMarshaller,
+ public AbstractXMLObjectUnmarshaller
+{
+protected:
+ SimpleXMLObject(const SimpleXMLObject& src)
+ : AbstractXMLObject(src), AbstractAttributeExtensibleXMLObject(src), AbstractComplexElement(src), AbstractDOMCachingXMLObject(src),
+ m_id(XMLString::replicate(src.m_id)) {
+#ifndef XMLTOOLING_NO_XMLSEC
+ m_children.push_back(nullptr);
+ m_signature=m_children.begin();
+#endif
+ VectorOf(SimpleXMLObject) mine=getSimpleXMLObjects();
+ for (vector<SimpleXMLObject*>::const_iterator i=src.m_simples.begin(); i!=src.m_simples.end(); i++) {
+ mine.push_back(dynamic_cast<SimpleXMLObject*>((*i)->clone()));
+ }
+ }
+
+public:
+ static const XMLCh NAMESPACE[];
+ static const XMLCh NAMESPACE_PREFIX[];
+ static const XMLCh LOCAL_NAME[];
+ static const XMLCh DERIVED_NAME[];
+ static const XMLCh TYPE_NAME[];
+ static const XMLCh ID_ATTRIB_NAME[];
+
+ SimpleXMLObject(
+ const XMLCh* nsURI=nullptr, const XMLCh* localName=nullptr, const XMLCh* prefix=nullptr, const xmltooling::QName* schemaType=nullptr
+ ) : AbstractXMLObject(nsURI, localName, prefix, schemaType), m_id(nullptr) {
+#ifndef XMLTOOLING_NO_XMLSEC
+ m_children.push_back(nullptr);
+ m_signature=m_children.begin();
+#endif
+ }
+
+ virtual ~SimpleXMLObject() {
+ XMLString::release(&m_id);
+ }
+
+ XMLObject* clone() const {
+ auto_ptr<XMLObject> domClone(AbstractDOMCachingXMLObject::clone());
+ SimpleXMLObject* ret=dynamic_cast<SimpleXMLObject*>(domClone.get());
+ if (ret) {
+ domClone.release();
+ return ret;
+ }
+
+ return new SimpleXMLObject(*this);
+ }
+
+ const XMLCh* getXMLID() const { return getId(); }
+ const XMLCh* getId() const { return m_id; }
+ void setId(const XMLCh* id) { m_id=prepareForAssignment(m_id,id); }
+
+ const XMLCh* getValue() const { return getTextContent(); }
+ void setValue(const XMLCh* value) { setTextContent(value); }
+
+#ifndef XMLTOOLING_NO_XMLSEC
+ Signature* getSignature() const {
+ return dynamic_cast<Signature*>(*m_signature);
+ }
+
+ void setSignature(Signature* sig) {
+ *m_signature=prepareForAssignment(*m_signature,sig);
+ }
+#endif
+
+ VectorOf(SimpleXMLObject) getSimpleXMLObjects() {
+ return VectorOf(SimpleXMLObject)(this, m_simples, &m_children, m_children.end());
+ }
+
+ const std::vector<SimpleXMLObject*>& getSimpleXMLObjects() const {
+ return m_simples;
+ }
+
+protected:
+ void marshallAttributes(xercesc::DOMElement* domElement) const {
+ if(getId()) {
+ domElement->setAttributeNS(nullptr, SimpleXMLObject::ID_ATTRIB_NAME, getId());
+#ifdef XMLTOOLING_XERCESC_BOOLSETIDATTRIBUTE
+ domElement->setIdAttributeNS(nullptr, SimpleXMLObject::ID_ATTRIB_NAME, true);
+#else
+ domElement->setIdAttributeNS(nullptr, SimpleXMLObject::ID_ATTRIB_NAME);
+#endif
+ }
+ marshallExtensionAttributes(domElement);
+ }
+
+ void processChildElement(XMLObject* childXMLObject, const xercesc::DOMElement* root) {
+ SimpleXMLObject* simple=dynamic_cast<SimpleXMLObject*>(childXMLObject);
+ if (simple) {
+ getSimpleXMLObjects().push_back(simple);
+ return;
+ }
+
+#ifndef XMLTOOLING_NO_XMLSEC
+ Signature* sig=dynamic_cast<Signature*>(childXMLObject);
+ if (sig) {
+ setSignature(sig);
+ return;
+ }
+#endif
+
+ throw UnmarshallingException("Unknown child element cannot be added to parent object.");
+ }
+
+ void processAttribute(const xercesc::DOMAttr* attribute) {
+ if (XMLHelper::isNodeNamed(attribute, nullptr, SimpleXMLObject::ID_ATTRIB_NAME)) {
+ setId(attribute->getValue());
+ return;
+ }
+ unmarshallExtensionAttribute(attribute);
+ }
+
+private:
+ XMLCh* m_id;
+ vector<SimpleXMLObject*> m_simples;
+#ifndef XMLTOOLING_NO_XMLSEC
+ list<XMLObject*>::iterator m_signature;
+#endif
+};
+
+class SimpleXMLObjectBuilder : public XMLObjectBuilder
+{
+public:
+ XMLObject* buildObject() const {
+ return buildObject(SimpleXMLObject::NAMESPACE, SimpleXMLObject::LOCAL_NAME, SimpleXMLObject::NAMESPACE_PREFIX);
+ }
+
+ XMLObject* buildObject(
+ const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=nullptr, const xmltooling::QName* schemaType=nullptr
+ ) const {
+ return new SimpleXMLObject(nsURI, localName, prefix, schemaType);
+ }
+
+ static SimpleXMLObject* buildSimpleXMLObject() {
+ const SimpleXMLObjectBuilder* b = dynamic_cast<const SimpleXMLObjectBuilder*>(
+ XMLObjectBuilder::getBuilder(xmltooling::QName(SimpleXMLObject::NAMESPACE,SimpleXMLObject::LOCAL_NAME))
+ );
+ if (b)
+ return dynamic_cast<SimpleXMLObject*>(b->buildObject());
+ throw XMLObjectException("Unable to obtain typed builder for SimpleXMLObject.");
+ }
+};
+
+#if defined (_MSC_VER)
+ #pragma warning( pop )
+#endif