#include "signature/KeyInfo.h"
#include "util/XMLHelper.h"
+#include <boost/lambda/bind.hpp>
+#include <boost/lambda/casts.hpp>
+#include <boost/lambda/if.hpp>
+#include <boost/lambda/lambda.hpp>
#include <xercesc/util/XMLUniDefs.hpp>
using namespace xmlencryption;
EncryptionMethodImpl(const EncryptionMethodImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src), AbstractDOMCachingXMLObject(src) {
init();
- setAlgorithm(src.getAlgorithm());
- if (src.getKeySize())
- setKeySize(src.getKeySize()->cloneKeySize());
- if (src.getOAEPparams())
- setOAEPparams(src.getOAEPparams()->cloneOAEPparams());
- for (vector<XMLObject*>::const_iterator i=src.m_UnknownXMLObjects.begin(); i!=src.m_UnknownXMLObjects.end(); ++i) {
- if (*i) {
- getUnknownXMLObjects().push_back((*i)->clone());
- }
- }
+ IMPL_CLONE_ATTRIB(Algorithm);
+ IMPL_CLONE_TYPED_CHILD(KeySize);
+ IMPL_CLONE_TYPED_CHILD(OAEPparams);
+ IMPL_CLONE_XMLOBJECT_CHILDREN();
}
IMPL_XMLOBJECT_CLONE(EncryptionMethod);
TransformsImpl(const TransformsImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src), AbstractDOMCachingXMLObject(src) {
- for (vector<xmlsignature::Transform*>::const_iterator i=src.m_Transforms.begin(); i!=src.m_Transforms.end(); i++) {
- if (*i) {
- getTransforms().push_back((*i)->cloneTransform());
- }
- }
+ IMPL_CLONE_TYPED_FOREIGN_CHILDREN(Transform,xmlsignature);
}
IMPL_XMLOBJECT_CLONE(Transforms);
CipherReferenceImpl(const CipherReferenceImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src), AbstractDOMCachingXMLObject(src) {
init();
- setURI(src.getURI());
- if (src.getTransforms())
- setTransforms(src.getTransforms()->cloneTransforms());
+ IMPL_CLONE_ATTRIB(URI);
+ IMPL_CLONE_TYPED_CHILD(Transforms);
}
IMPL_XMLOBJECT_CLONE(CipherReference);
CipherDataImpl(const CipherDataImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src), AbstractDOMCachingXMLObject(src) {
init();
- if (src.getCipherValue())
- setCipherValue(src.getCipherValue()->cloneCipherValue());
- if (src.getCipherReference())
- setCipherReference(src.getCipherReference()->cloneCipherReference());
+ IMPL_CLONE_TYPED_CHILD(CipherValue);
+ IMPL_CLONE_TYPED_CHILD(CipherReference);
}
IMPL_XMLOBJECT_CLONE(CipherData);
AbstractComplexElement(src),
AbstractDOMCachingXMLObject(src) {
init();
- setId(src.getId());
- setTarget(src.getTarget());
- for (vector<XMLObject*>::const_iterator i=src.m_UnknownXMLObjects.begin(); i!=src.m_UnknownXMLObjects.end(); ++i) {
- if (*i) {
- getUnknownXMLObjects().push_back((*i)->clone());
- }
- }
+ IMPL_CLONE_ATTRIB(Id);
+ IMPL_CLONE_ATTRIB(Target);
+ IMPL_CLONE_XMLOBJECT_CHILDREN();
}
IMPL_XMLOBJECT_CLONE(EncryptionProperty);
EncryptionPropertiesImpl(const EncryptionPropertiesImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src), AbstractDOMCachingXMLObject(src) {
init();
- setId(src.getId());
- for (vector<EncryptionProperty*>::const_iterator i=src.m_EncryptionPropertys.begin(); i!=src.m_EncryptionPropertys.end(); i++) {
- if (*i) {
- getEncryptionPropertys().push_back((*i)->cloneEncryptionProperty());
- }
- }
+ IMPL_CLONE_ATTRIB(Id);
+ IMPL_CLONE_TYPED_CHILDREN(EncryptionProperty);
}
IMPL_XMLOBJECT_CLONE(EncryptionProperties);
}
void _clone(const ReferenceTypeImpl& src) {
- setURI(src.getURI());
- for (vector<XMLObject*>::const_iterator i=src.m_UnknownXMLObjects.begin(); i!=src.m_UnknownXMLObjects.end(); ++i) {
- if (*i) {
- getUnknownXMLObjects().push_back((*i)->clone());
- }
- }
+ IMPL_CLONE_ATTRIB(URI);
+ IMPL_CLONE_XMLOBJECT_CHILDREN();
}
IMPL_XMLOBJECT_CLONE_EX(ReferenceType);
ReferenceListImpl(const ReferenceListImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src), AbstractDOMCachingXMLObject(src) {
- for (list<XMLObject*>::const_iterator i=src.m_children.begin(); i!=src.m_children.end(); i++) {
- if (*i) {
- DataReference* data=dynamic_cast<DataReference*>(*i);
- if (data) {
- getDataReferences().push_back(data->cloneDataReference());
- continue;
- }
-
- KeyReference* key=dynamic_cast<KeyReference*>(*i);
- if (key) {
- getKeyReferences().push_back(key->cloneKeyReference());
- continue;
- }
+ for (list<XMLObject*>::const_iterator i = src.m_children.begin(); i != src.m_children.end(); ++i) {
+ DataReference* data=dynamic_cast<DataReference*>(*i);
+ if (data) {
+ getDataReferences().push_back(data->cloneDataReference());
+ continue;
+ }
+
+ KeyReference* key=dynamic_cast<KeyReference*>(*i);
+ if (key) {
+ getKeyReferences().push_back(key->cloneKeyReference());
+ continue;
}
}
}
}
void _clone(const EncryptedTypeImpl& src) {
- setId(src.getId());
- setType(src.getType());
- setMimeType(src.getMimeType());
- setEncoding(src.getEncoding());
- if (src.getEncryptionMethod())
- setEncryptionMethod(src.getEncryptionMethod()->cloneEncryptionMethod());
- if (src.getKeyInfo())
- setKeyInfo(src.getKeyInfo()->cloneKeyInfo());
- if (src.getCipherData())
- setCipherData(src.getCipherData()->cloneCipherData());
- if (src.getEncryptionProperties())
- setEncryptionProperties(src.getEncryptionProperties()->cloneEncryptionProperties());
+ IMPL_CLONE_ATTRIB(Id);
+ IMPL_CLONE_ATTRIB(Type);
+ IMPL_CLONE_ATTRIB(MimeType);
+ IMPL_CLONE_ATTRIB(Encoding);
+ IMPL_CLONE_TYPED_CHILD(EncryptionMethod);
+ IMPL_CLONE_TYPED_CHILD(KeyInfo);
+ IMPL_CLONE_TYPED_CHILD(CipherData);
+ IMPL_CLONE_TYPED_CHILD(EncryptionProperties);
}
IMPL_XMLOBJECT_CLONE_EX(EncryptedType);
void _clone(const EncryptedKeyImpl& src) {
EncryptedTypeImpl::_clone(src);
- setRecipient(src.getRecipient());
- if (src.getReferenceList())
- setReferenceList(src.getReferenceList()->cloneReferenceList());
- if (src.getCarriedKeyName())
- setCarriedKeyName(src.getCarriedKeyName()->cloneCarriedKeyName());
+ IMPL_CLONE_ATTRIB(Recipient);
+ IMPL_CLONE_TYPED_CHILD(ReferenceList);
+ IMPL_CLONE_TYPED_CHILD(CarriedKeyName);
}
IMPL_XMLOBJECT_CLONE_EX(EncryptedKey);